工作小技巧:windows环境如何查看进程使用的端口

概述

对于运维有时在排查网络问题时需要去查看进程使用的端口,下面整了一个bat脚本,主要利用netstat命令找出使用TCP协议通信的端口,并将结果分割;将第二个参数(IP加端口)传给%%i,第五个参数(PID号)传给%%j;

下面介绍下脚本内容。

bat脚本内容:
@echooffcolor1fTitleXP端口-进程查询setlocalenabledelayedexpansionecho╔--╗echo本机开放的端口及使用该端口的进程echo╚--╝echo------------------------------------echo端口号进程名称ECHOTCP协议:::利用netstat命令找出使用TCP协议通信的端口,并将结果分割;::将第二个参数(IP加端口)传给%%i,第五个参数(PID号)传给%%j;for/F"usebackqskip=4tokens=2,5"%%iin(`"netstat-ano-pTCP"`)do(call:Assoc%%iTCP%%jecho!TCP_Port!!TCP_Proc_Name!)ECHOUDP协议:for/F"usebackqskip=4tokens=2,4"%%iin(`"netstat-ano-pUDP"`)do(call:Assoc%%iUDP%%jecho!UDP_Port!!UDP_Proc_Name!)echo按任意键退出pausenul:Assoc::对%1(第一个参数)进行分割,将第二个参数传给%%e。在本程序中,%1即为上面的%%i(形式为:IP:端口号)for/F"tokens=2delims=:"%%ein("%1")do(set%2_Port=%%e)::查询PID等于%3(第三个参数)的进程,并将结果传给变量?_Proc_Name,?代表UDP或者TCP;for/F"skip=2usebackqdelims=,tokens=1"%%ain(`"Tasklist/FI"PIDeq%3"/FOCSV"`)do(::%%~a表示去掉%%a外面的引号,因为上述命令的结果是用括号括起来的。set%2_Proc_Name=%%~a)

在这里大家只需要新建一个txt,复制上面代码后修改后缀名为bat(本来为txt),然后右键以管理员身份运行就可以了。

运行结果:

版权声明:本站所有作品(图文、音视频)均由用户自行上传分享,仅供网友学习交流,不声明或保证其内容的正确性,如发现本站有涉嫌抄袭侵权/违法违规的内容。请举报,一经查实,本站将立刻删除。

相关推荐