Windows下bat批处理脚本使用telnet批量检测远程端口小记

多年没写过批处理了,来新公司的第一个case却是需要写一个bat脚本,批量更新采集agent的配置文件,其中就涉及到远程IP的端口检测。

本以为会和Linux一样可以简单判断:

结果发现Windows下面telnet退出并没有执行结果的返回值:

Windows下bat批处理脚本使用telnet批量检测远程端口小记

一、借助工具

于是我优先开启懒人法则,找其他替代工具。果然,在Windows老娘家找到了:

Portqryhttps://support.microsoft.com/en-us/kb/310099/zh-cn

确实可以使用,不过检测速度不敢恭维,通与不通都很慢!鉴于手头没有更好的解决办法,就先试试看,贴一下我写的Portqry相关demo:

Ps:check是一个被call调用的模块,里面的一些变量就不做介绍了。

于是兴冲冲的封装成exe,给IDC(server2003系统)执行,结果第一台就悲剧了!远程桌面直接断开了:

Windows下bat批处理脚本使用telnet批量检测远程端口小记

然后再也连不上了,要他们去机房看了下,结果告诉我系统没了!!??太震精了有木有?一个简单的文本操作脚本,居然把系统干掉了么?而且脚本中都不存在任何删除命令。。。

要那边提供了一下启动错误信息,原来是系统引导坏了:

Windows下bat批处理脚本使用telnet批量检测远程端口小记

个人分析了一下,应该是Portqry这个工具导致系统蓝屏关机,进而导致引导损坏!

尼玛,娘家人介绍时说好的“性格”良好呢?

Windows下bat批处理脚本使用telnet批量检测远程端口小记

唉,看来这个工具是不敢使用了,俗话说林子大了什么系统都有嘞!

二、另辟蹊径

既然工具不敢用了,还是继续折腾代码吧!周末睡觉前突然灵感一闪,想起了tasklist判断窗口名称这个“失传绝技”,于是把刚关闭的本子又打开,终于在GF的不断抱怨之下搞定了这个问题。

①、窗口判断

思路比较简单:使用start命令在新窗口执行telnet -e 和 exit命令,如果端口畅通,那么新开的窗口将会立即关闭,而不通的窗口则会保持近半分钟左右,且窗口名称类似 telnet 192.168.1.1,这半分钟时间足够脚本来判断通还是不通了。

于是将上面check部分修改如下:

样就解决了Windows下telnet探测远程端口的问题了,而且检测速度比微软哪个portqry快多了,果然思路比技术更重要,只要有想法,任何技术都不应该成为瓶颈!

②、进程判断【最新补充

当使用窗口判断的方案下发各大机房实施的时候,又一个问题出现了!窗口判断在某些版本的Windows下是行不通的,比如英文版下的命令提示符窗口名称和中文版的就不一样,所以这个方案也是不完善的!

于是,继续抓耳挠腮,想出了第二个方案:通过判断telnet进程数量来判断网络是否畅通。

方案思路:

a. 先判断脚本执行之前是否存在 telnet.exe 的进程,如果存在则统计数量

b. 和窗口判断一样,利用start命令在新的cmd命令提示符中执行 telnet 命令

c. 延迟几秒后统计系统中存在的telnet.exe进程数(存在的telnet表示是不通的)

d. 和最开始统计的 telnet 进程数比对计算,就知道有几个IP是不通的了

示例代码:

 

很明显,这样就可以知道我测试了所有IP当中有几个是不通的了。遗憾的是无法知道是哪个IP不通。不过在手头的这个case当中是不需要具体不通的IP的,只要知道通的IP是否达标就行。

好了,终于把这个问题给解决了。显然,任何时候都需要给出多个方案,而不是自满于一个方案。否则出问题就会焦头烂额了。当然,再次说明了想法比技术更重要。

发表评论

gravatar

:?::razz::sad::evil::!::smile::oops::grin::eek::shock::???::cool::lol::mad::twisted::roll::wink::idea::arrow::neutral::cry::mrgreen:

刷新评论

