Ниже я демонстрирую политику, которую я использую для обработки запроса postAsync () с использованием httpclient. Тем не менее, кажется, что, несмотря на то, что я прошел общее исключение , он все еще решает бросить его и не повторно повторно. Я хотел бы спросить, почему это и любые обходные пути. < /P>
var retryPolicy = Policy.Handle()
.WaitAndRetryForeverAsync(
retryAttempt => TimeSpan.FromSeconds(Math.Pow(2, retryAttempt)),
onRetry: (exception, timeSpan) =>
{
_logger.Log(LogEnums.Error, $"Post failure on Authenticating Client for {this.GetType().Name.Replace("_", " ")}. Trying again...");
});
foreach (var payload in payloads)
{
var stringPayload = JsonConvert.SerializeObject(payload);
var httpContent = new StringContent(stringPayload, Encoding.UTF8, "application/json");
var r2 = await retryPolicy.ExecuteAsync(() =>
_httpClient.PostAsync($"{_moduleConfig.Endpoint}/options/selected", httpContent));
r2.EnsureSuccessStatusCode();
}
< /code>
Я также пытался использовать тайм -аут политики, а не время ожидания HttpClient. Это, казалось, имел такой же результат. См. Ответ для получения дополнительного контекста < /p>
Я также хотел бы добавить, что эта повторная повторная ретрика находится внутри залов, и исключение, которое будет отменено, запрос был отменен из -за настроенного httpclient.imeout из 15 Секунды, которые истекают.>
Подробнее здесь: https://stackoverflow.com/questions/794 ... httpclient
Почему моя политика Полли повторной попытки в любом случае бросает исключения "поймал" (httpclient.timeout) ⇐ C#
-
- Похожие темы
- Ответы
- Просмотры
- Последнее сообщение
-
-
Как я могу добавить политику повторной попытки Полли в aspnetcore.healthchecks.uris
Anonymous » » в форуме C# - 0 Ответы
- 12 Просмотры
-
Последнее сообщение Anonymous
-
-
-
SQL Server Timeout Timeout Post-Login Phase Docker .net8 openssl3.0 уже конфигурация для TLSV1
Anonymous » » в форуме C# - 0 Ответы
- 52 Просмотры
-
Последнее сообщение Anonymous
-