Lógica de Repetição do Banco de Dados do SQL Azure
Implementei o código a seguir para lidar com a lógica de repetição INSERT / UPDATE com backoff exponencial ao gravar em um Banco de Dados do 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.");
}
No entanto, devo considerar a aplicação de lógica de repetição para minhas leituras de banco de dados também? Ou seria o método SqlCommand.CommandTimeout () suficiente? A maioria das minhas leituras são instituídas usando o seguinte código:
Dim myDateAdapter As New SqlDataAdapter(mySqlCommand)
Dim ds As New DataSet
myDateAdapter.Fill(ds, "dtName")
É difícil saber que tipo de erros temporários ocorrerão em um ambiente de produção com o Azure, portanto, estou tentando fazer o máximo de mitigação possível agora.