使用PowerShell 监控运行时间和连接情况

概念

Powershell 是运行在windows机器上实现系统和应用程序管理自动化的命令行脚本环境。你可以把它看成是命令行提示符cmd.exe的扩充,不对,应当是颠覆。 powershell需要.NET环境的支持,同时支持.NET对象。微软之所以将Powershell 定位为Power,并不是夸大其词,因为它完全支持对象,面向对象的便捷可想而知了。其可读性,易用性都非常的完美。

在运维windows 服务器的时候,其作用是非常大的。简洁高效等等。这里我简单用一个我应用的地方来展示一下。

背景

有时候我们需要监视来自特定用户电脑对于数据库的连接。比如该用户说,他偶尔会断开连接或者有时连接某个程序时出现问题,而数据库就是我的数据库。这个问题一开始真的很让我着急(FUCK),因为问题不是经常能够重现难以追踪。即使重现了错误,可能提供的信息也不够完整。

为了帮助实现对此类问题的troubleshoot ,我编写了两个PowerShell 脚本。脚本能够可以无人值守,并且日志在一段时间后查询。我打算在用户的PC上运行这个脚本,并且该PC在不同的网络或者不同的子网。也可以在同一时间在SQLServer服务器运行脚本。会产生三个不同的日志文件,然后进行比较。这些脚本是对于cpu使用和负载占用很少的轻量级程序。但是必须要谨慎使用运行的查询,尽量针对一些小的表进行查询等,比如select count(*)from 小表。

基本上所有这些脚本主要实现是:连接SQLServer并且执行查询。循环执行查询知道手动终止它。假如有错误重现了,就会记录日志到日志文件然后再次连接->执行查询。

OpenConnQueryCloseConn.ps1 - 这个脚本作用就是打开连接数据库实例,运行sql指令,然后关闭连接。这个处理将会一次又一次的重复直到你手动关闭它。

OpenConnLoopQuery_Long.ps1 - 第二个脚本的功能就是打开连接,让它保持打开然后重复执行查询脚本,直到你手动终止循环才会中断循环关闭连接。

图1 最大区别在于循环位置

两个脚本都会在终端和日志记录日志。如果连接产生问题我们也希望在日志文件中看到错误信息。当错误信息只在一个日志文件中,那么有时就能引导我们发现网络或者特定的某种错误。

PowerShell脚本的概述

首先我们来看一下OpenConnQueryCloseConn.ps1这个脚本。这个脚本一开始先设定连接参数。确保下面的参数是可用的参数。

21-27行就是我们的连接参数和查询命令变量 。

图2 主要的参数变量

$serverName="服务器名称"
$databaseName="数据库名称"
$uid="User ID"
$pwd="user Password "
$sqlCommand="命令语句-比如查询一个小表的行数"
$logLoaction="记录日志文件的位置.   ---  c:\ps\OpenConnQueryCloseConn.log"

脚本的底部就是循环的主要部分。

图3 循环部分

fn_HitSQL 函数大部分工作已经完成了。打开数据库连接然后不断去执行查询。有很多地方主要的工作就是日志记录。如下:

图4 日志记录部分

还有一个函数去记录连接和错误。函数fn_WriteToLog 将错误信息附加上日期后记录到终端然后添加到日志文件中。

做好了以上所有工作后,执行脚本,当法伤网络连接问题时,就会产生日志文件错误日志。如下:

错误日志信息

第二个脚(OpenConnLoopQuery_Long.ps1 )本基本上与第一个一样如图1 中所示一样就是在执行语句后面紧跟着一个循环语句这样避免了关闭连接。在一个连接中不断重复语句。这里也就不仔细讲解了。

运行两个脚本需要执行powershell 脚本,指令如下,当然也可以自己拼写:

PowerShell.exe -ExecutionPolicy Bypass -File C:\PS\OpenConnLoopQuery_Long.ps1
PowerShell.exe -ExecutionPolicy Bypass -File C:\PS\OpenConnQueryCloseConn.ps1

需要注意的是要提前设定好路径“C:\PS”

脚本下载地址:

没找到如何上传脚本...,有哪位大神可以告知。具体脚本可向我询问留言即可。发邮箱

总结

本篇主要介绍了自己开发的一个利用powershell来实现的循环监测连接出现网络异常的脚本。本质上就是循环连接查询数据库,记录连接失败或者查询失败的信息。之前通过C#和其他开发工具也都实现过不论是windowsService 还是其他小程序。但是感觉powershell开发起来更简单,对机器性能影响更小,当然python也是一样的道理。之所以选择使用powershell主要是学习响应的语法便于将来运维windows服务器。越来越发现PowerShell的强大,与高手相比还有很大空间要去学习。

时间: 2024-11-15 16:31:05

使用PowerShell 监控运行时间和连接情况的相关文章

datasnap 如何监控客户端的连接情况

