欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

sql server中的任務(wù)調(diào)度與CPU深入講解

 更新時(shí)間:2018年05月30日 11:52:28   作者:hushaoren  
這篇文章主要給大家介紹了關(guān)于sql server中任務(wù)調(diào)度與CPU的相關(guān)資料,文中通過圖文以及示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

一. 概述

我們知道在操作系統(tǒng)看來, sql server產(chǎn)品與其它應(yīng)用程序一樣,沒有特別對(duì)待。但內(nèi)存,硬盤,cpu又是數(shù)據(jù)庫系統(tǒng)最重要的核心資源,所以在sql server 2005及以后出現(xiàn)了SQLOS,這個(gè)組件是sqlserver和windows的中間層,用于CPU的任務(wù)調(diào)度,解決I/O的資源爭用,協(xié)調(diào)內(nèi)存管理等其它的資源協(xié)調(diào)工作。下面我來試著講講SQLOS下的Scheduler調(diào)度管理。話不多說了,來一起看看詳細(xì)的介紹吧。

二. CPU 的配置

在Sql server 里點(diǎn)擊數(shù)據(jù)庫實(shí)例右鍵到屬性,選擇處理器進(jìn)行配置。最大工作線程數(shù)的默認(rèn)值是0 (注意這里配置的是worker它是對(duì)CPU的真正封裝)。這使得SQL Server能夠在啟動(dòng)時(shí)自動(dòng)配置工作線程的數(shù)量。默認(rèn)設(shè)置對(duì)于大多數(shù)系統(tǒng)是最好的。但是,根據(jù)您的系統(tǒng)配置,將最大工作線程數(shù)設(shè)置為一個(gè)特定的值有時(shí)會(huì)提高性能。當(dāng)查詢請(qǐng)求的實(shí)際數(shù)量小于最大工作線程數(shù)時(shí),一個(gè)線程處理一個(gè)查詢請(qǐng)求。但是,如果查詢請(qǐng)求的實(shí)際數(shù)量超過最大線程量時(shí),SQLServer會(huì)將Worker Threads線程池化,以便下一個(gè)可用的工作線程可以處理請(qǐng)求。

配置如下圖所示:

       

也可以通過T-sql配置,下例通過sp_configure將max worker線程選項(xiàng)配置為900

USE AdventureWorks2012 ; 
GO 
EXEC sp_configure 'show advanced options', 1; 
GO 
RECONFIGURE ; 
GO 
EXEC sp_configure 'max worker threads', 900 ; 
GO 
RECONFIGURE;

Max Worker Threads服務(wù)器配置選項(xiàng)不考慮的線程, 像高可用、Service Broker、 Lock 管理等其它。如果配置的線程數(shù)量超過了,下面的查詢將提供關(guān)于系統(tǒng)任務(wù)產(chǎn)生的額外線程信息

is_user_process = 0 表示系統(tǒng)任務(wù),非用戶任務(wù)。

SELECT s.session_id, r.command, r.status, r.wait_type, r.scheduler_id, w.worker_address, 
w.is_preemptive, w.state, t.task_state, t.session_id, t.exec_context_id, t.request_id 
FROM sys.dm_exec_sessions AS s 
INNER JOIN sys.dm_exec_requests AS r 
ON s.session_id = r.session_id 
INNER JOIN sys.dm_os_tasks AS t 
ON r.task_address = t.task_address 
INNER JOIN sys.dm_os_workers AS w 
ON t.worker_address = w.worker_address 
WHERE s.is_user_process = 0;

下面顯示每個(gè)用戶的活動(dòng)會(huì)話數(shù)

SELECT login_name ,COUNT(session_id) AS session_count 
FROM sys.dm_exec_sessions 
WHERE status<>'sleeping'
GROUP BY login_name; 

下表顯示了各種CPU和SQLServer組合的最大工作線程的自動(dòng)配置數(shù)量。

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ù)微軟的建議:這個(gè)選項(xiàng)是一個(gè)高級(jí)選項(xiàng),應(yīng)該只由經(jīng)驗(yàn)豐富的數(shù)據(jù)庫管理員或經(jīng)過認(rèn)證的SQL Server專業(yè)人員更改。如果您懷疑存在性能問題,則可能不是工作線程的可用性。原因更像是I/O,這會(huì)導(dǎo)致工作線程等待。在更改最大工作線程設(shè)置之前,最好找到性能問題的根本原因。

二.調(diào)度原理

2.1 Scheduler任務(wù)調(diào)度

