SQL Server中的timeout設定

來源:互聯網
上載者:User

上篇文章中, 我們總結了SharePoint裡的timeout相關的設定, 文章中我們說到SQL端的選項是不會有什麼影響的. 為什麼這麼說呢?

筆者這一塊原來也是暈乎乎. 於是去諮詢SQL的資深進階支援人員工程師Peter, 得到了如下的答案.

1. 與SQL相關的timeout, 都是由Client端發起的.

比如說, 我們自己寫了個C#小程式, 其中使用了SqlCommand.CommandTimeout屬性, 指定它的值為20秒. 那麼, 當這個query在SQL端執行了二十秒後, 我們的C#小程式會給SQL Server發送一個TDS Tension資料包, 告訴SQL Server我這邊逾時了, 你那邊的query不用做了. 於是SQL相應client的請求, 斷掉connection. Client端報出一條exception, 說SQL Server端的已耗用時間太長, 超過了我們原定的時限.

 

2. 那麼SQL Server Management Studio中有如下兩個有關Timeout的選項, 他們是幹什麼的呢?

  • a. Tools->Options->Query Exection->Execution time-out.

             

  • b. Right click SQL Server Node->Properties->Connections->Remote Query Timeout.

             

 

如果我們把Management Studio看作是我們自己寫的C#程式, 在這個程式中我們唯寫下來要執行的語句, timeout設定呢? 這裡的a選項指定的值就是SqlCommand.CommandTimeout. 好懂吧. ^_^

 

假設我們的C#小程式串連到SQL Server 1上運行預存程序取資料, 在這個預存程序中, SQL Server 1需要到SQL Server 2上去取未經處理資料. 那麼, 如果SQL Server 2上的查詢執行了600秒之後(預設值), 那麼SQL Server 1會發給SQL Server 2, 告訴它這個查詢我嫌它太久, 你不要做了. 於是SQL Server 1 發給SQL Server 2一個資料包, 告訴它停吧. 然後Server 2斷掉他們之間的Connection.

 

由此可見, 在一般情況下, b選項與我們關係不是很大.

 

我在研究這兩個選項的時候, 發現StackOverFlow.com上的網友問起相關的問題, 回答問題的人經常給出這兩個選項. 其實這是錯誤的. 調整了之後也不會對SQL端運行逾時的問題有改善的.

 

感謝Peter Zhu提供的精彩講解, 我在這裡才能分享給大家.

 

技術無止境, 這麼小的一個選項後面竟然有這麼多陷阱呀.

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.