Prática recomendada do DocumentDB TransientFaultHandling
Eu tenho escrito uma lógica de repetição muito detalhada para chamadas de cliente do DocumentDB otimizadas.
O exemplo abaixo é um exemplo comum disso com 10 tentativas de repetição.
Minha pergunta é dupla: Essa é uma prática recomendada e existe uma maneira menos detalhada de lidar com isso? Eu vejo que existe umMicrosoft.Azure.Documents.Client.TransientFaultHandling pacote nuget que deve obter os mesmos resultados com menos código, mas não consigo encontrar nenhum exemplo no StackOverflow ou no Google e não parece haver nenhuma documentação clara disponível na Microsoft.
int maxRetryAttempts = 10;
while (maxRetryAttempts > 0)
{
try
{
// Attempt to call DocumentDB Method
// ---[DocumentDB Method Here]---
}
catch (DocumentClientException de)
{
if (de.StatusCode.HasValue)
{
var statusCode = (int)de.StatusCode;
if (statusCode == 429 || statusCode == 503)
{
//Sleep for retry amount
Thread.Sleep(de.RetryAfter);
//Decrement max retry attempts
maxRetryAttempts--;
}
}
}
catch (AggregateException ae)
{
foreach (Exception ex in ae.InnerExceptions)
{
if (ex is DocumentClientException)
{
var documentClientException = ex as DocumentClientException;
var statusCode = (int)documentClientException.StatusCode;
if (statusCode == 429 || statusCode == 503)
{
//Sleep for retry amount
Thread.Sleep(documentClientException.RetryAfter);
//Decrement max retry attempts
maxRetryAttempts--;
}
else
{
throw;
}
}
}
}
}
if (maxRetryAttempts < 0)
{
//Max retry attempts reached
}