linux查看端口被占用情況,並根據PID kill掉相關進程。


原文:linux查看端口占用情況

  查看Linux端口占用,並kill掉相關進程   

一、Linux如何查看端口

1.1   lsof -i:端口號

  用於查看某一端口的占用情況,比如查看8000端口使用情況,lsof -i:8000

# lsof -i:8000 COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME lwfs 22065 root 6u IPv4 4395053 0t0 TCP *:irdmi (LISTEN)

可以看到8000端口已經被輕量級文件系統轉發服務lwfs占用

 

1.2  netstat -tunlp |grep 端口號

  用於查看指定的端口號的進程情況,如查看8000端口的情況,netstat -tunlp |grep 8000

復制代碼
# netstat -tunlp 
Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address               Foreign Address             State       PID/Program name tcp 0 0 0.0.0.0:111 0.0.0.0:* LISTEN 4814/rpcbind tcp 0 0 0.0.0.0:5908 0.0.0.0:* LISTEN 25492/qemu-kvm tcp 0 0 0.0.0.0:6996 0.0.0.0:* LISTEN 22065/lwfs tcp 0 0 192.168.122.1:53 0.0.0.0:* LISTEN 38296/dnsmasq tcp 0 0 0.0.0.0:22 0.0.0.0:* LISTEN 5278/sshd tcp 0 0 127.0.0.1:631 0.0.0.0:* LISTEN 5013/cupsd tcp 0 0 127.0.0.1:25 0.0.0.0:* LISTEN 5962/master tcp 0 0 0.0.0.0:8666 0.0.0.0:* LISTEN 44868/lwfs tcp 0 0 0.0.0.0:8000 0.0.0.0:* LISTEN 22065/lwfs 
復制代碼
# netstat -tunlp | grep 8000 tcp 0 0 0.0.0.0:8000 0.0.0.0:* LISTEN 22065/lwfs 

 

說明一下幾個參數的含義:

                                

復制代碼
 -t (tcp) 僅顯示tcp相關選項
                                 -u (udp)僅顯示udp相關選項
                                 -n 拒絕顯示別名,能顯示數字的全部轉化為數字
                                 -l 僅列出在Listen(監聽)的服務狀態
                                 -p 顯示建立相關鏈接的程序名  
復制代碼

 

二、 根據PID kill掉相關進程

kill -9 {PID}

 

如PID為 4814,則

kill -9 4814

 

 

補充1:根據程序名查看對應的PID

1、用ps命令(zb專用):

    ps -ef | grep {programName}
    kill -9 {PID}
     
    # 查看詳細內存占用
    ps aux -u root | grep {programName}

 



2、用pgrep命令:

pgrep命令的p表明了這個命令是專門用於進程查詢的grep。

    pgrep {programName}
    kill -9 {PID}

 

補充2:附加一個python端口占用監測的程序,該程序可以監測指定IP的端口是否被占用。

復制代碼
1 #!/usr/bin/env python 2 # -*- coding:utf-8 -*- 3 4 import socket, time, thread 5 socket.setdefaulttimeout(3) #設置默認超時時間 6 7 def socket_port(ip, port): 8 """ 9 輸入IP和端口號,掃描判斷端口是否占用 10 """ 11 try: 12 if port >=65535: 13 print u'端口掃描結束' 14 s=socket.socket(socket.AF_INET, socket.SOCK_STREAM) 15 result=s.connect_ex((ip, port)) 16 if result==0: 17 lock.acquire() 18 print ip,u':',port,u'端口已占用' 19 lock.release() 20 except: 21 print u'端口掃描異常' 22 23 def ip_scan(ip): 24 """ 25 輸入IP,掃描IP的0-65534端口情況 26 """ 27 try: 28 print u'開始掃描 %s' % ip 29 start_time=time.time() 30 for i in range(0,65534): 31 thread.start_new_thread(socket_port,(ip, int(i))) 32 print u'掃描端口完成,總共用時:%.2f' %(time.time()-start_time) 33 # raw_input("Press Enter to Exit") 34 except: 35 print u'掃描ip出錯' 36 37 if __name__=='__main__': 38 url=raw_input('Input the ip you want to scan: ') 39 lock=thread.allocate_lock() 40 ip_scan(url)
復制代碼

該程序執行結果如下:

復制代碼
# python scan_port.py Input the ip you want to scan: 20.0.208.112 開始掃描 20.0.208.112 20.0.208.112 : 111 端口已占用 20.0.208.112 : 22 端口已占用 20.0.208.112 : 8000 端口已占用 20.0.208.112 : 15996 端口已占用 20.0.208.112 : 41734 端口已占用 掃描端口完成,總共用時:9.38
復制代碼


免責聲明!

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



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