SQL Server 的max degree of parallelism引數
當 SQL Server 在具有多個微處理器或 CPU 的計算機上執行時,它將為每個並行計劃執行檢測最佳並行度(即執行一個語句所使用的處理器數)。您可以使用 max degree of parallelism 選項來限制並行計劃執行時所用的處理器數。如果預設值為 0,則使用所有可用的處理器。將 max degree of parallelism 設定為 1 以取消生成並行計劃。將該值設定為大於 1 的數字(最大為 64)來限制執行單個查詢時所用的最大處理器數。如果指定的值比可用的處理器數大,則使用實際可用數量的處理器。如果計算機只有一個處理器,則將忽略 max degree of parallelism 值。
以下來自微軟工程師經驗傳授:
關於max degree of parallelism這個選項,一般情況下采用預設的0就可以了,這樣的話SQL會根據查詢的複雜度來決定使用多大併發度的查詢。但是在有些OLTP(聯機事務處理)系統中,我們會發現SQL中存在大量的併發查詢,從而可能從兩方面影響SQL效能:
1. 單個查詢的併發度過高會導致查詢會花大量的時間在等待併發同步上,從而影響查詢效能
2. 併發查詢太多會佔用大量的CPU資源,從而減少其它查詢得到CPU時間的機會,這樣的話會使其它查詢變慢。
一般來說,如果我們看到SQL Server中有大量的CXPACKET等待型別、或者有許多查詢長期處於Runnable的狀態(表示該查詢在等待CPU時間片),我們會建議客戶將併發度降下來,以進一步排查問題。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/35489/viewspace-608752/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- RAC中的並行查詢 DOP(Degree of Parallelism)並行Parallel
- Why Is My Query Using a High Value for Degree of ParallelismParallel
- Automatic Degree of Parallelism in 11.2.0.2 (文件 ID 1269321.1)Parallel
- Sql Server 的引數化查詢SQLServer
- oracle parallel並行_引數parameter_parallel_max_serverOracleParallel並行Server
- SQL SERVER 引數化選項SQLServer
- SQL Server效能分析引數 (轉)SQLServer
- 手工指定CHANNEL與設定PARALLELISM引數的異同以及FILESPERSET引數的作用Parallel
- SQL Server SQL效能優化之引數化SQLServer優化
- 淺析SQL Server效能分析引數SQLServer
- Oracle 11g中的IO Calibrate(IO校準)--Automatic Degree of Parallelism(DOP)OracleParallel
- SQL Server之旅(12):sqltext的引數化處理SQLServer
- [zt] Oracle10g 隱含引數 - LOG_PARALLELISMOracleParallel
- SQL Server 2005中的模板引數的利用方法SQLServer
- SQL Server-儲存過程(Procedure),帶入引數和出引數SQLServer儲存過程
- 【MySql】修改max_connections引數的方法MySql
- 【MySql】修改max_connections 引數的方法MySql
- Sql Server之旅——第十二站 sqltext的引數化處理SQLServer
- SQL SERVER 2008傳遞表值引數SQLServer
- SQL Server系統儲存過程和引數示例SQLServer儲存過程
- SQL Server 2008:傳遞表值引數SQLServer
- 給SQL Server傳送陣列引數的變通辦法(轉)SQLServer陣列
- SQL Server 2008 引數化行篩選器SQLServer
- SQL Server系統儲存過程和引數總結SQLServer儲存過程
- 樂視樂Max Pro評測 引數至上的理科男?
- [AlwaysOn] 建立SQL Server高可用性組T-SQL語法:BASIC引數SQLServer
- 為SQL Server資料庫傳陣列引數的變通辦法SQLServer資料庫陣列
- pl/sql中的引數模式SQL模式
- [AlwaysOn] 建立SQL Server高可用性組T-SQL語法:DISTRIBUTED引數SQLServer
- 為什麼不帶引數的 Math.max() 返回-Infinity
- MYSQL max_user_connections back_log max_connections引數和Max_used_connectionsMySql
- Sql Server系列:Transact-SQL變數SQLServer變數
- SQL Server中的全域性變數SQLServer變數
- MySQL效能引數詳解 - max_connect_errorsMySqlError
- [AlwaysOn] 建立SQL Server高可用性組T-SQL語法:BACKUP_PRIORITY引數SQLServer
- [AlwaysOn] 建立SQL Server高可用性組T-SQL語法:CLUSTER_TYPE引數SQLServer
- [AlwaysOn] 建立SQL Server高可用性組T-SQL語法:DTC_SUPPORT引數SQLServer
- [AlwaysOn] 建立SQL Server高可用性組T-SQL語法:group_name引數SQLServer