亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > SQL Server > 正文

sql server中的任務調度與CPU深入講解

2024-08-31 01:05:22
字體:
來源:轉載
供稿:網友

一. 概述

我們知道在操作系統看來, 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線程池化,以便下一個可用的工作線程可以處理請求。

配置如下圖所示:

  sqlserver,任務調度,CPU     

也可以通過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;

Max Worker Threads服務器配置選項不考慮的線程, 像高可用、Service Broker、 Lock 管理等其它。如果配置的線程數量超過了,下面的查詢將提供關于系統任務產生的額外線程信息

is_user_process = 0 表示系統任務,非用戶任務。

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;

下面顯示每個用戶的活動會話數

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

下表顯示了各種CPU和SQLServer組合的最大工作線程的自動配置數量。

 

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

 

根據微軟的建議:這個選項是一個高級選項,應該只由經驗豐富的數據庫管理員或經過認證的SQL Server專業人員更改。如果您懷疑存在性能問題,則可能不是工作線程的可用性。原因更像是I/O,這會導致工作線程等待。在更改最大工作線程設置之前,最好找到性能問題的根本原因。

二.調度原理

2.1 Scheduler任務調度

Sqlserver 的一個Scheduler對應操作系統上的一個邏輯CPU用于任務分配。調度分配從NUMA節點級別開始?;舅惴ㄊ且粋€用于新連接的循環調度。當每個新的連接到達時,它被分配給基于循環的調度器。在相同的NUMA節點內,以最小的負載因子分配給調度器的新連接。

2.2  Worker

Worker又稱為WorkerThread,每個Worker跟一個線程,是Sql server任務的執行單位。 多個Worker對應一個Scheduler,公式Workers=max worker threads/onlines scheduler。在一個Scheduler上,同一時間只能有一個Worker運行。例如4個處理器的64位操作系統,它的每個Scheduler的Worker是512/4=128。

2.3  Task

在Worker上運行的最小任務單元。最簡單的Task就是一個簡單的Batch,當一個會話發出一個請求時,Sql server會把這個請求拆分一個或多個任務(Tasks),然后關聯對應個數的工作者線程(worker thread)。

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

select @@servernameGoselect getdate()GO

每個Task線程都有3個狀態:

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

2.4 Yielding

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

下面講述幾種發生的狀態:

  1. 當Woker在Scheduler上運行了超過4ms,就做Yielding。

  2. 每做64k的結果集的排序,就會做一次Yielding。

  3. 做語句Complie編譯的過程中,這個過程比較占CPU資源時,經常會有Yielding等。

2.5 調度關系圖如下:

sqlserver,任務調度,CPU             

2.5  Task在調度運行圖如下:

sqlserver,任務調度,CPU                 

1. 當 Task 是Runnig時,它是Schedler的活動Worker。

2. 當 Task只等待CPU運行時,它被放入Schedler可運行的隊列中。

3. 當 Task 在等待某個資源時(比如鎖、磁盤輸入/輸出等)時,它處于“Suspended掛起狀態” 狀態。

4. 如果Task Scheduler掛起狀態完成了等待,那么它就會被放到Scheduler 的Runnable隊列的末尾。

5. 如果運行線程自動Yidlding讓步,則將其放回Scheduler 的Runnable隊列的末尾。

6. 如果運行的線程需要等待某個資源,它將被調出Scheduler調度器并進入掛起狀態Waiter list。

7. 如果正在運行的線程完成它的工作,那么Runnable隊列的頂部的第一個線程就變成了“運行”線程。

三. 使用dmv任務查看

3.1.  通過sys.dm_os_sys_info 查看scheduler與cpu的關系如下:

 SELECT cpu_count,max_workers_count,scheduler_count FROM sys.dm_os_sys_info

sqlserver,任務調度,CPU  

3.2  查看最大Worker數  

select max_workers_count from sys.dm_os_sys_info  

3.3  查看Task與Worker關系

--在每一個連接里,我們可能會有很多batch,分解成多個task以支持如并行查詢 select task_address,task_state,scheduler_id,session_id,worker_address  from sys.dm_os_tasks where session_id>50select state,last_wait_type,tasks_processed_count,task_address, worker_address, scheduler_address from sys.dm_os_workers where worker_address =0x00000000043621A0

sqlserver,任務調度,CPU

3.4 查看Scheduler

--scheduler_id<255 代表用戶CPU,相反代表SYSTEM SCHEDULERSELECT 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:關聯的cpu 。 CPU ID  >=255 這類Scheduler都用于系統內部使用。比如說資源管理、DAC、備份還原操作等。

   is_online: 0 調度器離線,1 在線。

  current_tasks_count:當前任務數,狀態包括:(等待,運行,已完成)。

  runnable_tasks_count:以分配任務,并在可運行隊列中等待被調度的任務數,使用率不高的情況下,這個值會是0。

  current_workers_count:此scheduler關聯的線程數。包括處于空閑狀態的線程work。

  active_workers_count:當前處理活動的線程數,它必須關聯任務task,包括running,runnable,suspend。

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

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

參考文獻:

  Troubleshooting SQL Server Scheduling and Yielding

  Microsoft SQL Server企業級平臺管理實踐

  How It Works: SQL Server 2012 Database Engine Task Scheduling

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對VeVb武林網的支持。