目前评论:20   其中:访客  15   博主  5

  1. 雪鹰领主 1 来自天朝的朋友 谷歌浏览器 Windows 7 湖北省黄冈市 电信

    技术帝就是厉害,顶礼膜拜了

  2. unmn 2 来自天朝的朋友 谷歌浏览器 Windows 7 广东省深圳市福田区 电信

    只能说牛B,不能再用其它语言表达。

  3. 威客任务 2 来自天朝的朋友 火狐浏览器 Windows 7 湖北省武汉市 电信

    就我现在的水平实在插不上嘴,我才知道表单提交的的说,慢慢来,总会有一天能和大神一起交流的

  4. 厘米天空 2 来自天朝的朋友 谷歌浏览器 Windows 8.1 安徽省马鞍山市 电信

    我来坐沙发,看来搞运维批处理必须掌握啊!

  5. 胡歌网摘 4 来自天朝的朋友 谷歌浏览器 Windows 7 广东省广州市 电信

    用Python……

    • 张戈 [博主] 来自天朝的朋友 QQ浏览器 Windows 7 广东省深圳市 联通

      py是可以,但需要额外安装环境支持。给客户的东西使用越简单越好。

      • f 1 Hong Kong 谷歌浏览器 Windows 10 香港 电讯盈科有限公司

        只要額外安裝,就有風險,萬一安裝python出了問題,又是一大輪折騰

  6. 青春励志语录 1 来自天朝的朋友 谷歌浏览器 Windows 8.1 湖北省武汉市 电信

    青春励志语录www.qclzyl.com博主的文章非常精彩,向博主学习~ 希望能和博主交换链接~

  7. 暴赚金 3 来自天朝的朋友 谷歌浏览器 Windows 7 河南省开封市 联通

    谢谢分享 搜来的

  8. 大老鹰2015 1 来自天朝的朋友 谷歌浏览器 Windows XP 河南省郑州市 联通

    talnet命令号强大的说

  9. 27joy.cn耕耘网 1 来自天朝的朋友 谷歌浏览器 Windows 7 广东省佛山市 电信

    老哥,你的网站车震效果很猛啊,搞得我心颤抖,还有点小鸡冻 :mrgreen:

  10. copdips 1 France 火狐浏览器 Windows 10 法国

    telnet只能tcp,udp还是不行啊

    • 张戈 [博主] 来自天朝的朋友 Safari浏览器  Android 4.4.4 M463C Build/KTU84P 湖南省长沙市 电信

      仔细看一看文章,portqry方案支持-p udp 参数,另外netcat也可以检测udp端口,自行百度看看。

      • copdips 1 France 火狐浏览器 Windows 10 法国

        你说portqry不好用,所以我就单看telnet了。最好的办法还是你说的netcat nmap之类感觉

  11. f 1 Hong Kong 谷歌浏览器 Windows 10 香港 电讯盈科有限公司

    有什麼辦法可以隱藏彈出來的Telnet窗口,想讓他後台執行

    • 张戈 [博主] 来自天朝的朋友 QQ浏览器 Windows 7 广东省广州市 电信

      http://blog.csdn.net/jeefchen/article/details/5644450

  12. wenyu 1 来自天朝的朋友 谷歌浏览器 Mac OS X 10_12_3 北京市 电信通

    for /l %i in (1,1,254) do ping -n 1 10.10.10.%i 输出文件,可以试试

    • 张戈 [博主] 来自天朝的朋友 QQ浏览器 Windows 7 广东省广州市 电信

      啥?文章说的是telnet测试端口是否通,不是能否ping通

      • wenyu 1 来自天朝的朋友 谷歌浏览器 Mac OS X 10_12_3 浙江省 电信

        全ping一遍,然后arp 可以看到那些机子存活,然后再进行后面的事情不是简单多了,有的机子禁ping,但是ping完以后arp 是有记录的。

        • 张戈 [博主] 来自天朝的朋友 QQ浏览器 Windows 7 广东省广州市 电信

          不是存不存活的问题,这些机器都存在,只是防火墙策略或网络链路不通,需要telnet测试的问题。

加载中,请稍候...