標籤:class 返回 串連數 連續 測試 自己 距離 開啟 最大
很多做架構設計、程式開發、營運、技術管理的朋友可能或多或少有這樣的困惑:
- SQLServer到底支援多少串連數的並發?
- SQLServer是否可以滿足現有的應用嗎?
- 現有的技術架構支援多少串連數的並發?
- 在硬體效能與網路效能足夠理想的情況下理論上可以支援多少並發串連?
- 生產環境中的資料庫現在的並發量是多少?
- 如何監控現有資料庫並發的數量?
- 生產環境中的並發量距離理論上的最大並量發還差多少?
為此,我專門寫程式做了下測試,利用迴圈不斷的開啟串連並保持串連開啟不關閉,測試代碼如下:
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,那麼返回的就是所有的串連。
既然串連數是可預測、可監測的,那麼它就是可度量的,那麼我們就可以根據實際情況來評估或測試程式的並發放量了。
有了這些,相信以上的困惑應該可以解開了吧。
轉自:http://www.cnblogs.com/wlb/archive/2012/04/08/2437617.html
親測SQLServer的最大串連數