注:相關教程知識閱讀請移步到MSSQL教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品久久久久久影视| 亚洲人成免费电影| 欧美日韩美女在线观看| 国产美女高潮久久白浆| 欧美日韩国产丝袜美女| 九九热这里只有在线精品视| 欧美色道久久88综合亚洲精品| 国产精品高潮粉嫩av| 欧美高清在线观看| 成人xvideos免费视频| 奇门遁甲1982国语版免费观看高清| 国产精品扒开腿做爽爽爽视频| 欧美激情亚洲激情| 欧美丝袜第一区| 2019中文字幕在线免费观看| 欧美肥臀大乳一区二区免费视频| 国产午夜精品美女视频明星a级| 成人一区二区电影| 国产精品久久久久7777婷婷| 国产精品男女猛烈高潮激情| 日韩精品亚洲元码| 色樱桃影院亚洲精品影院| 日韩在线视频观看正片免费网站| 精品国偷自产在线| 欧美成人手机在线| 亚洲国产婷婷香蕉久久久久久| 国产九九精品视频| 国内偷自视频区视频综合| 欧美精品videos另类日本| 国产成一区二区| 亚洲国产成人精品女人久久久| 7777精品久久久久久| 亚洲视频综合网| 亚洲国产精品嫩草影院久久| 黄色成人av网| 久久精品91久久久久久再现| 国产成人精品久久二区二区91| 一区二区三区无码高清视频| 深夜福利亚洲导航| 中文字幕日韩电影| 亚洲精品视频中文字幕| 国产乱人伦真实精品视频| 中文字幕精品av| 怡红院精品视频| 国产精品精品久久久久久| 亚洲人午夜色婷婷| 国产精品久久久久久久午夜| 亚洲成人激情在线观看| 欧美午夜女人视频在线| 久久久成人的性感天堂| 国产日韩欧美在线播放| 国产啪精品视频网站| 亚洲美女性视频| 国产精品嫩草影院久久久| 亚洲а∨天堂久久精品9966| 清纯唯美亚洲综合| 热99精品只有里视频精品| 17婷婷久久www| 在线看片第一页欧美| 日韩免费中文字幕| 久久91亚洲精品中文字幕| 日韩电影大全免费观看2023年上| 亚洲国产一区二区三区四区| 国产亚洲欧美日韩美女| 亚洲精品二三区| 九九视频这里只有精品| 亚洲综合日韩中文字幕v在线| 日本精品一区二区三区在线| 久久久在线观看| 久久久久久成人精品| 欧美日韩国产一区二区三区| 国产精品欧美日韩| 日韩女在线观看| 成人午夜在线视频一区| 亚洲欧美国产精品久久久久久久| 中文字幕日韩在线播放| 91在线免费视频| www.欧美精品| 亚洲国产欧美一区| 秋霞午夜一区二区| 国产免费一区二区三区在线能观看| 国产成人拍精品视频午夜网站| 一本色道久久综合狠狠躁篇的优点| 亚洲电影免费观看| 国产精品久久综合av爱欲tv| 一区二区三区回区在观看免费视频| 欧美精品在线观看91| 91久久久国产精品| 精品久久久久久久久中文字幕| 久久久久国色av免费观看性色| 国产精品狠色婷| 成人黄色在线观看| 欧美日韩福利视频| 亚洲女人天堂色在线7777| 亚洲第一偷拍网| 日韩在线视频网| 国产久一一精品| 亚洲肉体裸体xxxx137| 国产日韩av高清| 国产精品久久久久999| 日韩美女视频免费看| 国产精品色午夜在线观看| 日韩在线视频线视频免费网站| 91香蕉嫩草影院入口| 欧美高清在线视频观看不卡| 欧美整片在线观看| 91精品国产777在线观看| 日韩国产一区三区| 91免费看片网站| 久久亚洲电影天堂| 欧美激情一级欧美精品| 亚洲欧美色图片| 国产精品视频资源| 久久在线免费观看视频| 成人乱色短篇合集| 久久天堂av综合合色| 欧美精品生活片| 国产亚洲精品美女久久久久| 亚洲精品小视频| 成人免费视频xnxx.com| 欧美日韩成人精品| 欧美黑人极品猛少妇色xxxxx| 91精品国产综合久久香蕉| 高跟丝袜欧美一区| 国产精品视频公开费视频| 最近2019年手机中文字幕| 国产精品视频一区二区高潮| 亚洲国产日韩欧美在线图片| 97精品国产97久久久久久春色| 国产精品老女人视频| 欧美另类极品videosbestfree| 亚洲xxxx妇黄裸体| 亚洲激情自拍图| 欧美性xxxx极品高清hd直播| 国产精品日韩一区| 亚洲欧洲一区二区三区久久| 日本精品视频在线播放| 亚洲精品国产福利| 91国产精品91| 欧美电影院免费观看| 55夜色66夜色国产精品视频| 色系列之999| 国产在线观看精品一区二区三区| 国产欧美日韩专区发布| 亚洲国产精品一区二区三区| 66m—66摸成人免费视频| 97在线观看视频国产| 日韩精品久久久久久久玫瑰园| 欧美电影免费观看大全| 国产精品高潮呻吟视频| 欧美裸体男粗大视频在线观看| 欧美裸体男粗大视频在线观看| 亚洲国产成人久久综合一区| 青草青草久热精品视频在线观看| 黄色一区二区在线观看| 91网站在线看| 国产精品日韩欧美| 亚洲free嫩bbb| 国产一区视频在线| 欧美韩国理论所午夜片917电影| 亚洲成人性视频| 国产美女主播一区| 久久久免费观看视频| 日韩av一区二区在线观看|