Linux如何查看端口
1、lsof -i:端口號 用于查看某一端口的占用情況,比如查看8000端口使用情況,lsof -i:8000
# lsof -i:8000COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME lwfs 22065 root 6u IPv4 4395053 0t0 TCP *:irdmi (LISTEN)
可以看到8000端口已經(jīng)被輕量級文件系統(tǒng)轉(zhuǎn)發(fā)服務(wù)lwfs占用
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 8000tcp 0 0 0.0.0.0:8000 0.0.0.0:* LISTEN 22065/lwfs
說明一下幾個參數(shù)的含義:
-t (tcp) 僅顯示tcp相關(guān)選項 -u (udp)僅顯示udp相關(guān)選項 -n 拒絕顯示別名,能顯示數(shù)字的全部轉(zhuǎn)化為數(shù)字 -l 僅列出在Listen(監(jiān)聽)的服務(wù)狀態(tài) -p 顯示建立相關(guān)鏈接的程序名
附加一個python端口占用監(jiān)測的程序,該程序可以監(jiān)測指定IP的端口是否被占用。
#!/usr/bin/env python # -*- coding:utf-8 -*- import socket, time, thread socket.setdefaulttimeout(3) #設(shè)置默認超時時間 def socket_port(ip, port): """ 輸入IP和端口號,掃描判斷端口是否占用 """ try: if port >=65535: print u'端口掃描結(jié)束' s=socket.socket(socket.AF_INET, socket.SOCK_STREAM) result=s.connect_ex((ip, port)) if result==0: lock.acquire() print ip,u':',port,u'端口已占用' lock.release() except: print u'端口掃描異常' def ip_scan(ip): """ 輸入IP,掃描IP的0-65534端口情況 """ try: print u'開始掃描 %s' % ip start_time=time.time() for i in range(0,65534): thread.start_new_thread(socket_port,(ip, int(i))) print u'掃描端口完成,總共用時:%.2f' %(time.time()-start_time) # raw_input("Press Enter to Exit") except: print u'掃描ip出錯' if __name__=='__main__': url=raw_input('Input the ip you want to scan: ') lock=thread.allocate_lock() ip_scan(url)
該程序執(zhí)行結(jié)果如下:
# 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
windows系統(tǒng)如何查看端口被占用、殺進程
開始---->運行---->cmd,或者是window+R組合鍵,調(diào)出命令窗口
輸入命令:netstat -ano,列出所有端口的情況。在列表中我們觀察被占用的端口,比如是49157,首先找到它。
查看被占用端口對應(yīng)的PID,輸入命令:netstat -aon|findstr "49157",回車,記下最后一位數(shù)字,即PID,這里是2720。
繼續(xù)輸入tasklist|findstr "2720",回車,查看是哪個進程或者程序占用了2720端口,結(jié)果是:svchost.exe
或者是我們打開任務(wù)管理器,切換到進程選項卡,在PID一列查看2720對應(yīng)的進程是誰,如果看不到PID這一列,如下圖:
則我們點擊查看--->選擇列,將PID(進程標(biāo)示符)前面的勾打上,點擊確定。
這樣我們就看到了PID這一列標(biāo)識,看一下2720對應(yīng)的進程是誰,如果沒有,我們把下面的顯示所有用戶的進程前面的勾打上,就可以看到了,映像名稱是svchost.exe,描述是,Windows的主進程,與上面命令查看的完全一致。
結(jié)束該進程:在任務(wù)管理器中選中該進程點擊”結(jié)束進程“按鈕,或者是在cmd的命令窗口中輸入:taskkill /f /t /im Tencentdl.exe。
命令行總結(jié):
netstat -ano 列出所有端口的使用情況 netstat -ano | findstr "8080" 即具體查看被占用端口對應(yīng)的PID tasklist | findstr "5616" 查看是哪個進程或者程序占用了8080端口 taskill /f /t /im xx.exe 即結(jié)束該進程xx.exe
如對本文有疑問,請?zhí)峤坏浇涣髡搲瑥V大熱心網(wǎng)友會為你解答?。?點擊進入論壇