Skip to content

Getting Started with Polly

Polly Validation is a .NET library which helps implement resilience and fault handling policies to make your application more robust and resilient when interacting with external systems. By providing policies such as Retry, WaitAndRetry, and CircuitBreaker, Polly can help you reduce fragility, and keep your systems and customers connected.

In order to get started with Polly, do the following activities

Installing Polly Package

Install-Package Polly

Configuration

After installing the Polly package, configure and apply policies to your services. These are used to define behaviors for handling faults, retries, and circuit breaking when making HTTP requests.

c#
    //Configure WaitAndRetry policy
    _retryPolicy = Policy.Handle<HttpRequestException>()
        .OrResult<HttpResponseMessage>(r => !r.IsSuccessStatusCode)
        .WaitAndRetryAsync(3, retryAttempt => TimeSpan.FromSeconds(Math.Pow(2, retryAttempt)));

    //Configure Circuit Breaker policy
    _circuitBreakerPolicy = Policy.Handle<Exception>()
    .CircuitBreakerAsync(
        exceptionsAllowedBeforeBreaking: 3,
        durationOfBreak: TimeSpan.FromMinutes(1)
    );

    //Configure Timeout policy
    _timeoutPolicy = Policy.TimeoutAsync(TimeSpan.FromSeconds(30));

    //Configure Fallback policy
    _fallbackPolicy = Policy<string>.Handle<Exception>()
    .FallbackAsync("Fallback value");

    //Configure Bulkhead policy
    _bulkheadPolicy = Policy.BulkheadAsync(10, 2);

Sample Usage

This is a sample use case with the Retry policy to see how it works.

Configure and apply WaitAndRetry policy to service method

c#
    public class MyService
    {
        private readonly HttpClient _httpClient;
        private readonly Policy _retryPolicy;

        public MyService()
        {
            _httpClient = new HttpClient();

            // Configure WaitAndRetry policy
            _retryPolicy = Policy.Handle<HttpRequestException>()//define the exception or result to handle
                .OrResult<HttpResponseMessage>(r => !r.IsSuccessStatusCode)//include non-successful HTTP responses for retrying
                .WaitAndRetryAsync(3, retryAttempt => TimeSpan.FromSeconds(Math.Pow(2, retryAttempt)));//specify the retry count and the duration between retries.
        }

        public async Task<HttpResponseMessage> MakeHttpRequest() 
        {
            return await _retryPolicy.ExecuteAsync(() => _httpClient.GetAsync("https://api.example.com"));//applies the WaitAndRetry policy
        }

    }

Inject and consume service method

c#
    public class MyApplication
    {
        private readonly MyService _myService;

        public MyApp(MyService myService)
        {
            _myService = myService;
        }

        public async Task PerformHttpRequest()
        {
            try
            {
                HttpResponseMessage response = await _myService.MakeHttpRequest();//HTTP request is performed using WaitAndRetry policy
                // Process the response
            }
            catch (Exception ex)
            {
                // Handle the exception or log the error
            }
        }
    }

Polly provides various other policies such as Circuit Breaker, Timeout, Bulkhead, etc., which can be configured and applied as needed.

Further Readings

Follow this link to learn more.