如何查看哪個端口被哪個應用占用


1)使用lsof命令
lsof是一個非常強大的linux工具,她被用來查找哪些程序使用了那些文件。在linux系統下,基本上所有的東西都可以被當作文件來用。socket當然也是一種文件了。所以lsof可以用來查找誰用了某一個端口。具體方法:
lsof -i :port_number |grep "(LISTEN)"
-i是用來查找和網絡相關的文件,":"號是必須的,它是標志你查找的是一個端口。port_number就是你要查找的端口號,譬如你要查找是否 有程序占用了oracle的監聽端口1521,就可以使用lsof -i :1521 |grep "(LISTEN)"。如果有程序已經占用了,那么下面打印的第二個字段就是該程序的進程id,第一個字段是進程的名字。
如果只有losf -i :port_number可能會查到很多應用程序,但這些程序實際並沒有占用你指定的端口,這些端口只是連接到本機器或者別的機器的該端口。所以要grep "(LISTEN)“,因為一個端口只可能被一個程序占用的,所以這種方法是可靠的。

2)使用netstat 命令
大家一定對這個命令比較熟悉了,可能你從沒有想到用到來查找哪一個程序的占用了指定的端口。但是netstat -an 的確提供了這種功能。所以有問題了一定要想到先去查找man手冊,不過說實話,某些man手冊寫得讓中國人看不懂,那沒有辦法了,就googe或者 baidu一下吧。
執行man netstat命令,你會發現netstat 提供了'-p'的選項,這個選項的功能是告訴你哪個程序占用了該端口,但是她提供的形式比較古怪是以pid/process_name提供的。pid當然 是進程id了,process_name是進程的命令,中間以'/'號分隔。
和上面的原因一樣,我們只查找listen的端口,netstat 給我們提供了-l的選項,這個選項不是默認的選項。
下面以1521端口來看怎么查找到該程序,我們使用下面的命令:
netstat -lnp|awk 'BEGIN{prt=":1521$"}{if ($4 ~ prt) print $0}'
在這里使用awk來匹配第4個字段的模式是為了避免誤判。

ll /proc/id


免責聲明!

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



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