对于运维有时在排查 *** 问题时需要去查看进程使用的端口,下面整了一个bat脚本,主要利用netstat命令找出使用TCP协议通信的端口,并将结果分割;将第二个参数(IP加端口)传给%%i,第五个参数(PID号)传给%%j;
下面介绍下脚本内容。
@echo off
color 1f
Title XP端口-进程查询
setlocal enabledelayedexpansion
echo ╔- -╗
echo 本机开放的端口及使用该端口的进程
echo ╚- -╝
echo ------------------------------------
echo 端口号 进程名称
ECHO TCP协议:
::利用netstat命令找出使用TCP协议通信的端口,并将结果分割;
::将第二个参数(IP加端口)传给%%i,第五个参数(PID号)传给%%j;
for /F "usebackq skip=4 tokens=2,5" %%i in (`"netstat -ano -p TCP"`) do (
call :Assoc %%i TCP %%j
echo !TCP_Port! !TCP_Proc_Name!
)
ECHO UDP协议:
for /F "usebackq skip=4 tokens=2,4" %%i in (`"netstat -ano -p UDP"`) do (
call :Assoc %%i UDP %%j
echo !UDP_Port! !UDP_Proc_Name!
)
echo 按任意键退出
pause>nul
:Assoc
::对%1(之一个参数)进行分割,将第二个参数传给%%e。在本程序中,%1即为上面的%%i(形式为:IP:端口号)
for /F "tokens=2 delims=:" %%e in ("%1") do (
set %2_Port=%%e
)
:: 查询PID等于%3(第三个参数)的进程,并将结果传给变量?_Proc_Name,?代表UDP或者TCP;
for /F "skip=2 usebackq delims=, tokens=1" %%a in (`"Tasklist /FI "PID eq %3" /FO CSV"`) do (
::%%~a表示去掉%%a外面的引号,因为上述命令的结果是用括号括起来的。
set %2_Proc_Name=%%~a
)
在这里大家只需要新建一个txt,复制上面代码后修改后缀名为bat(本来为txt),然后右键以管理员身份运行就可以了。
运行结果:
1.事情流程的界说 对组织而言,事情流程的本质是让权责分派公道高效,它指明白事情事项的勾当流向顺序,指组织内部产生的某项业务从起始到完成,由多个部分、多个岗亭、经多个环节协调及顺序事情配合完成的完整进...
facebook新心态标志发布 facebook新表情包发布。Facebook近日对全世界客户发布了一系列新的反映按键。在我们按住文章中关注按键就能见到全部的反映按键,随后就可以应用他们。除开关注...
找个私家侦探查小三需要多少钱?如何查小三所有的个人信息!...
南海里水怎么找外模价目表 他喜爱在暗室里游逛,每每我开启铁笼时,他都是奔向门。我还在90年代中后期的一次静态数据航展上碰到了迪妮莎模特网的航空员。我以前曾在这儿贴过一个贴子,但从数据上看来, 我或许...
关于thinkphp的缓存机制,是一个陈词滥调的问题,在本年强网杯final中也有相应的问题:请咱们遵从下列过程完结项目代码构建:网络垂钓进犯削减敞开服务前查询53端口状况,发现没有监听。 一个最新的...