linux 根據端口關閉程序的管道命令


netstat -anp|grep :3306|head -n1|cut -d"/" -f1|sed 's/ /\r\n/g'|tail -n1|xargs -I{} kill -9 {}

  

netstat -anp查看所有連接端口 -p [可以查看占用程序的pid]
|
grep :3306篩選出含 :3306的語句 即端口號
|
head -n1只取第一行信息
|
cut -d"/" -f1根據"/"將信息拆分 -f1取第一區域
|
sed 's/ /\r\n/g'將這信息的空格替換為 \r\n 即為回車
|
tail -n1選取最后一行的文字 即為pid
|
xargs -I{}可以為后面的語句 賦參 -I{} 可以將參數放在{}的位置
kill -9 {}后面跟pid 可以殺掉程序。。

寫了一下午 頭疼


另外

touch 1.txt |netstat -anp | grep :3306|head -n1|xargs -I{} echo {} >1.txt |cat 1.txt 

不清楚為什么echo后面的管道會不起作用

-------

似乎是因為echo在執行完整個管道才會關閉流的原因,使得cat執行時無法查到txt里的內容,具體原理以后再說嘍

又花了2小時更改了命令已經可以執行了

touch 1.txt|netstat -anp|grep :3306|head -n1|cut -d"/" -f1|xargs -I{} echo {}>1.txt;tr ' ' '\n'<1.txt|tail -n1|xargs -I{} kill -9 {};rm -f 1.txt

 

touch 1.txt:創建1.txt文件

|

netstat -anp查看所有連接端口 -p [可以查看占用程序的pid]
|
grep :3306篩選出含 :3306的語句 即端口號
|
head -n1只取第一行信息
|
cut -d"/" -f1根據"/"將信息拆分 -f1取第一區域

|

echo 用於傳輸與打印文字,這里將字符寫入txt

:這里是分號; 用於將這段命令結束,相當於回車。

tr ' ' '\n'<1.txt:將1.txt內的空格轉換為回車

|

tail -n1選取最后一行的文字 即為pid
|
xargs -I{}可以為后面的語句 賦參 -I{} 可以將參數放在{}的位置 
kill -9 {}后面跟pid 可以殺掉程序。。

rm -f 1.txt: rm刪除1.txt  -f無警告刪除

 

其實這命令只是寫着玩的 如要食用還請第一條

--------------------

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM