search
HomeDatabaseMysql TutorialSQL Server 2012中Task是如何调度的?

从SQL Server 7.0以来调度算法并没有很大的改变。 算法概述: 调度从分配NUMA节点开始,使用循环分配的方式,当一下链接来了,先分配给Node1,然后分配给Node2,然后在Node1 分配了NUMA节点之后,在分配调度器,根据Load factor来做调度,Load factor可以简

     从SQL Server 7.0以来调度算法并没有很大的改变。

算法概述:

     调度从分配NUMA节点开始,使用循环分配的方式,当一下链接来了,先分配给Node1,然后分配给Node2,然后在Node1

     分配了NUMA节点之后,在分配调度器,根据Load factor来做调度,Load factor可以简单的认为是分配给调度器的任务数量

     task分配是根据Load factor,如果首先的调度器比其他调度器多了120%,那么选择其他调度器,否则现在首选调度器

 

SQL Server 2012调度算法只在企业版上做了修改

     新的连接分配:新的连接是用环形循环分配,和前面提到的一样。所有的sql server 2012 产品都是这样分配连接的,美国服务器,然后查询目标节点把连接分配给负荷最小的调度器,然后这个调度器变为这个连接的首选调度器。

     

 

     新的连接并没有首选调度器,所以需要再分配的节点内给连接分配一个调度器,负荷最小的调度器被选中,如图的例子现在了Node1的sched2.

 

SQL Server 2012之前和非企业版

     这个比较简单,当task被请求,使用首选调度器,继续上面的例子如图:是sched2,当load factor是其他调度器120%以上的时候就需要重新选中调度器。

     

 

SQL Server 2012企业版

     在企业版中,对load factor的算法进行了改进。

     每个调度器,都有一个以cpu为目标的,资源池,并是有load factor对能力进行跟踪。并不是Load factor一样120%,而是通过每个资源池的平均cpu

     

调度还是以首选调度器开始,如果调度之后,并没有比同节点内的所有调度器平均少80%,那么可以调度,否则做调度平衡,选择可用资源最多的调度器。

     调度的例子(笔者认为例子有些错误,所以做了修改):


Scheduler RG Pool Target Pool Runnable Tasks Avg Pool/Task  

1 50 10 5  

2 50 8 6.25 Currently Best Target – More resources to provide for tasks in the same pool

 

 

假设sched1 可以为每个task提供5,香港虚拟主机,那么sched2可以提供6.25

当前平均是 (5+6.25)/2 = 5.625

 

当有一个任务要被分配,首选是sched1那么如果被分配,可提供 50/11 = 4.545 > 5.625*0.8 = 4.5008所以可以分配


Scheduler RG Pool Target Pool Runnable Tasks Avg Pool/Task  

1 50 11 4.545   Not below 80th percentile

2 50 8 6.25  

 

当前平均= 5.3977 (6.25 + 4.5454/2) 

然后又有一个新的要分配,首选还是sched1,50/12 = 4.1666 4.3181所以需要做调整,选择自愿最多的一个调度器


Scheduler RG Pool Target Pool Runnable Tasks Avg Pool/Task  

1 50 11 4.5454  

2 50 9 5.55  Added task

 

当前平均值 5.047 (5.55 + 4.5454 / 2)

 

相关Trace Flag

     -T8008 强制调度,不管scheduler提示,香港服务器租用,总是调度给最小的负荷(使用最小load factor或者资源池)

     -T8016 忽略负载均衡,总是调度给首选调度器

Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
windows11关机提示task host window任务宿主正在执行关闭任务的解决方法windows11关机提示task host window任务宿主正在执行关闭任务的解决方法Feb 12, 2024 pm 12:40 PM