如果客户端是TCP/IP是短连接的情况就没有必要了. 1 type 2 pClientConns = ^TClientConns; // 客户连接 3 TClientConns = record 4 clientid: integer; 5 ip: string; 6 port: string; 7 logintime: TDateTime; 8 end; 9 10 type 11 G_ClientConnects: TDictionary<TIdTCPConnection, pClientCo

netstat监控大量ESTABLISHED连接与Time_Wait连接问题

问题描述: 在不考虑系统负载.CPU.内存等情况下,netstat监控大量ESTABLISHED连接与Time_Wait连接. # netstat -n | awk '/^tcp/ {++y[$NF]} END {for(w in y) print w, y[w]}' CLOSE_WAIT 348 ESTABLISHED 1240 TIME_WAIT 5621 监控Apache与tomcat之间的链接端口 #netstat -n | grep 8009 | wc -l 7198 问题1:怎么解决

jconsole监控内容和CPU情况

jconsole监控内容和CPU情况 本地:开始--运行--cmd--jconsole,弹出选择框: 查看本地内存和CPU使用情况: 选择本地进程,选择并点击一下sun.tools.jconsole.JConsole这一行,然后点击连接,就可以查看我们的内存和CPU的使用情况了. 服务器内存和CPU信息: 远程进程,在文本框中输入我们需要测试的服务器的IP地址:端口,然后在下面输入用户名和密码,点击连接,就能测服务器内容等情况

[AlwaysOn Availability Groups]使用Powershell监控AlwayOn健康

使用Powershell监控AlwayOn健康 1.基本命令概述 AlwayOn Dashboard是很有用的查看整体AG健康状况的工具.但是这个工具不是用于7*24监控的.如果应用程序夜间发送严重的问题,Dashboard并不会有任何提示.那么可以使用Powershell命令来获取并通过SQL Agent调用创建告警. 1.1 Dashboard 首先创建一个AG.这个AG被配置为自动故障转移.查看这个AG的dashboard 通过查看AG的状态发现,AG状态不对.而且问题是来自于WSNAVE

服务器性能调优(netstat监控大量ESTABLISHED连接与Time_Wait连接问题)

netstat监控大量ESTABLISHED连接与Time_Wait连接问题 问题描述: 在不考虑系统负载.CPU.内存等情况下,netstat监控大量ESTABLISHED连接与Time_Wait连接. # netstat -n | awk '/^tcp/ {++y[$NF]} END {for(w in y) print w, y[w]}' CLOSE_WAIT 348 ESTABLISHED 1240 TIME_WAIT 5621 监控Apache与tomcat之间的链接端口 #netst

powershell 监控, 重启网卡

#powershell 监控, 重启网卡 一台Windows服务器,由于负荷较大,偶尔会网络中断,就写了个powershell脚本,监控ip是否通,不通就重启网卡 cls $host.UI.RawUI.WindowTitle = '--VM监控--' $host.UI.RawUI.ForegroundColor='Green' #version V1.3.9 #t1间隔时间s $t1=5 $log='C:\Router.log.txt' #region $nu=0 $n1="##########

利用ngxtop实时监控nginx的访问情况

关于对nginx web server的实时访问的实时监控问题,我很久之前就想实现的,现在虽有nginx自带的status扩展,但那是全局的,无法细分到vhost,并且提供的metric也很少,加之目前是通过cacti每5分钟取nginx status,实时性也不是很好,记得前一阵为maptail兴奋一点,以为能够解决我的问题,可是他只是漂亮的在地图上显示实时用户的ip地理位置信息,没有其他功能了,不过他的思想很重要---"tail -f log",如今的ngxtop其实也是这种思想,

Java千百问_07JVM架构(018)_如何监控jvm的运行情况

点击进入_更多_Java千百问 1.如何监控jvm的运行情况 了解jvm内存模型看这里:java内存模型是什么样的 了解jvm内存管理看这里:jvm是如何管理内存的 了解jvm垃圾回收机制看这里:java垃圾回收机制是什么 了解jvm内存优化看这里:java内存如何优化 我们通常使用Jdk工具来监控jvm的运行情况,当然目前有很多第三方产品是通过jdk提供的api来组织数据进行监控的.具体来说有如下监控软件: Jconsole jdk自带,功能简单,但是可以在系统有一定负荷的情况下使用.对垃圾回

Inotifywait解决监控子目录树的情况

Inotifywait解决监控子目录树的情况   inotifywait是一个可以实时监控文件变动的工具.它利用linux内核中的inotify机制实现监控功能,在内核高于2.6.13的版本中,据说不需要软件的安装包.(本实验采用centos7.3) ○前提:系统支持inotify inotifywait 命令的常用参数包括: -m, --monitor       保持一直监听 -r, --recursive       若有多级目录循环递归每一层. -q, --quiet