Mac 下查看某個端口的占用情況,并殺死進程
使用Hexo時,本機以4000端口啟動server:
sh-3.2# hexo server
INFO Hexo is running at http://0.0.0.0:4000/. Press Ctrl+C to stop.
此時,4000端口被Hexo占用,如果想查看4000端口的占用情況,使用:
sh-3.2# lsof -i:4000
COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME
QQ 1942 tongkun 14u IPv4 0x1d28bfd60907da57 0t0 UDP *:terabase
node 2476 root 12u IPv4 0x1d28bfd61b65bd9f 0t0 TCP *:terabase (LISTEN)
可以看出4000端口正在node(進程的名稱)程序,pid2476是它的進程號,如果想殺死進程,執(zhí)行:
sh-3.2# kill -9 2476
lsof 介紹:
lsof(list open file)是一個列出當前系統打開文件的工具,在linux/unix系統中,任何事物都是以文件的形式存在,通過文件不僅可以訪問常規(guī)數據,還可以訪問網絡連接和硬件。所以如果傳輸控制協議(TCP)和用戶數據包協議(UDP)套接字等,系統在后臺都為該應用分配一個文件描述符,無論這個文件的本質如何,該文件描述符為應用程序與基礎操作系統之間提供了通用的接口。
lsof 輸出信息含義,ps:
sh-3.2# lsof -i :80
COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME
nginx 1287 root 9u IPv4 0x1d28bfd6090094bf 0t0 TCP *:http (LISTEN)
nginx 1288 nobody 9u IPv4 0x1d28bfd6090094bf 0t0 TCP *:http (LISTEN)
vmnet-nat 2317 root 7u IPv4 0x1d28bfd61eac2d9f 0t0 TCP 192.168.0.22:60264->hn.kd.ny.adsl:http (ESTABLISHED)
vmnet-nat 2317 root 10u IPv4 0x1d28bfd61b61a4bf 0t0 TCP 192.168.0.22:60548->111.206.79.231:http (ESTABLISHED)
vmnet-nat 2317 root 18u IPv4 0x1d28bfd61ea914bf 0t0 TCP 192.168.0.22:60927->123.126.51.18:http (CLOSE_WAIT)
vmnet-nat 2317 root 29u IPv4 0x1d28bfd609008bdf 0t0 TCP 192.168.0.22:60964->215.255.72.118.adsl-pool.sx.cn:http (CLOSE_WAIT)
vmnet-nat 2317 root 30u IPv4 0x1d28bfd61eaae85f 0t0 TCP 192.168.0.22:60965->111.202.102.35:http (CLOSE_WAIT)
vmnet-nat 2317 root 31u IPv4 0x1d28bfd61b5e7d9f 0t0 TCP 192.168.0.22:60963->123.126.51.33:http (CLOSE_WAIT)
說明
每行打開一個文件,如果不指定條件,將顯示所有進程打開的文件。lsop輸出各列信息如下:
- COMMAND:進程的名稱
- PID:進程標識符
- USER:進程所有者
- FD:文件描述符,應用程序通過文件描述符識別該文件。如cwd、txt等
- TYPE:文件類型,如DIR、REG等
- DEVICE:指定磁盤的名稱
- SIZE:文件的大小
- NODE:索引節(jié)點(文件在磁盤上的標識)
- NAME:打開文件的確切名稱
其中FD 列中的文件描述符cwd 值表示應用程序的當前工作目錄,這是該應用程序啟動的目錄,除非它本身對這個目錄進行更改,txt 類型的文件是程序代碼,如應用程序二進制文件本身或共享庫,如上列表中顯示的 /sbin/init 程序。其次數值表示應用程序的文件描述符,就是打開文件時返回的一個整數。u表示該文件并處于打開并讀寫模式
常用的參數列表:
- lsof filename 顯示打開指定文件的所有進程
- lsof -a 表示兩個參數都必須滿足時才顯示結果
- lsof -c string 顯示COMMAND列中包含指定字符的進程所有打開的文件
- lsof -u username 顯示所屬user進程打開的文件
- lsof -g gid 顯示歸屬gid的進程情況
- lsof +d /DIR/ 顯示目錄下被進程打開的文件
- lsof +D /DIR/ 同上,但是會搜索目錄下的所有目錄,時間相對較長
- lsof -d FD 顯示指定文件描述符的進程
- lsof -n 不將IP轉換為hostname,缺省是不加上-n參數
- lsof -i 用以顯示符合條件的進程情況
- lsof -i[46][protocol][@hostname|hostaddr][:service|port]
- 46 –> IPv4 or IPv6
- protocol –> TCP or UDP
- hostname –> Internet host name
- hostaddr –> IPv4地址
- service –> /etc/service中的 service name (可以不只一個)
- port –> 端口號 (可以不只一個)
查看所屬root用戶進程所打開的文件類型為txt的文件:
sh-3.2# lsof -a -u root -d txt
COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME
launchd 1 root txt REG 1,4 317280 15338828 /sbin/launchd
launchd 1 root txt REG 1,4 638336 15339947 /usr/lib/dyld
launchd 1 root txt REG 1,4 488952294 23197852 /private/var/db/dyld/dyld_shared_cache_x86_64
syslogd 45 root txt REG 1,4 142736 15341124 /usr/sbin/syslogd
syslogd 45 root txt REG 1,4 638336 15339947 /usr/lib/dyld
syslogd 45 root txt REG 1,4 488952294 23197852 /private/var/db/dyld/dyld_shared_cache_x86_64
UserEvent 46 root txt REG 1,4 35456 15340516 /usr/libexec/UserEventAgent
......
**lsof的用處還有很多,在這里就不一一列舉,未完待續(xù)。。。。