- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
这篇文章的重点是最终确定 SQL 服务器机器的 CPU 和 IO 利用率。传统上我们会使用@@cpu_busy、@@io_busy 和@@idle 来确定,但是在 MSSQL 上,它们会在 28 天后停止工作。我们从盒子上的不同来源获得了 CPU 利用率,但我们需要确定 IO 限制。
查看 sys.dm_os_wait_stats 中的数据并每十分钟计算一次增量时,等待的秒数可能超过十分钟。我也尝试除以等待的任务,但数据仍然没有意义。
基本上,我们希望将每种等待类型都变成十分钟内等待的百分比。但是,如果等待时间超过 10 分钟,则无法简单地将时间除以 10 分钟来查看使用百分比。
我们正在尝试确定一个指标来显示 IO 绑定(bind)框的情况。
https://msdn.microsoft.com/en-us/library/ms179984.aspx
wait_type = 等待类型的名称。有关详细信息,请参阅本主题后面的等待类型。
waiting_tasks_count = 此等待类型的等待次数。该计数器在每次等待开始时递增。
wait_time_ms = 此等待类型的总等待时间(以毫秒为单位)。
编辑
第一个答案在正确的轨道上,但不完全正确。该统计数据显示的是对于给定的时间间隔,可归因于任何一种特定等待类型的等待百分比。请参见下图。
编辑
基于超过 10 分钟间隔的增量的相关矩阵:
wait_time_ms wait.NO.signal signal_wait_time @@io_busy @@cpu_busy ioPct cpuPctwait_time_ms 100 100 70 74 58 71 58wait.NO.signal 100 100 64 72 53 69 53signal_wait_time 70 64 100 71 89 67 89@@io_busy 74 72 71 100 77 99 77@@cpu_busy 58 53 89 77 100 75 100ioPct 71 69 67 99 75 100 75cpuPct 58 53 89 77 100 75 100
在上面的图表中,可以看到信号时间与@@cpu_busy 滴答计数器增量的相关性最高。等待时间与@@io_busy 计数器增量最相关。
根据@@vars,此 SQL 框受 cpu 限制(cpu% 比 io% 高很多),而“根据”等待统计信息,它受 IO 限制。根据 sys.dm_os_ring_buffers ,该框受 CPU 限制。我相信 SystemHealth/SystemIdle 所说的。
这篇文章建议可以使用信号等待时间 vs 等待时间来获得 CPU 压力%。然而,与@@cpu_busy 的数据相比,我强烈怀疑他的结论只是部分正确。如果他的 cpuPressure% 很高,是的,增加 CPU 能力会有所帮助,但这不是全部。 http://blogs.msdn.com/b/sqlcat/archive/2005/09/05/461199.aspx
wait_time_ms cpuPress wait.NO.signal signal_wait_time @@io_busy @@cpu_busy ioPct cpuPctcpuPress -50 100 -56 25 -11 25 -11 25
编辑
以下适用于所选框之一,但鉴于不同的内核,我们必须将其考虑在内。
summary(m)Call:lm(formula = ioPct ~ cpuPct + signal_wait_time + wait_time_ms, data = rd)Residuals: Min 1Q Median 3Q Max -3.13921 -0.75004 -0.07748 0.60897 2.14655 Coefficients: Estimate Std. Error t value Pr(>|t|) (Intercept) -0.442311370934 0.085652949324 -5.164 0.000000286383 xxxcpuPct 0.123717691895 0.004503995334 27.468 less 2e-16 xxxsignal_wait_time -0.000000302969 0.000000046933 -6.455 0.000000000161 xxxwait_time_ms 0.000000022240 0.000000002534 8.777 less 2e-16 xxx---Signif. codes: 0 ‘xxx’ 0.001 ‘xx’ 0.01 ‘x’ 0.05 ‘.’ 0.1 ‘ ’ 1Residual standard error: 0.9959 on 1109 degrees of freedomMultiple R-squared: 0.7566, Adjusted R-squared: 0.7559 F-statistic: 1149 on 3 and 1109 DF, p-value:
最佳答案
在多核机器上,每个 CPU 都有自己的调度器,并且可以注册自己的等待。例如 - 如果您有一个跨多个 CPU 并行运行的查询,则并行查询的每个部分都可以在等待查询完成时注册自己的 CXPACKET 等待。
要获得利用率,只需除以总等待时间,而不是 10 分钟。
SELECT wait_type,
wait_time_ms * 100.00 / SUM(wait_time_ms) OVER()
FROM sys.dm_os_wait_stats
关于sql-server - Microsoft SQL sys.dm_os_wait_stats 加起来比时间段多毫秒,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30389242/
这是一个复杂的查询,我希望用一条语句实现它,而不是必须在 PHP 中处理数组值。 要达到预期的输出: User Jobs Total John D. 5 $1245.67 Ma
SELECT B. * , SC.cate_name, ( CASE WHEN special_offer_type = 'Fixed Value' THEN B.price - special_o
关于将 booksleeve 与 protobuf-net 结合使用,我有一些相当基本的问题。现在我已经实现了一个单例类来管理连接,所以我多次重复使用与 recommended 相同的连接。 .现在我
我想要一个客户端加/减系统,用户可以单击加号,值会增加 1,减号,值会减少 1,该值永远不应该低于零,并且应该从 0 开始.有没有办法在 jquery 中简单地做到这一点?所有 jquery 插件都会
我正在使用加号和减号按钮更新我的产品数量,这很有效,但我的问题是因为我在一个容器中有多个产品,它正在更新所有产品的数量。这是代码:
我需要在大小相等的小整数数组上做大量简单的代数运算。这些操作仅包括三种:(i) 添加数组和 (ii) 按元素减去数组,以及 (iii) 比较一个数组中的所有元素是否不小于/大于另一个数组中的对应元素。
我对 javascript 很陌生,但我需要一种 JS 方式来在单击按钮时增加/减少输入字段中的值。我已成功将值设置为显示 0,但当我单击“添加”按钮时,它不会增加。 以下是 html 和 JS 代码
我可以在输入字段中添加/减去一个数字。 但是,我希望结果显示在中而不是在input中字段。 我尝试使用innerHTML自己完成它但无法让它发挥作用。 $(function() { $('.min
我的页面上有一个加号/减号 jquery 选择器。当页面加载或数字达到 1 时,我希望减号按钮变灰以模拟非事件状态。这是我的代码和 fiddle https://jsfiddle.net/pgxvhs
我如何加/减用户输入的十六进制数? 喜欢: basehex = input() sechex = input() sum = hex(basehex - sechex) print(sum) 我得到:
本文实例讲述了python简单实现矩阵的乘,加,转置和逆运算。分享给大家供大家参考,具体如下: 使用python完成矩阵的乘,加,转置和逆: ?
我输入的一些文本包括几个上下箭头(↑ 和 ↓),以及一个加号/减号 (±)。 这些特殊字符以 HTML ASCII 输入:↑ ↓ ±。在 POST 上,HTML 在保存到 MySQL 表之前使用 ht
我正在尝试配置 Live Gamer Portable 2 Plus 的输出引脚以降低帧速率。通过 GraphStudioNext,我可以通过捕获引脚访问配置并更改帧速率。 但是,当我通过 API 在
我正在尝试使用批处理文件创建任意时间。我试图从我的代码中减去设置值(例如1天,1个月和2000年),以显示系统时间减去前面所述的设置值。对于小时和分钟,我要减去10小时和10分钟(在代码中显示为不同的
我想建立一个 5 位向上/向下计数器。当我能让模拟工作时,我会更乐意购买零碎的东西来构建它。到目前为止,我使用的是 ATmega8,但坦率地说,只要组件相当便宜,任何解决方案都适合我。 我在网上找到了
使用 ng-repeat 时在数字输入字段上添加加/减切换的最佳方法是什么 我这样试过,但没用: - + vm.plus = f
我正在尝试弄清楚如何将 UNION 与相同的 JOIN 一起使用,而不是陷入 #2014 - 命令不同步。 我创建了四个简单的表格并为它们编写了简化的代码。主要想法是获得名字中带有“最佳”字样的每把剑
这个问题已经有答案了: Is floating point math broken? (33 个回答) 已关闭 9 年前。 我有一个简单的函数,应该生成 1000 个不同的元素: var start
我目前正在编写一个响应式设计,我正处于移动导航折叠的地步。 为此,我创建了两个 div 和一个 ul。 ul 包含我的 nav 元素,而 div 将显示移动设备和平板电脑下拉菜单的导航图像。 HTML
我为 woocommerce 单个产品页面创建了一个加/减数量按钮。创建了一个新的数量-input.php " min="" max="" name="" value="" ti
我是一名优秀的程序员,十分优秀!