Number of CPUs |
32-bit computer |
64-bit computer |
= 4 processors |
256 |
512 |
8 processors |
288 |
576 |
16 processors |
352 |
704 |
32 processors |
480 |
960 |
64 processors |
736 |
1472 |
128 processors |
4224 |
4480 |
256 processors |
8320 |
8576 |
根據(jù)微軟的建議:這個選項是一個高級選項,應該只由經(jīng)驗豐富的數(shù)據(jù)庫管理員或經(jīng)過認證的SQL Server專業(yè)人員更改。如果您懷疑存在性能問題,則可能不是工作線程的可用性。原因更像是I/O,這會導致工作線程等待。在更改最大工作線程設置之前,最好找到性能問題的根本原因。
二.調(diào)度原理
2.1 Scheduler任務調(diào)度
Sqlserver 的一個Scheduler對應操作系統(tǒng)上的一個邏輯CPU用于任務分配。調(diào)度分配從NUMA節(jié)點級別開始。基本算法是一個用于新連接的循環(huán)調(diào)度。當每個新的連接到達時,它被分配給基于循環(huán)的調(diào)度器。在相同的NUMA節(jié)點內(nèi),以最小的負載因子分配給調(diào)度器的新連接。
2.2 Worker
Worker又稱為WorkerThread,每個Worker跟一個線程,是Sql server任務的執(zhí)行單位。 多個Worker對應一個Scheduler,公式Workers=max worker threads/onlines scheduler。在一個Scheduler上,同一時間只能有一個Worker運行。例如4個處理器的64位操作系統(tǒng),它的每個Scheduler的Worker是512/4=128。
2.3 Task
在Worker上運行的最小任務單元。最簡單的Task就是一個簡單的Batch,當一個會話發(fā)出一個請求時,Sql server會把這個請求拆分一個或多個任務(Tasks),然后關(guān)聯(lián)對應個數(shù)的工作者線程(worker thread)。
例如下面是二個Task ,二個Task可能不是同一個Worker。二個Worker也可能不是同一個Scheduler.
select @@servername Go select getdate() GO
每個Task線程都有3個狀態(tài):
2.4 Yielding
Yelding就是所有邏輯scheduler上運行的Worker都是非搶占式的, 在 Scheduler上Worker由于資源等待,讓出給其它Worker就叫Yielding。
下面講述幾種發(fā)生的狀態(tài):
1. 當Woker在Scheduler上運行了超過4ms,就做Yielding。
2. 每做64k的結(jié)果集的排序,就會做一次Yielding。
3. 做語句Complie編譯的過程中,這個過程比較占CPU資源時,經(jīng)常會有Yielding等。
2.5 調(diào)度關(guān)系圖如下:
2.5 Task在調(diào)度運行圖如下:
1. 當 Task 是Runnig時,它是Schedler的活動Worker。
2. 當 Task只等待CPU運行時,它被放入Schedler可運行的隊列中。
3. 當 Task 在等待某個資源時(比如鎖、磁盤輸入/輸出等)時,它處于“Suspended掛起狀態(tài)” 狀態(tài)。
4. 如果Task Scheduler掛起狀態(tài)完成了等待,那么它就會被放到Scheduler 的Runnable隊列的末尾。
5. 如果運行線程自動Yidlding讓步,則將其放回Scheduler 的Runnable隊列的末尾。
6. 如果運行的線程需要等待某個資源,它將被調(diào)出Scheduler調(diào)度器并進入掛起狀態(tài)Waiter list。
7. 如果正在運行的線程完成它的工作,那么Runnable隊列的頂部的第一個線程就變成了“運行”線程。
三. 使用dmv任務查看
3.1. 通過sys.dm_os_sys_info 查看scheduler與cpu的關(guān)系如下:
SELECT cpu_count,max_workers_count,scheduler_count FROM sys.dm_os_sys_info
3.2 查看最大Worker數(shù)
select max_workers_count from sys.dm_os_sys_info
3.3 查看Task與Worker關(guān)系
--在每一個連接里,我們可能會有很多batch,分解成多個task以支持如并行查詢 select task_address,task_state,scheduler_id,session_id,worker_address from sys.dm_os_tasks where session_id>50 select state,last_wait_type,tasks_processed_count,task_address, worker_address, scheduler_address from sys.dm_os_workers where worker_address =0x00000000043621A0
3.4 查看Scheduler
--scheduler_id255 代表用戶CPU,相反代表SYSTEM SCHEDULER SELECT scheduler_id, cpu_id, is_online, current_tasks_count, runnable_tasks_count, current_workers_count, active_workers_count, work_queue_count FROM sys.dm_os_schedulers WHERE scheduler_id 255
cpu_id:關(guān)聯(lián)的cpu 。 CPU ID >=255 這類Scheduler都用于系統(tǒng)內(nèi)部使用。比如說資源管理、DAC、備份還原操作等。
is_online: 0 調(diào)度器離線,1 在線。
current_tasks_count:當前任務數(shù),狀態(tài)包括:(等待,運行,已完成)。
runnable_tasks_count:以分配任務,并在可運行隊列中等待被調(diào)度的任務數(shù),使用率不高的情況下,這個值會是0。
current_workers_count:此scheduler關(guān)聯(lián)的線程數(shù)。包括處于空閑狀態(tài)的線程work。
active_workers_count:當前處理活動的線程數(shù),它必須關(guān)聯(lián)任務task,包括running,runnable,suspend。
work_queue_count:隊列中的任務task等待數(shù),如果不為0,意味著線程用盡的壓力。
講到這里,后面講講CPUf過高的分析...
參考文獻:
Troubleshooting SQL Server Scheduling and Yielding
Microsoft SQL Server企業(yè)級平臺管理實踐
How It Works: SQL Server 2012 Database Engine Task Scheduling
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
標簽:七臺河 威海 益陽 銅仁 防疫戰(zhàn)設 宿州 來賓 天水
巨人網(wǎng)絡通訊聲明:本文標題《sql server中的任務調(diào)度與CPU深入講解》,本文關(guān)鍵詞 sql,server,中的,任務,調(diào)度,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權(quán)與本站無關(guān)。