親測SQLServer的最大連接數


很多做架構設計、程序開發、運維、技術管理的朋友可能或多或少有這樣的困惑:

 

  1. SQLServer到底支持多少連接數的並發?
  2. SQLServer是否可以滿足現有的應用嗎?
  3. 現有的技術架構支持多少連接數的並發?
  4. 在硬件性能與網絡性能足夠理想的情況下理論上可以支持多少並發連接?
  5. 生產環境中的數據庫現在的並發量是多少?
  6. 如何監控現有數據庫並發的數量?
  7. 生產環境中的並發量距離理論上的最大並量發還差多少?

為此,我專門寫程序做了下測試,利用循環不斷的打開連接並保持連接打開不關閉,測試代碼如下:

 

 1  using System;
 2  using System.Collections.Generic;
 3 
 4  namespace SQLServerMaxConnectionTest
 5 {
 6      class Program
 7     {
 8          static  void Main( string[] args)
 9         {
10              int maxCount =  40000;
11             List<HotSpotEntities> collection =  new List<HotSpotEntities>();
12              for ( int i =  0; i < maxCount; i++)
13             {
14                 Console.WriteLine( string.Format( " 成功創建連接對象{0} ",i));
15                  var db =  new HotSpotEntities();
16                 db.Connection.Open();
17                 collection.Add(db);
18             }
19         }
20     }
21 }

 

第一輪的測試結果令我比較吃驚。

 

當創建到101個連接的時候,就無法再創建新連接了。也就是說,如果連接字符串不做任何處理,我們的程序只能夠跟SQLServer建立101個連接。測試結果截圖如下:

 

 

第二輪測試,啟用連接池。

 

在連接字符串中加入代碼:

Pooling=true;Max Pool Size=40000;Min Pool Size=0;

連續若干次內存都被耗盡了,不過結果還算欣慰。

 

 

最高記錄是29299,很顯然不是最高記錄,只因為我的筆記本內存有限,所以很難突破。

 

微軟對最大連接數的定義


 

微軟在MSDN上對最大連接數的定義是:“默認是0,代表不限制,但最大連接數是32767”。 如下圖所示:

 

 有興趣的朋友可以自己編寫代碼測試、分享一下。

 

如何監測SQLServer的連接數

 

SP_WHO 'loginName'
loginName 是當然登陸Sql的用戶名,一般程序里面都會使用一個username來登陸SQL這樣通過這個用戶名就能查看到此用戶名登陸之后占用的連接了。
如果不寫loginName,那么返回的就是所有的連接。

既然連接數是可預測、可監測的,那么它就是可度量的,那么我們就可以根據實際情況來評估或測試程序的並發放量了。

 

有了這些,相信以上的困惑應該可以解開了吧。

 

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM