Tcp三次握手和四次揮手狀態圖

三次握手

這里寫圖片描述

四次揮手

  • 正常情況下
    這里寫圖片描述

  • 同時揮手
    這里寫圖片描述

SYN攻擊:

在三次握手過程中,Server發送SYN-ACK之后,收到Client的ACK之前的TCP連接稱為半連接(half-open connect),此時Server處于SYN_RCVD狀態,當收到ACK后,Server轉入ESTABLISHED狀態。SYN攻擊就是Client在短時間內偽造大量不存在的IP地址,并向Server不斷地發送SYN包,Server回復確認包,并等待Client的確認,由于源地址是不存在的,因此,Server需要不斷重發直至超時,這些偽造的SYN包將產時間占用未連接隊列,導致正常的SYN請求因為隊列滿而被丟棄,從而引起網絡堵塞甚至系統癱瘓。SYN攻擊時一種典型的DDOS攻擊,檢測SYN攻擊的方式非常簡單,即當Server上有大量半連接狀態且源IP地址是隨機的,則可以斷定遭到SYN攻擊了,使用如下命令可以讓之現行: #netstat -nap | grep SYN_RECV

TIME_WAIT狀態是什么?

下文轉載自 TIME_WAIT是什么?

在TCP斷開的過程中會有四個狀態變化過程,如下圖所示:
這里寫圖片描述
在連接撤銷過程中,有如下過程:

  • HOST1上的應用程序關閉己方的連接導致TCP發送一個FIN消息給HOST2。
  • HOST2發送一個確認消息給HOST1,并且HOST2把FIN作為EOF遞交給HOST2上的應用程序。
  • 一段時間過后,HOST2上的應用程序關閉它那邊的連接,引發一個FIN消息給HOST1。
  • HOST1給HOST2發送一個確認消息,然后HOST2關閉連接并釋放資源,然而,HOST1卻沒有關閉連接,而是進入了TIME_WAIT狀態,并為兩個最大段生存時間(2MSL)保留在此狀態.
為什么需要TIME_WAIT?
  • 因為在第四步的時候,HOST1發送的ACK可能丟失并導致HOST2重新發送FIN消息,TIME_WAIT維護連接狀態.
    如果執行主動關閉的一方HOST1 不進入到TIME_WAIT狀態就關閉連接那會發生什么呢?當重傳的FIN消息到達時,因為TCP已經不再有連接的信息了,所以就用RST(重新啟動)消息應答,導致HOST2進入錯誤的狀態而不是有序終止狀態,如果發送最后ACK消息的一方處于TIME_WAIT狀態并仍然記錄著連接的信息,它就可以正確的響應對等方HOST2的FIN消息了.

  • TIME_WAIT為連接中”離群的段”提供從網絡中消失的時間。
    考慮一下,如果延遲或者重傳段在連接關閉后到達時會發生什么呢?通常情況下,因為TCP僅僅丟棄該數據并響應RST消息,所以這不會造成任何問題。當RST消息到達發出延時段的主機時,因為該主機也沒有記錄連接的任何信息,所以它也丟棄該段。然而,如果兩個相同主機之間又建立了一個具有相同端口號的新連接,那么離群的段就可能被看成是新連接的,如果離群的段中數據的任何序列號恰恰在新連接的當前接收窗口中,數據就會被重新接收,其結果就是破壞新連接。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/450071.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/450071.shtml
英文地址,請注明出處:http://en.pswp.cn/news/450071.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

QEMU 3.0.0 新特性一覽

QEMU 在 2018年8月15發布了版本3.0.0, 正式從 2.12 進入了3.0 時代。 而且到今年位為止,QEMU 已經有15個年頭了,出乎意料的長阿,:) 其主要新特性如下: ARM: 在virt機器中支持SMMUv3 IOMMU 在v8M中支持VLLDM…

OpenCL、OpenGL 同時工作

視頻處理如果能使用OpenCL、OpenGL、omap將大量提高運算速度,簡單介紹OpenCL、OpenGL 同時工作。 OpenCL和OpenGL都能用于操作GPU,但是前者主要用于通用計算,而后者主要用于圖像渲染。在某些情況下,我們希望能用OpenCL計得到算圖像…

財務自由之路——為什么選擇淘寶(下)

接上文~一、淘寶之前的大佬們是怎么試錯的?我們看看在淘寶之前的大佬們是怎么試錯迭代產品的。都知道飛機是萊特兄弟發明的,但很少有人知道為什么是他們。在內燃機發明后的很長一段時間內全球各地發明家都在投入研究飛機,萊特兄弟相對于其他競爭者&…

java參數后面跟三個點是什么意思

前些天發現了一個巨牛的人工智能學習網站,通俗易懂,風趣幽默,忍不住分享一下給大家。點擊跳轉到教程。 AVA中類型后面跟三個點是什么來的。 看代碼中那個三點,這樣做起到重載的作用,但這是什么意思? cla…

一只視頻程序猿的移動直播SDK初體驗

本文轉自一只視頻程序猿的移動直播SDK初體驗,此處僅做排版改動。 今早老板召開站會,“移動直播這么火,市面上有一百多個APP,小斌,你下周交個原型APP瞅瞅!” 小弟心中一萬匹草泥馬奔過,這玩意兒哪兒是幾天就…

Xilinx zynq-7000系列FPGA移植Linux操作系統詳細教程

Xilinx zynq-7000系列FPGA移植Linux操作系統詳細教程 一:前言 最近手上壓了一塊米聯客的Miz7035,一塊xilinx zynq-7000系列的開發板,想著正好學習一下linux在ARM9上的移植,網上基本都是ZC702、zed的教程,這對于買了非標…

程序員的創業困境 誰來幫助出出主意?

【編者按】有人說,程序員是吃青春飯的,到一定年齡就得考慮轉行,也有人選擇自己創業。而當創業使你偏離了之前持續學習專業知識的軌道時,你會選擇在創業路上繼續堅持還是回歸自己的老本行?編程編了十幾年的Dan McComas半…

節選—Android 視頻直播 ( 從快播到直播,從高清到無碼 )十年視頻開發項目

本文轉載自Android 視頻直播 ( 從快播到直播,從高清到無碼 )十年視頻開發項目,截取其中技術概念比較相關的部分,并做了重新的排版。 視頻和直播的準備: android-java層:camera相關(視頻&#x…

getDeclaredMethod和getMethod的區別

前些天發現了一個巨牛的人工智能學習網站,通俗易懂,風趣幽默,忍不住分享一下給大家。點擊跳轉到教程。 getDeclaredMethod*()獲取的是類自身聲明的所有方法,包含public、protected和private方法。getMethod*()獲取的是類的所有共有…

12.5PMP試題每日一題

在什么情況下項目正式受控于實施整體變更控制過程:A、從項目啟動到收尾的所有過程B、只有當項目基準建立之后C、在項目基準建立之前D、只要有人提起變更請求的時候 作者:Tracy19890201(同微信號) 答案將于明天和新題一起揭曉&…

在線預覽word,excel文檔

Google Doc 示例:https://jsfiddle.net/7xr419yb/ Microsoft Office 示例:https://jsfiddle.net/gcuzq343/轉載于:https://www.cnblogs.com/alexguoyihao/p/10314626.html

如何遷移整個git倉庫

轉自準備更換git托管,如何遷移原git倉庫一個回答 如果你想從別的 Git 托管服務那里復制一份源代碼到新的 Git 托管服務器上的話,可以通過以下步驟來操作。 從原地址克隆一份裸版本庫,比如原本托管于 GitHub。 git clone –bare git://githu…

關于創業:希望有人在N年前就告訴我的一些事兒

【編者按】原文作者為前微軟員工、創業家Amir Khella,他離開微軟后開始自主創業,并成功創辦了多家公司。他經常在博客中分享自己的創業故事和經驗。以下是其中一篇博文,他認為創業者想要成功,首先需要找到自己的方向,再…

Rust核心團隊前成員Brian Anderson加入PingCAP

昨天,國內新型分布式數據庫公司PingCAP聯合創始人兼CEO劉奇在朋友圈宣布,Rust核心團隊前成員Brian Anderson將加入公司。PingCAP聯合創始人兼CTO黃東旭進一步向InfoQ記者證實了此消息,并透露Brian將從事TiKV相關的工作,從存儲引擎…

JeeSite 是什么、概述

見JeeSite官網:http://jeesite4.mydoc.io/ 前些天發現了一個巨牛的人工智能學習網站,通俗易懂,風趣幽默,忍不住分享一下給大家。點擊跳轉到教程。 總體概述 快速訪問 JeeSite 官網地址:http://jeesite.comJeeSite 在…

單機單網卡最大tcp長連接數真的是65535嗎?

很早微博上一直討論比較多的問題,這里轉載個知乎的答案:單機單網卡最大tcp長連接數真的是65535嗎? 作者:許懷遠 鏈接:https://www.zhihu.com/question/66553828/answer/244313925 來源:知乎 著作權歸作者…

觀察者模式-Observer Pattern

1.主要優點 觀察者模式的主要優點如下: (1) 觀察者模式可以實現表示層和數據邏輯層的分離,定義了穩定的消息更新傳遞機制,并抽象了更新接口,使得可以有各種各樣不同的表示層充當具體觀察者角色。 (2) 觀察者模式在觀察目標和觀察者…

賭還是不賭 你應該辭職去創業嗎?

【編者按】本文的作者是Amir Khella,他是一位著名的用戶體驗設計師,也是創業顧問和企業家。在過去的三年里,他成功的打造了十幾家公司,其中不少還被大企所收購,比如說Google收購了他的DocVerse,LimeLight N…

Python 深淺copy 和文件操作

深淺copy 1,先看賦值運算。 l1 [1,2,3,[barry,alex]] l2 l1l1[0] 111 print(l1) # [111, 2, 3, [barry, alex]] print(l2) # [111, 2, 3, [barry, alex]]l1[3][0] wusir print(l1) # [111, 2, 3, [wusir, alex]] print(l2) # [111, 2, 3, [wusir, alex]] 對…

這樣安靜下去...

前些天發現了一個巨牛的人工智能學習網站,通俗易懂,風趣幽默,忍不住分享一下給大家。點擊跳轉到教程。 我從來就不想要整個世界,我只想這樣安靜下去 ... 放肆我所有癡狂的心愿,無怨無悔 ... 縱我一執燃燒后成灰的稻草…