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無警告刪除
其實這命令只是寫着玩的 如要食用還請第一條
--------------------