近期不少的win11用户们反映关机的时候提示taskhostwindow任务宿主正在执行关闭任务,那么这是怎么回事?用户们可以进入到本地注册表编辑器下的Desktop文件夹,然后在右边的窗口中选择AutoEndTasks来进行设置就可以了。下面就让本站来为用户们来仔细的介绍一下关机出现这个问题的解决方法吧。windows11关机提示taskhostwindow任务宿主正在执行关闭任务的解决方法1、使用组合键win键+r键,输入“regedit”,回车,如下图所示。2、寻找[HKEY

如何安装、卸载、重置Windows服务器备份如何安装、卸载、重置Windows服务器备份Mar 06, 2024 am 10:37 AM

WindowsServerBackup是WindowsServer操作系统自带的一个功能,旨在帮助用户保护重要数据和系统配置,并为中小型和企业级企业提供完整的备份和恢复解决方案。只有运行Server2022及更高版本的用户才能使用这一功能。在本文中,我们将介绍如何安装、卸载或重置WindowsServerBackup。如何重置Windows服务器备份如果您的服务器备份遇到问题,备份所需时间过长,或无法访问已存储的文件,那么您可以考虑重新设置WindowsServer备份设置。要重置Windows

利用go-zero实现分布式任务分发与调度利用go-zero实现分布式任务分发与调度Jun 22, 2023 am 09:06 AM

随着互联网业务的快速发展以及渐渐增加的业务量,单台服务器所能处理的数据量已经远远不能满足需求。为了满足高并发、高可用、高性能的要求,分布式架构应运而生。在分布式架构中,任务的分发和调度是一个非常关键的组成部分。任务分发和调度的好坏将直接影响整个系统的性能和稳定性。在这里,我们将介绍如何利用go-zero框架实现分布式任务分发和调度。1.分布式任务分发任务分发

如何在 macOS 中禁用“单击桌面显示”功能如何在 macOS 中禁用“单击桌面显示”功能Nov 23, 2023 pm 02:31 PM

默认情况下,macOSSonoma会在您单击桌面壁纸时隐藏所有活动窗口。如果您倾向于在桌面上有一堆需要访问的文件,这将很方便。但是,如果您发现这种行为令人抓狂,则有一种方法可以将其关闭。Apple最新的macOSSonomaMac操作系统有一个新选项,称为“单击壁纸以显示桌面”。默认情况下启用,如果您倾向于打开多个窗口,并且想要访问桌面上的文件或文件夹,而不必最小化或移动窗口,则该选项可能特别有用。启用该功能并单击桌面墙纸后,所有打开的窗口都会暂时被扫到一边,从而直接访问桌面。完成后,您可以再次

Windows Server 2025预览版迎来更新,微软改善Insiders测试体验Windows Server 2025预览版迎来更新,微软改善Insiders测试体验Feb 19, 2024 pm 02:36 PM

在发布WindowsServer的build26040版本之际,微软公布了该产品的官方名称:WindowsServer2025。一同推出的,还有Windows11WindowsInsiderCanaryChannel版本的build26040。有些朋友可能还记得,多年前有人成功将WindowsNT从工作站模式转换为服务器模式,显示微软操作系统各版本之间的共性。尽管现在微软的服务器操作系统版本和Windows11之间有明显区别,但关注细节的人可能会好奇:为什么WindowsServer更新了品牌,

如何在PHP微服务中实现分布式定时任务和调度如何在PHP微服务中实现分布式定时任务和调度Sep 25, 2023 pm 05:54 PM

如何在PHP微服务中实现分布式定时任务和调度在现代的微服务架构中,分布式定时任务和调度是非常重要的组成部分。它们能够帮助开发者轻松地管理、调度和执行多个微服务中的定时任务,提高系统的可靠性和可扩展性。本文将介绍如何使用PHP来实现分布式定时任务和调度,并提供代码示例供参考。使用队列系统为了实现分布式定时任务和调度,首先需要使用一个可靠的队列系统。队列系统能够

MySql的定时任务与调度:如何使用MySQL实现高效的定时任务和调度MySql的定时任务与调度:如何使用MySQL实现高效的定时任务和调度Jun 15, 2023 pm 07:47 PM

MySQL是目前使用最广泛的关系型数据库之一,它提供了众多的功能和工具,其中包括定时任务和调度功能。在实际开发中,我们经常需要定时执行某些任务,比如备份数据库、生成报表等,这时MySQL的定时任务和调度功能就能派上用场了。在本文中,我们将介绍MySQL的定时任务和调度功能,以及如何使用它们实现高效的定时任务和调度。一、MySQL的定时任务和调度功能MySQL

怎么修改Nginx版本名称伪装任意web server怎么修改Nginx版本名称伪装任意web serverMay 14, 2023 pm 09:19 PM

如何修改nginx默认的名称,可以稍微的伪装一下,也可以装x一般来说修改3个位置,一个是nginx.h、另一个是ngx_http_header_filter_module.c、还有一个ngx_http_special_response.c。提示:一般修改都是在nginx编译之前修改,修改完了之后需要重新编译代码如下:scr/core/nginx.conf#definenginx_version"1.4.7"#definenginx_ver"nginx/"n

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
3 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Best Graphic Settings
3 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. How to Fix Audio if You Can't Hear Anyone
3 weeks agoBy尊渡假赌尊渡假赌尊渡假赌

Hot Tools

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Powerful PHP integrated development environment

VSCode Windows 64-bit Download

VSCode Windows 64-bit Download

A free and powerful IDE editor launched by Microsoft

DVWA

DVWA

Damn Vulnerable Web App (DVWA) is a PHP/MySQL web application that is very vulnerable. Its main goals are to be an aid for security professionals to test their skills and tools in a legal environment, to help web developers better understand the process of securing web applications, and to help teachers/students teach/learn in a classroom environment Web application security. The goal of DVWA is to practice some of the most common web vulnerabilities through a simple and straightforward interface, with varying degrees of difficulty. Please note that this software

mPDF

mPDF

mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),