Zaimplementowałem następujący kod obsługi operacji logicznej INSERT/UPDATE z wykładniczym wycofaniem podczas zapisu do bazy danych Azure.Logika ponownej próby SQL Azure Database
static SqlConnection TryOpen(this SqlConnection connection)
{
int attempts = 0;
while (attempts < 5)
{
try
{
if (attempts > 0)
System.Threading.Thread.Sleep(((int)Math.Pow(3, attempts)) * 1000);
connection.Open();
return connection;
}
catch { }
attempts++;
}
throw new Exception("Unable to obtain a connection to SQL Server or SQL Azure.");
}
Jednak czy powinienem rozważyć zastosowanie logiki ponownej dla odczytów z mojej bazy danych? A może wystarczy metoda SqlCommand.CommandTimeout()? Większość moich odczytów są ustanowione za pomocą następującego kodu:
Dim myDateAdapter As New SqlDataAdapter(mySqlCommand)
Dim ds As New DataSet
myDateAdapter.Fill(ds, "dtName")
Trudno wiedzieć, jakiego rodzaju błędy przejściowe wystąpią w środowisku produkcyjnym z Azure więc staram się robić jak najwięcej jak to możliwe złagodzenie teraz.
Zajmę się tym teraz. Czy blok TFH zawiera szczegółowe informacje o tym, dlaczego połączenie zostało przerwane? – QFDev