有時候根據應用需求,會需要針對去檢查目前系統上有哪些port正在被使用
#[FreeBSD]
可以使用 sockstat 這個command 來檢查系統上port的使用。
USER COMMAND PID FD PROTO LOCAL ADDRESS FOREIGN ADDRESS
root cron 93468 4 udp4 :638 :*
在預設的情況下,會輸出
使用者名稱,執行的程序,該程序的pid,在該程序中使用該port的file descriptor是多少 使用何種協定,以及address
如果使用 sockstat -4lP tcp 就可以找出 使用tcp & ipv4 ,並且正在listen的port
這對於要尋找是否有人在寫Socket programming來說是很方便的。
詳細的可以man sockstat
#[Linux]
可以使用 netstat 這個工具來檢視,搭配一些參數還可以看到該 port 被那些 process 使用
netstat -anptn
tcp 1 0 127.0.0.1:40147 127.0.0.1:36524 CLOSE_WAIT 7147/vim
tcp 1 0 127.0.0.1:58289 127.0.0.1:52849 CLOSE_WAIT 19421/vi
...
#[Windows]
可以使用netstat來檢視,netstat能夠顯示的資訊非常的多,為了精簡我們的需求,必須去過濾這些資訊
在windows上使用find這個指令,類似於UNIX中grep的功能
舉例來說,netstat -an |find /i “listening" 這個指令
netstat -an 會顯示所有連線以及正在監聽的port,並且以數字的形式來顯示IP以及PORT
find /i “listening" 則會以不區分的方式去搜尋每一行,若包含listening則將該行印出
EX:
TCP 192.168.1.116:139 0.0.0.0:0 LISTENING
TCP 192.168.1.116:49156 216.52.233.65:12975 ESTABLISHED
ref:
www.microsoft.com/resources/