Logika ponawiania bazy danych SQL Azure

Zaimplementowałem następujący kod do obsługi logiki ponownej próby INSERT / UPDATE z wykładniczym odczekiwaniem podczas zapisywania do bazy danych Azure.

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.");
}

Czy jednak powinienem rozważyć zastosowanie logiki ponownej próby również dla moich odczytów z bazy danych? Czy może wystarczy metoda SqlCommand.CommandTimeout ()? Większość moich czytań jest wprowadzana za pomocą następującego kodu:

Dim myDateAdapter As New SqlDataAdapter(mySqlCommand)
Dim ds As New DataSet
myDateAdapter.Fill(ds, "dtName")

Trudno jest stwierdzić, jakie błędy przejściowe wystąpią w środowisku produkcyjnym z Azure, więc staram się jak najbardziej zminimalizować.

questionAnswers(3)

yourAnswerToTheQuestion