日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

SQL Serve里你总要去改变的3个配置选项

發布時間:2025/3/13 数据库 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 SQL Serve里你总要去改变的3个配置选项 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

你用安裝向導安裝了全新的SQL Server,最后你點擊了完成按鈕。哇噢~~~現在我們可以把我們的服務器進入生產了!抱歉,那并不是真的,因為你的全新SQL Server默認配置是錯誤的。

是的,你沒看錯:SQL Server的默認安裝在很多方面的配置是錯誤的。在今天的文章里,我想給你展示下,為了更快的性能,在SQL Server安裝完成后3個你需要立即修改的配置選項。我們開始吧!

最大服務器內存(Max Server Memory)

免責聲明:如果這些天你在32位系統上運行你的SQL Server,請扔掉你的硬件,買個64位的系統,安裝64位的SQL Server,然后從這里繼續讀。

現在在你面前你應該i有個64位的SQL Server。64位意味著你可以理論上訪問2^64的內存大小——那是16艾字節(10億GB)!因為這些巨量的內存,計算機供應商當前限制64位系統的地址總線“只有”48位——完全64位沒有真正意義。用48位的地址空間,你可以訪問256TB的內存——那還是大量的空間。

你可以使用最大服務器內存配置選項來配置SQL Server可以消耗的內存大小。下圖顯示的是在64位系統上SQL Server默認安裝后的配置選項。

從剛才的圖片你可以看到,SQL Server默認配置是可以消耗上至2147483647MB的內存——那是2千兆!嗯,用48位的地址總線我們只能物理訪問256TB的內存,現在SQL Server可以消耗上至2千兆的內存?這里有什么東西不對……最大服務器內存設置比32位最大整形值還大——2147483647。沒別的。因此SQL Server可以消耗比物理地址更多的內存?這是一個很不好的默認配置。SQL Server默認可以吃光你整個物理內存!

你總應該改變這個配置選項,這樣的話你可以給系統一些內存,讓它可以活著喘氣。一般來說(在服務器上沒有其它程序/進程)你應該系統至少10%的物理內存。這就是說你需要調低最大服務器內存設置。有64GB的物理內存我會配置最大服務器內存為56GB,這樣的話系統可以用剩下的8G來消耗和工作。

并行開銷閾值(Cost Threshold for Parallelism)

下一個你需要修改的配置選項是SQL Server處理并行開銷的閾值。并行意味著SQL Server能透過多個工作線程運行執行計劃里的運算符。并行的目的是提高你查詢的吞吐量。SQL Server里第1個影響并行的配置選項是所謂的并行開銷閾值

這里你配置的數字定義查詢成本,查詢優化器用它來找更便宜的并行執行計劃。如果找到的并行計劃更便宜,這個計劃會被執行,不然串行計劃會被執行。從剛才的圖你可以看到,SQL Server默認配置使用5的成本閾值。當你的串行計劃查詢成本大于5,然后查詢優化器再次運行查詢優化來找更便宜并行執行計劃的可能。

遺憾的是,5的成本值當下來說是個很小的數字。因此SQL Server太快嘗試并行你的執行計劃。當你處理更大的查詢并行才有意義——例如報表或數據倉庫情形。在純OLTP情形下,并行計劃象征著糟糕的索引設計,因為當你有缺失索引時,SQL Server需要掃描你的整個聚集索引(在與過濾(Filter)和剩余謂語(residual predicate)組合里),因此你的查詢成本越來越大,它們穿過成本閾值,最后查詢優化器給你并行計劃。當人們看到并行計劃時,總會擔心!但問題根源是缺失非聚集索引。

對于并行的成本閾值,我總推薦至少20,甚至50。那樣的話,你確保SQL Server只為你對更大的查詢進行并行。即使在你面前有個并行計劃,你也應該考慮下可否通過增加一個支持的非聚集索引來是這個查詢成本更低。另外,CXPACKET并不象征著在你的系統里你有并行問題!

最大并行度(Max Degree of Parallelism (MAXDOP))

當在SQL Server里一個執行計劃進入并行,最大并行度定義了執行計劃里每個并行運算符可用工作線程。下圖顯示了這個選項的默認配置。

如你所見,SQL Server使用默認值0。這個值意味著SQL Server嘗試并行化你的執行計劃穿過分配給SQL Server的所有CPU內核(默認情況所有內核都分配給SQL Server!)。你應該能看出這樣的設置沒有意義,尤其當你有大量CPU內核的系統。并行化本身帶來負擔,一旦你使用越多的工作線程,這個負擔越大。

一個建議是設置最大并行度為在一個NUMA結點里擁有的內核數。因此在查詢執行時,SQL Server會嘗試在一個NUMA結點里保持并行計劃,這也會提高性能。

有時你也會看到建議去設置最大并行度為1。這個是不好的建議,因為這個使你的“整個”SQL Server 單線程!即使維護操作(例如索引重建)已單線程執行,這會嚴重傷及性能!當然也有一些“獲獎”產品指示你使用1的最大并行度(MAXOP)……

將承載 SharePoint 數據庫的 SQL Server 實例的最大并行度 (MAXDOP) 設置為 1 以確保單個 SQL Server 過程能夠為每個請求提供服務。

小結

在你安裝完SQL Server后,DBA的真正工作才開始:你需要配置你的SQL Server安裝到你的硬件配置。在這篇文章里你已看到,SQL Server的默認配置是明顯錯誤的。因此在安裝后立即修改一些配置選項非常重要。我已經見過生產環境里SQL Server使用我這里提到的默認選項,因為它們“稍后“會被配置,“稍后”就從未發生了……

因此今天請幫自己一個忙,為最大性能和吞吐量配置你的SQL Server!

感謝關注!

參考文章:

https://www.sqlpassion.at/archive/2015/02/23/the-3-configuration-options-that-you-always-have-to-change-in-sql-server/

轉載于:https://www.cnblogs.com/woodytu/p/4715415.html

總結

以上是生活随笔為你收集整理的SQL Serve里你总要去改变的3个配置选项的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。