如需要確定誰占用了9050端口 為例:
1、Windows平台
在windows命令行窗口下執行:
1.查看所有的端口占用情況
C:\>netstat -ano 協議 本地地址 外部地址 狀態 PID TCP 127.0.0.1:1434 0.0.0.0:0 LISTENING 3236 TCP 127.0.0.1:5679 0.0.0.0:0 LISTENING 4168 TCP 127.0.0.1:7438 0.0.0.0:0 LISTENING 4168 TCP 127.0.0.1:8015 0.0.0.0:0 LISTENING 1456 TCP 192.168.3.230:139 0.0.0.0:0 LISTENING 4 TCP 192.168.3.230:1957 220.181.31.225:443 ESTABLISHED 3068 TCP 192.168.3.230:2020 183.62.96.189:1522 ESTABLISHED 1456 TCP 192.168.3.230:2927 117.79.91.18:80 ESTABLISHED 4732 TCP 192.168.3.230:2929 117.79.91.18:80 ESTABLISHED 4732 TCP 192.168.3.230:2930 117.79.91.18:80 ESTABLISHED 4732 TCP 192.168.3.230:2931 117.79.91.18:80 ESTABLISHED 4732
2.查看指定端口的占用情況
 C:\>netstat -aon|findstr "9050"
  協議    本地地址                     外部地址               狀態                   PID
  TCP    127.0.0.1:9050         0.0.0.0:0              LISTENING       2016 
        
P: 看到了嗎,端口被進程號為2016的進程占用,繼續執行下面命令: (也可以去任務管理器中查看pid對應的進程)
3.查看PID對應的進程
 C:\>tasklist|findstr "2016"
  映像名稱                       PID 會話名              會話#       內存使用
  tor.exe                     2016 Console                 0     16,064 K 
        P:很清楚吧,tor占用了端口。
4.結束該進程
C:\>taskkill /f /t /im tor.exe
Linux 查看端口占用情況
Linux 查看端口占用情況可以使用 lsof 和 netstat 命令。
lsof
lsof(list open files)是一個列出當前系統打開文件的工具。
lsof 查看端口占用語法格式:
lsof -i:端口號 
          實例
查看服務器 8000 端口的占用情況:
# lsof -i:8000 COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME nodejs 26993 root 10u IPv4 37999514 0t0 TCP *:8000 (LISTEN) 
          可以看到 8000 端口已經被輕 nodejs 服務占用。
lsof -i 需要 root 用戶的權限來執行,如下圖:

更多 lsof 的命令如下:
lsof -i:8080:查看8080端口占用 lsof abc.txt:顯示開啟文件abc.txt的進程 lsof -c abc:顯示abc進程現在打開的文件 lsof -c -p 1234:列出進程號為1234的進程所打開的文件 lsof -g gid:顯示歸屬gid的進程情況 lsof +d /usr/local/:顯示目錄下被進程開啟的文件 lsof +D /usr/local/:同上,但是會搜索目錄下的目錄,時間較長 lsof -d 4:顯示使用fd為4的進程 lsof -i -U:顯示所有打開的端口和UNIX domain文件 
          netstat
netstat -tunlp 用於顯示 tcp,udp 的端口和進程等相關情況。
netstat 查看端口占用語法格式:
netstat -tunlp | grep 端口號 
          - -t (tcp) 僅顯示tcp相關選項
 - -u (udp)僅顯示udp相關選項
 - -n 拒絕顯示別名,能顯示數字的全部轉化為數字
 - -l 僅列出在Listen(監聽)的服務狀態
 - -p 顯示建立相關鏈接的程序名
 
# netstat -tunlp | grep 8000 tcp 0 0 0.0.0.0:8000 0.0.0.0:* LISTEN 26993/nodejs  
          更多命令:
netstat -ntlp //查看當前所有tcp端口 netstat -ntulp | grep 80 //查看所有80端口使用情況 netstat -ntulp | grep 3306 //查看所有3306端口使用情況 
          kill
在查到端口占用的進程后,如果你要殺掉對應的進程可以使用 kill 命令:
kill -9 PID 
          如上實例,我們看到 8000 端口對應的 PID 為 26993,使用以下命令殺死進程:
kill -9 26993
參考:Linux 查看端口占用情況
參考:如何在Windows下查看JAVA端口占用明細