Sqlserver 的一個(gè)Scheduler對(duì)應(yīng)操作系統(tǒng)上的一個(gè)邏輯CPU用于任務(wù)分配。調(diào)度分配從NUMA節(jié)點(diǎn)級(jí)別開始?;舅惴ㄊ且粋€(gè)用于新連接的循環(huán)調(diào)度。當(dāng)每個(gè)新的連接到達(dá)時(shí),它被分配給基于循環(huán)的調(diào)度器。在相同的NUMA節(jié)點(diǎn)內(nèi),以最小的負(fù)載因子分配給調(diào)度器的新連接。

2.2  Worker

Worker又稱為WorkerThread,每個(gè)Worker跟一個(gè)線程,是Sql server任務(wù)的執(zhí)行單位。 多個(gè)Worker對(duì)應(yīng)一個(gè)Scheduler,公式Workers=max worker threads/onlines scheduler。在一個(gè)Scheduler上,同一時(shí)間只能有一個(gè)Worker運(yùn)行。例如4個(gè)處理器的64位操作系統(tǒng),它的每個(gè)Scheduler的Worker是512/4=128。

2.3  Task

在Worker上運(yùn)行的最小任務(wù)單元。最簡單的Task就是一個(gè)簡單的Batch,當(dāng)一個(gè)會(huì)話發(fā)出一個(gè)請(qǐng)求時(shí),Sql server會(huì)把這個(gè)請(qǐng)求拆分一個(gè)或多個(gè)任務(wù)(Tasks),然后關(guān)聯(lián)對(duì)應(yīng)個(gè)數(shù)的工作者線程(worker thread)。

例如下面是二個(gè)Task ,二個(gè)Task可能不是同一個(gè)Worker。二個(gè)Worker也可能不是同一個(gè)Scheduler.           

select @@servername
Go
select getdate()
GO

每個(gè)Task線程都有3個(gè)狀態(tài):

  • Running: 一個(gè)處理器在某個(gè)時(shí)間只能做一件事情,當(dāng)一個(gè)線程正在一個(gè)處理器上運(yùn)行時(shí),這個(gè)線程的狀態(tài)就是running。
  • Suspended: 沒有足夠資源時(shí),當(dāng)前線程放棄占有處理器,變成掛起狀態(tài)。
  • Runnable: 一個(gè)線程已完成了等待,但還沒有輪到它運(yùn)行,就會(huì)變成runnable狀態(tài),這種信號(hào)等待(signal wait)

2.4 Yielding

Yelding就是所有邏輯scheduler上運(yùn)行的Worker都是非搶占式的, 在 Scheduler上Worker由于資源等待,讓出給其它Worker就叫Yielding。

下面講述幾種發(fā)生的狀態(tài):

  1. 當(dāng)Woker在Scheduler上運(yùn)行了超過4ms,就做Yielding。

  2. 每做64k的結(jié)果集的排序,就會(huì)做一次Yielding。

  3. 做語句Complie編譯的過程中,這個(gè)過程比較占CPU資源時(shí),經(jīng)常會(huì)有Yielding等。

2.5 調(diào)度關(guān)系圖如下:

             

2.5  Task在調(diào)度運(yùn)行圖如下:

                 

1. 當(dāng) Task 是Runnig時(shí),它是Schedler的活動(dòng)Worker。

2. 當(dāng) Task只等待CPU運(yùn)行時(shí),它被放入Schedler可運(yùn)行的隊(duì)列中。

3. 當(dāng) Task 在等待某個(gè)資源時(shí)(比如鎖、磁盤輸入/輸出等)時(shí),它處于“Suspended掛起狀態(tài)” 狀態(tài)。

4. 如果Task Scheduler掛起狀態(tài)完成了等待,那么它就會(huì)被放到Scheduler 的Runnable隊(duì)列的末尾。

5. 如果運(yùn)行線程自動(dòng)Yidlding讓步,則將其放回Scheduler 的Runnable隊(duì)列的末尾。

6. 如果運(yùn)行的線程需要等待某個(gè)資源,它將被調(diào)出Scheduler調(diào)度器并進(jìn)入掛起狀態(tài)Waiter list。

7. 如果正在運(yùn)行的線程完成它的工作,那么Runnable隊(duì)列的頂部的第一個(gè)線程就變成了“運(yùn)行”線程。

三. 使用dmv任務(wù)查看

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)系

