2010-06-11 95 views
3

我想爲所有實體SaveChanges方法調用實施應用程序範圍重試系統。EF 4.0:保存更改重試邏輯

技術:
實體框架4.0
.NET 4.0

namespace Sample.Data.Store.Entities { 
    public partial class StoreDB 
    { 
     public override int SaveChanges(System.Data.Objects.SaveOptions options) 
     {    
      for (Int32 attempt = 1; ;) 
      { 

       try 
       { 
        return base.SaveChanges(options); 
       } 
       catch (SqlException sqlException) 
       { 
        // Increment Trys 
        attempt++; 

        // Find Maximum Trys 
        Int32 maxRetryCount = 5; 

        // Throw Error if we have reach the maximum number of retries 
        if (attempt == maxRetryCount) 
         throw; 

        // Determine if we should retry or abort. 
        if (!RetryLitmus(sqlException)) 
         throw; 
        else 
         Thread.Sleep(ConnectionRetryWaitSeconds(attempt)); 
       } 
      } 
     } 

     static Int32 ConnectionRetryWaitSeconds(Int32 attempt) 
     { 
      Int32 connectionRetryWaitSeconds = 2000; 

      // Backoff Throttling 
      connectionRetryWaitSeconds = connectionRetryWaitSeconds * 
       (Int32)Math.Pow(2, attempt); 

      return (connectionRetryWaitSeconds); 
     } 



     /// <summary> 
     /// Determine from the exception if the execution 
     /// of the connection should Be attempted again 
     /// </summary> 
     /// <param name="exception">Generic Exception</param> 
     /// <returns>True if a a retry is needed, false if not</returns> 
     static Boolean RetryLitmus(SqlException sqlException) 
     { 
     switch (sqlException.Number) 
      { 
       // The service has encountered an error 
       // processing your request. Please try again. 
       // Error code %d. 
       case 40197: 
       // The service is currently busy. Retry 
       // the request after 10 seconds. Code: %d. 
       case 40501: 
       //A transport-level error has occurred when 
       // receiving results from the server. (provider: 
       // TCP Provider, error: 0 - An established connection 
       // was aborted by the software in your host machine.) 
       case 10053: 
        return (true); 
      } 

      return (false); 
     } 
    } 
} 

問題:

我怎麼可以運行StoreDB.SaveChanges到一個新的DB背景下重試錯誤發生後? 與Detach/Attach類似的東西可能會派上用場。

在此先感謝! Bart

回答

0

查看SQL Azure的瞬態故障處理框架,here。這是非常通用的,並且很容易修改以包含後端的重試邏輯。