時間:2024-03-07 21:27作者:下載吧人氣:21
一. 概述
我們知道在操作系統看來, sql server產品與其它應用程序一樣,沒有特別對待。但內存,硬盤,cpu又是數據庫系統最重要的核心資源,所以在sql server 2005及以后出現了SQLOS,這個組件是sqlserver和windows的中間層,用于CPU的任務調度,解決I/O的資源爭用,協調內存管理等其它的資源協調工作。下面我來試著講講SQLOS下的Scheduler調度管理。話不多說了,來一起看看詳細的介紹吧。
二. CPU 的配置
在Sql server 里點擊數據庫實例右鍵到屬性,選擇處理器進行配置。最大工作線程數的默認值是0 (注意這里配置的是worker它是對CPU的真正封裝)。這使得SQL Server能夠在啟動時自動配置工作線程的數量。默認設置對于大多數系統是最好的。但是,根據您的系統配置,將最大工作線程數設置為一個特定的值有時會提高性能。當查詢請求的實際數量小于最大工作線程數時,一個線程處理一個查詢請求。但是,如果查詢請求的實際數量超過最大線程量時,SQLServer會將Worker Threads線程池化,以便下一個可用的工作線程可以處理請求。
配置如下圖所示:
也可以通過T-sql配置,下例通過sp_configure將max worker線程選項配置為900
USE AdventureWorks2012 ;
GO
EXEC sp_configure ‘show advanced options’, 1;
GO
RECONFIGURE ;
GO
EXEC sp_configure ‘max worker threads’, 900 ;
GO
RECONFIGURE;
網友評論