tcp四次揮手

2022-03-20 01:29:33 字數 1247 閱讀 2103

tcp是全雙工通道,通訊雙方都可以獨立關閉自己的通訊通道,也就是半關閉。

client先傳送fin告知對方我已經完成資料傳送了,server回覆ack來確定我知道了。這樣乙個流程,就關閉了client的傳送資訊通道。但是還可以接收來自server方的資料。

server此時已經知道接收不到client的資料了,但是還可以給它傳送資料。如果server也沒有啥資料要傳送給對方了,server也會以fin標誌位傳送乙個資訊給client,client接到後,也會傳遞乙個ack表示知道了。這樣子,雙方都完成了關閉。

客戶端資料傳送完成,則它向服務端傳送連線釋放請求。該請求只有報文頭,頭中攜帶的主要引數為:fin=1,seq=u。此時,客戶端將進入fin-wait-1狀態。tcp規定,fin報文段即使不攜帶資料,也要消耗乙個序號。

伺服器收到客戶端連線釋放報文,通知相應的高層應用程序,告訴它客戶端向伺服器這個方向的連線已經釋放了。此時服務端進入了close-wait(關閉等待)狀態,並向客戶端發出連線釋放的應答,其報文頭包含:ack=1,ack=u+1,seq=v。客戶端收到該應答後,進入fin-wait-2狀態,等待伺服器傳送連線釋放報文(在這之前還需要接受伺服器傳送的最後的資料)。第二次揮手完成後,客戶端到服務端方向的連線已經釋放,服務端不會再接收客戶端的資料,客戶端也沒有資料要傳送了。但服務端到客戶端方向的連線仍然存在,伺服器若傳送資料,客戶端依然要接受。這個狀態還要持續一段時間,也就是整個close-wait狀態持續的時間。

服務端將最後的資料傳送完畢後,就向客戶端傳送連線釋放報文,其報文頭包含:fin=1,ack=u+1,由於在clos-wait狀態,服務端很可能又傳送了一些資料,假定此時的序列號為seq=w,此時,伺服器就進入了last-ack(最後確認)狀態,等待客戶端的確認。

客戶端收到伺服器的連線釋放報文後,向服務端發出確認應答,報文頭:ack=1,ack=w+1,seq=u+1,此時,客戶端就進入了time-wait(時間等待)狀態。該狀態會持續2msl(最長報文段壽命)時間,這個期間tcp連線還未釋放,若該時間段內沒有服務端的重發請求的話,客戶端就進入closed狀態,服務端只要收到了客戶端發出的確認,立即進入closed狀態。就結束了這次的tcp連線。可以看到,伺服器結束tcp連線的時間要比客戶端早一些。

client已經關閉了socket連線,而我方忙於讀或寫,沒有及時的去關閉連線。

檢查**,特別是釋放資源的**。

檢查配置,特別是處理請求的執行緒配置。

tcp 四次揮手 TCP四次揮手

tcp斷開連線的過程 客戶端傳送fin報文,表明客戶端將不在傳送資料。具體過程 把fin標誌位改為1,序號seq u,之前傳送的資料加1,這裡規定即使不攜帶資料序號也要 1。該過程中客戶端通過close系統呼叫從established狀態進入fin wait 1狀態。第二次揮手 服務端收到客戶端發來...

TCP四次揮手

純給自己看的 發起關閉的一方是客戶端,被動關閉的一方是伺服器。1 客戶端a傳送乙個fin 1,用來關閉客戶a到伺服器b的資料傳送。圖上畫的對,還有乙個seq n 2 伺服器b收到這個fin,它發回乙個ack 1,確認序號ack為收到的序號加1。3 伺服器b關閉與客戶端a的連線,傳送乙個fin 1給客...

TCP四次揮手

四次揮手 1.客戶端程序發出連線釋放報文,並且停止傳送資料。釋放資料報文首部,fin 1,其序列號為seq u 等於前面已經傳送過來的資料的最後乙個位元組的序號加1 此時,客戶端進入fin wait 1 終止等待1 狀態。tcp規定,fin報文段即使不攜帶資料,也要消耗乙個序號。2.伺服器收到連線釋...