sql server 任務調度與CPU

来源:https://www.cnblogs.com/MrHSR/archive/2018/05/28/9087686.html
-Advertisement-
Play Games

一. 概述 我們知道在操作系統看來, sql server產品與其它應用程式一樣,沒有特別對待。但記憶體,硬碟,cpu又是資料庫系統最重要的核心資源,所以在sql server 2005及以後出現了SQLOS,這個組件是sqlserver和windows的中間層,用於CPU的任務調度,解決I/O的資源 ...


 

一. 概述

    我們知道在操作系統看來, 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; 

    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 @@servername
Go
select 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 調度關係圖如下:

              

  2.5  Task在調度運行圖如下:

                 

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

  

  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>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:關聯的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

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 安裝截圖軟體 1.下載安裝python-xlib apt-get install python-xlib 2.下載截圖軟體包 wget http://packages.linuxdeepin.com/deepin/pool/main/d/deepin-scrot/deepin-scrot_2.0-0 ...
  • Flashloader程式主要是用來將你的Application下載進i.MXRT支持的所有外部非易失性存儲器中,為後續從外部存儲器啟動做準備。BootROM只有啟動Application功能,沒有下載更新Application功能,而Flashloader最核心的就是下載更新Application... ...
  • 環境 centos:7.2 JDK:1.8 Flume:1.8 一、Flume 安裝 1) 下載 wget http://mirrors.tuna.tsinghua.edu.cn/apache/flume/1.8.0/apache-flume-1.8.0-bin.tar.gz 2) 解壓 tar – ...
  • 誤刪除了部分重要數據,已提交,需要恢復。首先嘗試flashback query閃回數據。資料庫運行在歸檔模式,首先確認資料庫的SCN的變化:SQL> col fscn for 999999999999999999999SQL> col nscn for 999999999999999999999SQ ...
  • url=jdbc:oracle:thin:@localhost:1521:orcldriver=oracle.jdbc.OracleDriverusrname=GJQ (PLSQL Developer 登錄時候的用戶名 即通過cmd命令創建的用戶)password=gjq (PLSQL Develo ...
  • 一、背景 在數據開發中,有時你需要合併兩個動態游標sys_refcursor。 開發一個存儲過程PROC_A,這個過程業務邏輯相當複雜,代碼篇幅較長。一段時間後要開發一個PROC_B,要用PROC_A同樣的邏輯,而且在這個過程中,還要迴圈調用PROC_A這個過程。擺在你面前的有兩個選擇。 打開PL/ ...
  • https://www.cnblogs.com/tuyile006/p/6382062.html https://www.cnblogs.com/chinesern/p/5581422.html ...
  • 為什麼函數影響性能 在SQL語句中,如果不合理的使用函數(Function)就會嚴重影響性能,其實這裡想說的是PL/SQL中的自定義函數,反而對於一些內置函數而言,影響性能的可能性較小。那麼為什麼SQL語句當中,不合理的使用函數會影響性能呢? 在SELECT語句中調用函數時,那麼查詢返回的結果集中的... ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...