--在每一個(gè)連接里,我們可能會(huì)有很多batch,分解成多個(gè)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_id<255 代表用戶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:當(dāng)前任務(wù)數(shù),狀態(tài)包括:(等待,運(yùn)行,已完成)。

  runnable_tasks_count:以分配任務(wù),并在可運(yùn)行隊(duì)列中等待被調(diào)度的任務(wù)數(shù),使用率不高的情況下,這個(gè)值會(huì)是0。

  current_workers_count:此scheduler關(guān)聯(lián)的線程數(shù)。包括處于空閑狀態(tài)的線程work。

  active_workers_count:當(dāng)前處理活動(dòng)的線程數(shù),它必須關(guān)聯(lián)任務(wù)task,包括running,runnable,suspend。

  work_queue_count:隊(duì)列中的任務(wù)task等待數(shù),如果不為0,意味著線程用盡的壓力。

講到這里,后面講講CPUf過高的分析...

參考文獻(xiàn):

  Troubleshooting SQL Server Scheduling and Yielding

  Microsoft SQL Server企業(yè)級(jí)平臺(tái)管理實(shí)踐

  How It Works: SQL Server 2012 Database Engine Task Scheduling

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對(duì)腳本之家的支持。

相關(guān)文章

  • SQL Server表中添加新列并添加描述

    SQL Server表中添加新列并添加描述

    這篇文章主要介紹了SQL Server表中添加新列并添加描述的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2016-07-07
  • SQL Server 2012 安全概述

    SQL Server 2012 安全概述

    這篇文章給你概括介紹了SQL Server 2012里的基本安全概念。你學(xué)到了一些常見的數(shù)據(jù)威脅,探尋了SQL Server背后的設(shè)計(jì)理念,學(xué)習(xí)了在整個(gè)系列文章看到的一些安全術(shù)語,算是一篇比較非公式化的開篇,希望能夠勾引起大家對(duì)于sql安全的興趣
    2016-04-04
  • SQL Server中索引的用法詳解

    SQL Server中索引的用法詳解

    本文詳細(xì)講解了SQL Server中索引的用法,文中通過示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-05-05
  • SQL?Server?異地?cái)?shù)據(jù)庫每日同步作業(yè)操作圖文詳解

    SQL?Server?異地?cái)?shù)據(jù)庫每日同步作業(yè)操作圖文詳解

    最近因?yàn)榻?jīng)常有攻擊,所以考慮到網(wǎng)站的安全問題,所以多弄了幾臺(tái)服務(wù)器并實(shí)現(xiàn)數(shù)據(jù)庫與文件每天同步,這里主要介紹了sqlserver數(shù)據(jù)的每天同步問題
    2024-04-04
  • SQL實(shí)現(xiàn)查詢某字段的值為空的記錄

    SQL實(shí)現(xiàn)查詢某字段的值為空的記錄

    這篇文章主要介紹了SQL實(shí)現(xiàn)查詢某字段的值為空的記錄,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • 合并SQL腳本文件的方法分享

    合并SQL腳本文件的方法分享

    在平時(shí)的工作中,我會(huì)經(jīng)常的碰到這樣需要合并SQL腳本的問題。如,有很多的SQL腳本文件,需要按照一定的先后順序,再生成一個(gè)合并SQL腳本文件,然后再發(fā)布到用戶SQL Server服務(wù)器上。
    2011-09-09
  • 用SQL批量插入數(shù)據(jù)的代碼

    用SQL批量插入數(shù)據(jù)的代碼

    循環(huán)插入數(shù)據(jù)的代碼,需要的朋友可以參考下。
    2011-01-01
  • sqlServer實(shí)現(xiàn)去除字符串空格

    sqlServer實(shí)現(xiàn)去除字符串空格

    簡單的說SQL 中使用ltrim()去除左邊空格 ,rtrim()去除右邊空格 ,沒有同時(shí)去除左右空格的函數(shù),要去除所有空格可以用replace(字符串,' ',''),將字符串里的空格替換為空 。
    2017-01-01
  • SQL注入全過程深入分析

    SQL注入全過程深入分析

    這篇文章主要介紹了SQL注入全過程,由淺入深的分析了SQL注入的全過程及相關(guān)的注意事項(xiàng),需要的朋友可以參考下
    2016-07-07
  • SQL查詢排序?qū)ull值排到最后的兩種解決方法

    SQL查詢排序?qū)ull值排到最后的兩種解決方法

    本文介紹在SQL查詢排序時(shí),如果遇到NULL值,如何根據(jù)實(shí)際業(yè)務(wù)需求,控制將NULL值排在最后或最前邊,文中給出了兩種解決方法,通過代碼示例講解的非常詳細(xì),需要的朋友可以參考下
    2023-12-12

最新評(píng)論