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

使用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 – 第二个脚本的功能就是打开连接,让它保持打开然后重复执行查询脚本,直到你手动终止循环才会中断循环关闭连接。

 

 image

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

 

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

PowerShell脚本的概述

 

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

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

123

图2 主要的参数变量

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

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

121

图3 循环部分

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

321

图4 日志记录部分

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

321

 

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

321

错误日志信息

 

第二个脚(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”

脚本下载地址:

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

谢谢博友提供方式。

下载地址:

https://files.cnblogs.com/files/wenBlog/OpenConnLoopQuery_Long.zip

https://files.cnblogs.com/files/wenBlog/OpenConnQueryCloseConn.zip

总结

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

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/119619.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 最通俗易懂的JavaScript入门教程

    最通俗易懂的JavaScript入门教程前言:“成功没有捷径,脚踏实地一步一个脚印,该来的总会来,不好高骛远,不急功近利,付出总会有回报,不管处于哪个阶段,都要一步一个脚印,踏实的走好每一步!”你好,我是梦阳辰!快和我一起走进JavaScript的世界吧。01.JavaScript概述1.什么是JavaScript?JavaScript是运行在浏览器上的脚本语言。简称JS。JavaScript是王景公司(NetScape)…

    2022年7月17日
    11
  • 【已解决】罗技K380蓝牙键盘可以连接电脑,但无法输入怎么办?[通俗易懂]

    【已解决】罗技K380蓝牙键盘可以连接电脑,但无法输入怎么办?[通俗易懂]【问题】罗技k380可以连接并正常使用平板、手机。电脑显示着已连接,但就是无法输入。之前是可以用的,最近需要频繁配对突然不能用了。网上的各种方法都不好使,问京东客服也解决不了准备申请售后。【解决方案】后来仔细看了下k380使用方法,发现Fn+F1可以重置键盘的蓝牙设备,于是在电脑删除了k380蓝牙设备后,在蓝牙键盘上进行了Fn+F1重置,最后进行重启配对就ok了。可能是频繁配对让键盘有了缓存错误了。

    2022年10月16日
    0
  • Expected BEGIN_ARRAY but was BEGIN_OBJECT at line 1 column 21 path $.data

    Expected BEGIN_ARRAY but was BEGIN_OBJECT at line 1 column 21 path $.data

    2021年10月1日
    159
  • 大数据的胖哥的方式(9)- 金融业数据仓库的逻辑模型FS-LDM

    大数据的胖哥的方式(9)- 金融业数据仓库的逻辑模型FS-LDM

    2022年1月4日
    232
  • UIWebView OC与JS交互那些事

    UIWebView OC与JS交互那些事UIWebView 基础 1 UIWebView 与 WKWebView 基本使用 https blog csdn net article details UIWebView 与 JS 交互本人使用的是原生的 JavaScriptCo 库或者第三方 WebViewJavas 第三方 WebViewJavas

    2025年7月21日
    0
  • Linux SIGPIPE信号产生原因与解决方法

    Linux SIGPIPE信号产生原因与解决方法TCP四次握手产生SIGPIPE的原因SIGPIPE信号产生的原因:简单来说,就是客户端程序向服务器端程序发送了消息,然后关闭客户端,服务器端返回消息的时候就会收到内核给的SIGPIPE信号。TCP的全双工信道其实是两条单工信道,client端调用close的时候,虽然本意是关闭两条信道,但是其实只能关闭它发送的那一条单工信道,还是可以接受数据,server端还是可以发送…

    2022年5月30日
    47

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号