Я использую Polly для исключения SQL в моем коде. В этой ситуации код выполняет непосредственно поймать блок, но никогда не повторяйте, чтобы подключить SQL Server.
RetryAutoPolicy retryAutoPolicy = new RetryAutoPolicy();
retryAutoPolicy.retryEvery5SecondsUpTo3Minutes.Execute(() =>
{
using (var conn = new SqlConnection(ProjDB_ConnectionString))
{
try
{
//**This part is not handling Retrying.. Directly went to catch block. Instead of retry for 3 minutes for every 5 seconds**
conn.Open();
string selectCommand = "SELECT TOP 1 * FROM [dbo].[TABLEA]";
var command = new SqlCommand(selectCommand, conn);
//Console.WriteLine($" commandTime out is {command.CommandTimeout} And Connection Timeout is {conn.ConnectionTimeout}");
using (SqlDataReader reader = command.ExecuteReader())
{
while (reader.Read())
{
Console.WriteLine($"Response is - " + String.Format("{0}", reader[0]));
}
}
}
**catch (Exception e)
{
Console.WriteLine($"Erros is" + e.Message);
}**
conn.Close();
}
});
public Policy retryEvery5SecondsUpTo3Minutes
{
Policy timeoutAfter3Minutes = Policy.Timeout(TimeSpan.FromMinutes(totalRetryTimeLimit));
Policy retrySqlConnEvery5Seconds = Policy.Handle
.WaitAndRetryForever(sleepDurationProvider: i => TimeSpan.FromSeconds(delaySecondsAfterTries)
, (exception, retry, timespan) =>
{
Console.WriteLine($"Retry Count [{retry}] ");
});
retryEvery5SecondsUpTo3Minutes = timeoutAfter3Minutes.Wrap(retrySqlConnEvery5Seconds);
}
< /code>
У меня уже есть попытка поймать перед открытием подключения к SQL и выполнить команду, которую я не могу изменить для нашего приложения.
Я добавил повторную попытку, чтобы обработать, если SQL Server Down. < /p>
Подробнее здесь: https://stackoverflow.com/questions/795 ... -try-catch
C# Polly, Polly не работает, если функция завершится ⇐ C#
-
- Похожие темы
- Ответы
- Просмотры
- Последнее сообщение
-
-
Что произойдет с аргументами потока, если создание потока завершится неудачно?
Anonymous » » в форуме C++ - 0 Ответы
- 35 Просмотры
-
Последнее сообщение Anonymous
-