Dos命令查看端口占用及關閉進程


 

1. 查看端口占用

在windows命令行窗口下執行:

netstat -aon|findstr "8080" 
TCP     127.0.0.1:80         0.0.0.0:0               LISTENING       2448

端口“8080”被PID(進程號)為2448的進程占用。

查看端口“8080”被哪個應用占用,,繼續執行下面命令:

tasklist|findstr "2448"
notepad.exe                     2016 Console                 0     16,064 K

2. 關閉進程

2.1 按進程號關閉進程

taskkill /pid 2152

多個時格式為:

taskkill /pid 2152 /pid 1284

2.2 按進程名關閉進程

如要關閉notepad.exe,格式為:

taskkill /im notepad.exe

指定多個時格式為:

taskkill /im notepad.exe /im iexplorer.exe

如果是要關閉所有的,則使用通配符*,即:

taskkill /im *.exe

2.3 有提示的關閉進程

taskkill /t /im notepad.exe
taskkill /t /pid 2152

這個效果是提示后在使用者確定后關閉,有提示框。

2.4 強行終止進程

taskkill /f /im notepad.exe
taskkill /f /pid 2152

3. 端口狀態

3.1 LISTENING狀態

FTP服務啟動后首先處於偵聽(LISTENING)狀態。

3.2 ESTABLISHED狀態

ESTABLISHED的意思是建立連接。表示兩台機器正在通信。

3.3 CLOSE_WAIT

對方主動關閉連接或者網絡異常導致連接中斷,這時我方的狀態會變成CLOSE_WAIT 此時我方要調用close()來使得連接正確關閉

3.4 TIME_WAIT

我方主動調用close()斷開連接,收到對方確認后狀態變為TIME_WAIT。TCP協議規定TIME_WAIT狀態會一直持續2MSL(即兩倍的分段最大生存期),以此來確保舊的連接狀態不會對新連接產生影響。處於TIME_WAIT狀態的連接占用的資源不會被內核釋放,所以作為服務器,在可能的情況下,盡量不要主動斷開連接,以減少TIME_WAIT狀態造成的資源浪費。

目前有一種避免TIME_WAIT資源浪費的方法,就是關閉socket的LINGER選項。但這種做法是TCP協議不推薦使用的,在某些情況下這個操作可能會帶來錯誤。

3.5 SYN_SENT狀態

SYN_SENT狀態表示請求連接,當你要訪問其它的計算機的服務時首先要發個同步信號給該端口,此時狀態為SYN_SENT,如果連接成功了就變為ESTABLISHED,此時SYN_SENT狀態非常短暫。但如果發現SYN_SENT非常多且在向不同的機器發出,那你的機器可能中了沖擊波或震盪波之類的病毒了。這類病毒為了感染別的計算機,它就要掃描別的計算機,在掃描的過程中對每個要掃描的計算機都要發出了同步請求,這也是出現許多SYN_SENT的原因。

 

 

 

 

來源:http://www.cnblogs.com/rainman/p/3457227.html


免責聲明!

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



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