SQL Server自动化运维系列——监控性能指标脚本(Power Shell)

网友投稿 1240 2022-10-14

本站部分文章、图片属于网络上可搜索到的公开信息,均用于学习和交流用途,不能代表睿象云的观点、立场或意见。我们接受网民的监督,如发现任何违法内容或侵犯了您的权益,请第一时间联系小编邮箱jiasou666@gmail.com 处理。

SQL Server自动化运维系列——监控性能指标脚本(Power Shell)

需求描述

一般在生产环境中,有时候需要自动的检测指标值状态,如果发生异常,需要提前预警的,比如发邮件告知,本篇就介绍如果通过Power shell实现状态值监控

监控值范围

根据经验,作为DBA一般需要监控如下系统能行指标

cpu:     \Processor(_Total)\% Processor Time    \Processor(_Total)\% Privileged Time     \SQLServer:SQL Statistics\Batch Requests/sec    \SQLServer:SQL Statistics\SQL Compilations/sec    \SQLServer:SQL Statistics\SQL Re-Compilations/sec    \System\Processor Queue Length    \System\Context Switches/sec   Memory:     \Memory\Available Bytes    \Memory\Pages/sec    \Memory\Page Faults/sec    \Memory\Pages Input/sec    \Memory\Pages Output/sec    \Process(sqlservr)\Private Bytes    \SQLServer:Buffer Manager\Buffer cache hit ratio    \SQLServer:Buffer Manager\Page life expectancy    \SQLServer:Buffer Manager\Lazy writes/sec    \SQLServer:Memory Manager\Memory Grants Pending    \SQLServer:Memory Manager\Target Server Memory (KB)    \SQLServer:Memory Manager\Total Server Memory (KB)   Disk:     \PhysicalDisk(_Total)\% Disk Time    \PhysicalDisk(_Total)\Current Disk Queue Length    \PhysicalDisk(_Total)\Avg. Disk Queue Length    \PhysicalDisk(_Total)\Disk Transfers/sec    \PhysicalDisk(_Total)\Disk Bytes/sec    \PhysicalDisk(_Total)\Avg. Disk sec/Read    \PhysicalDisk(_Total)\Avg. Disk sec/Write   SQL Server:     \SQLServer:Access Methods\FreeSpace Scans/sec    \SQLServer:Access Methods\Full Scans/sec    \SQLServer:Access Methods\Table Lock Escalations/sec    \SQLServer:Access Methods\Worktables Created/sec    \SQLServer:General Statistics\Processes blocked    \SQLServer:General Statistics\User Connections    \SQLServer:Latches\Total Latch Wait Time (ms)    \SQLServer:Locks(_Total)\Lock Timeouts (timeout > 0)/sec    \SQLServer:Locks(_Total)\Lock Wait Time (ms)    \SQLServer:Locks(_Total)\Number of Deadlocks/sec    \SQLServer:SQL Statistics\Batch Requests/sec    \SQLServer:SQL Statistics\SQL Re-Compilations/sec

监控脚本

其中涉及到2个配置文件:computernamexml,alter_cpuxml分别如下:

wuxuelei-pc

\Processor(_Total)\% Processor Time \Processor(_Total)\% Privileged Time \SQLServer:SQL Statistics\Batch Requests/sec \SQLServer:SQL Statistics\SQL Compilations/sec \SQLServer:SQL Statistics\SQL Re-Compilations/sec \System\Processor Queue Length \System\Context Switches/sec

其中 alter 就是阀值,如第一条,如果 阀值 > 性能计数器值,就会发出警告。

其实这种自定义配置的方式,实现了灵活多变的自动化监控标准:

1、比如可以检测磁盘空间大小

2、检测运行峰值状态

3、定时的根据历史运行值,更改生产系统中的阀值大小,也就是所谓的运行基线

警告实现方式

1、SQL Agent配置Job方式实现

2、计划任务

以上两种配置方式,可以灵活掌握,操作还是蛮简单的,如果不会,可自行google。当然,如果不想干预正常的生产系统,可以添加一个Server专门用来自动化运维检测来用,实现远程监控。

后续文章中会分析关于Power Shell的远程调用,并且能实现事故当前状态下,自动化截图....自动Send Email......为DBA现场取证第一手材料...方便诊断问题...

效果图如下

以上只提供实现方式,如需要内容更新,自己灵活更新。

上一篇:重磅 | 华为开源多云多 Kubernetes 集群应用编排项目 Karmada
下一篇:记一次 Kubernetes 集群被入侵,服务器变矿机
相关文章

 发表评论

暂时没有评论,来抢沙发吧~