国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

TCP/IP協議的工作流程

GReq_mcu168 ? 來源:CSDN博客 ? 作者:溫柔狠角色 ? 2021-11-19 14:11 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

TCP/IP協議

TCP/IP不是一個協議,而是一個協議族的統稱。里面包括IP協議、IMCP協議、TCP協議。

這里有幾個需要注意的知識點:

互聯網地址:也就是IP地址,一般為網絡號+子網號+主機號

域名系統:通俗的來說,就是一個數據庫,可以將主機名轉換成IP地址

RFC:TCP/IP協議的標準文檔

端口號:一個邏輯號碼,IP包所帶有的標記

Socket:應用編程接口

數據鏈路層的工作特性:

為IP模塊發送和接收IP數據報

為ARP模塊發送ARP請求和接收ARP應答(ARP:地址解析協議,將IP地址轉換成MAC地址)

為RARP發送RARP請求和接收RARP應答

接下來我們了解一下TCP/IP的工作流程:

數據鏈路層從ARP得到數據的傳遞信息,再從IP得到具體的數據信息

IP協議

IP協議頭當中,最重要的就是TTL(IP允許通過的最大網段數量)字段(八位),規定該數據包能穿過幾個路由之后才會被拋棄。

ARP協議工作原理

a6dcd3ae-41f7-11ec-b939-dac502259ad0.jpg

ICMP協議(網絡控制文協議)

將IP數據包不能傳送的錯誤信息傳送給主機

查詢報文

ping查詢:主機是否可達,通過計算間隔時間和傳送多少個包的數量

子網掩碼

時間戳:獲得當前時間

差錯報文

不產生的情況:

ICMP差錯報文不產生差錯報文

源地址為零地址、環目地址、廣播地址、多播地址

IP路由器選擇協議

靜態路由選擇

a75243b4-41f7-11ec-b939-dac502259ad0.jpg

靜態路由選擇

配置接口以默認方式生成路由表項,或者使用route add手動添加表項

ICMP報文(ICMP重定向報文)更新表項

動態路由選擇(只使用在路由之間)

RIP(路由信息協議)

分布式的基于距離向量(路由器到每一個目的網絡的距離記錄)的路由選擇協議

router承擔的工作:

給每一個已知路由器發送RIP請求報文,要求給出完整的路由表

如果接受請求,就將自己的路由表交給請求者;如果沒有,就處理IP請求表項(自己部分+跳數/沒有的部分+16)

接受回應,更新路由表

定期更新路由表(一般為30s,只能說太頻繁~)

OSPF(開放最短路徑優先協議)

分布式鏈路狀態(和這兩個路由器都有接口的網絡)協議

當鏈路狀態發生變化時,采用可靠的洪泛法,向所有的路由器發送信息(相鄰的所有路由器的鏈路狀態)

最終會建立一個全網的拓撲結構圖

TCP/IP的三次握手,四次分手

首先我們先來了解TCP報文段

重要的標志我在圖中也有標記,重點了解標志位

ACK:確認序號有效

RST:重置連接

SYN:發起了一個新連接

FIN:釋放一個連接

三次握手的過程(客戶端我們用A表示,服務器端用B表示)

前提:A主動打開,B被動打開

在建立連接之前,B先創建TCB(傳輸控制塊),準備接受客戶進程的連接請求,處于LISTEN(監聽)狀態

A首先創建TCB,然后向B發出連接請求,SYN置1,同時選擇初始序號seq=x,進入SYN-SEND(同步已發送)狀態

B收到連接請求后向A發送確認,SYN置1,ACK置1,同時產生一個確認序號ack=x+1。同時隨機選擇初始序號seq=y,進入SYN-RCVD(同步收到)狀態

A收到確認連接請求后,ACK置1,確認號ack=y+1,seq=x+1,進入到ESTABLISHED(已建立連接)狀態。向B發出確認連接,最后B也進入到ESTABLISHED(已建立連接)狀態。

簡單來說,就是

建立連接時,客戶端發送SYN包(SYN=i)到服務器,并進入到SYN-SEND狀態,等待服務器確認

服務器收到SYN包,必須確認客戶的SYN(ack=i+1),同時自己也發送一個SYN包(SYN=k),即SYN+ACK包,此時服務器進入SYN-RECV狀態

客戶端收到服務器的SYN+ACK包,向服務器發送確認報ACK(ack=k+1),此包發送完畢,客戶端和服務器進入ESTABLISHED狀態,完成三次握手

在此穿插一個知識點就是SYN攻擊,那么什么是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

四次分手的過程(客戶端我們用A表示,服務器端用B表示)

由于TCP連接時是全雙工的,因此每個方向都必須單獨進行關閉。這一原則是當一方完成數據發送任務后,發送一個FIN來終止這一方向的鏈接。收到一個FIN只是意味著這一方向上沒有數據流動,既不會在收到數據,但是在這個TCP連接上仍然能夠發送數據,知道這一方向也發送了FIN,首先進行關閉的一方將執行主動關閉,而另一方則執行被動關閉。

前提:A主動關閉,B被動關閉

有人可能會問,為什么連接的時候是三次握手,而斷開連接的時候需要四次揮手?

這是因為服務端在LISTEN狀態下,收到建立連接請求的SYN報文后,把ACK和SYN放在一個報文里發送給客戶端。而關閉連接時,當收到對方的FIN 報文時,僅僅表示對方不再發送數據了但是還能接收數據,己方也未必全部數據都發送給對方了,所以己方可以立即close,也可以發送一些數據給對方后,再 發送FIN報文給對方來表示同意現在關閉連接,因此,己方ACK和FIN一般都會分開發送。

A發送一個FIN,用來關閉A到B的數據傳送,A進入FIN_WAIT_1狀態。

B收到FIN后,發送一個ACK給A,確認序號為收到序號+1(與SYN相同,一個FIN占用一個序號),B進入CLOSE_WAIT狀態。

B發送一個FIN,用來關閉B到A的數據傳送,B進入LAST_ACK狀態。

A收到FIN后,A進入TIME_WAIT狀態,接著發送一個ACK給B,確認序號為收到序號+1,B進入CLOSED狀態,完成四次揮手。

簡單來說就是

客戶端A發送一個FIN,用來關閉客戶A到服務器B的數據傳送(報文段4)。

服務器B收到這個FIN,它發回一個ACK,確認序號為收到的序號加1(報文段5)。和SYN一樣,一個FIN將占用一個序號。

服務器B關閉與客戶端A的連接,發送一個FIN給客戶端A(報文段6)。

客戶端A發回ACK報文確認,并將確認序號設置為收到序號加1(報文段7)。

A在進入到TIME-WAIT狀態后,并不會馬上釋放TCP,必須經過時間等待計時器設置的時間2MSL(最長報文段壽命),A才進入到CLOSED狀態。為什么?

為了保證A發送的最后一個ACK報文段能夠到達B

防止“已失效的連接請求報文段”出現在本連接中

OK~是不是很難懂的感覺?那我們來說的“人性化點的”吧

三次握手流程

客戶端發個請求“開門吶,我要進來”給服務器

服務器發個“進來吧,我去給你開門”給客戶端

客戶端有很客氣的發個“謝謝,我要進來了”給服務器

四次揮手流程

客戶端發個“時間不早了,我要走了”給服務器,等服務器起身送他

服務器聽到了,發個“我知道了,那我送你出門吧”給客戶端,等客戶端走

服務器把門關上后,發個“我關門了”給客戶端,然后等客戶端走(尼瑪~矯情啊)

客戶端發個“我知道了,我走了”,之后自己就走了

OK,先到這吧

原文鏈接:http://blog.csdn.net/qq_25827845/article/details/66975129

責任編輯:haq

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 協議
    +關注

    關注

    2

    文章

    618

    瀏覽量

    41080
  • IP
    IP
    +關注

    關注

    5

    文章

    1862

    瀏覽量

    155828
  • TCP
    TCP
    +關注

    關注

    8

    文章

    1424

    瀏覽量

    83500

原文標題:詳解TCP/IP協議總結(怒噴一口老血)

文章出處:【微信號:mcu168,微信公眾號:硬件攻城獅】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    是德科技與三星攜手英偉達展示端到端AI-RAN驗證工作流程

    是德科技(NYSE: KEYS )與三星電子宣布,會在巴塞羅那舉行的2026年世界移動通信大會(MWC 2026)上,與英偉達聯合演示端到端人工智能無線接入網絡(AI-RAN)測試與驗證工作流程。該
    的頭像 發表于 03-05 10:04 ?335次閱讀

    TCP/IP(Socket)協議深度剖析

    TCP/IP協議作為互聯網通信的基礎架構,其核心機制Socket編程承載著全球數據交換的使命。本文將深入剖析這一協議的七層架構、三次握手與四次揮手的精妙設計、流量控制與擁塞控制的動態平
    的頭像 發表于 03-03 17:06 ?460次閱讀

    工業級4G路由器:TCP/IP與UDP協議,解鎖工業物聯網高效傳輸新范式

    /以太網能力,正重新定義工業數據傳輸的邊界。其核心優勢,在于對TCP/IP與UDP協議的深度適配,為不同場景提供精準的通信解決方案。 ?? ?TCP/
    的頭像 發表于 01-19 18:25 ?185次閱讀
    工業級4G路由器:<b class='flag-5'>TCP</b>/<b class='flag-5'>IP</b>與UDP<b class='flag-5'>協議</b>,解鎖工業物聯網高效傳輸新范式

    為什么會有TCP/IP協議

    見了面,完全不能交流信息。因而他們需要定義一些共通的東西來進行交流,TCP/IP就是為此而生。TCP/IP不是一個協議,而是一個
    發表于 12-03 06:28

    Profinet轉TCP/IP工業智能網關破解S7-1200與TCP/IP攝像頭視覺通訊壁壘的方案

    某汽車零部件工廠的自動化裝配車間需實現產線全流程視覺監控與質量追溯。車間以西門子S7-1200 PLC作為核心控制器(支持Profinet協議),負責產線節拍控制、設備聯動及異常響應;同時部署TCP
    的頭像 發表于 11-02 13:52 ?1729次閱讀
    Profinet轉<b class='flag-5'>TCP</b>/<b class='flag-5'>IP</b>工業智能網關破解S7-1200與<b class='flag-5'>TCP</b>/<b class='flag-5'>IP</b>攝像頭視覺通訊壁壘的方案

    ADI Power Studio工作流程與工具概述

    、直觀的工作流程,利用準確的模型來仿真實際性能,并自動生成關鍵的物料清單和報告等內容,幫助工程團隊更早做出更優決策。
    的頭像 發表于 10-22 09:38 ?1058次閱讀

    恩智浦i.MX RT1180跨界MCU驅動EtherCAT的工作流程

    上周的分享已經介紹了整個參考設計的概況和相關硬件資源。那么,本次會從軟件工程角度進行分享。首先來了解EtherCAT Slave工作流程
    的頭像 發表于 09-28 14:20 ?1202次閱讀
    恩智浦i.MX RT1180跨界MCU驅動EtherCAT的<b class='flag-5'>工作流程</b>

    電芯自動面墊分選裝盒生產線的工作流程解析

    電芯自動面墊分選裝盒生產線的工作流程解析|深圳比斯特自動化
    的頭像 發表于 09-28 10:29 ?480次閱讀

    EtherNet/IP轉Modbus TCP網關,讓設備對話更簡單!

    在工業自動化與物聯網飛速發展的今天,不同協議設備之間的互聯互通已成為企業提升生產效率、實現智能化升級的關鍵挑戰。如何讓支持EtherNet/IP的PLC、伺服系統與基于Modbus TCP
    的頭像 發表于 09-19 16:30 ?706次閱讀
    EtherNet/<b class='flag-5'>IP</b>轉Modbus <b class='flag-5'>TCP</b>網關,讓設備對話更簡單!

    GraniStudio : TCP/IP(Socket)協議深度剖析

    在工業自動化與物聯網領域,TCP/IP(Socket)協議作為應用最廣泛的網絡通信標準,是實現設備間數據交互的核心技術。GraniStudio 軟件作為工業級零代碼開發平臺,其內置的 TCP
    的頭像 發表于 08-03 22:20 ?1187次閱讀
    GraniStudio : <b class='flag-5'>TCP</b>/<b class='flag-5'>IP</b>(Socket)<b class='flag-5'>協議</b>深度剖析

    什么是Modbus TCP協議

    Modbus TCP是一種基于TCP/IP協議的Modbus通信協議,用于在客戶機和服務器之間進行數據通信。它常用于工業自動化控制、電力監控
    的頭像 發表于 07-23 17:18 ?4268次閱讀
    什么是Modbus <b class='flag-5'>TCP</b><b class='flag-5'>協議</b>

    生物制藥自動化升級:Modbus TCP與Ethernet/IP協議轉換實踐

    為優化生物制藥生產流程,我司計劃將現有的Allen-Bradley PLC控制系統與新型生物反應器進行集成。由于兩者采用不同的通信協議(AB PLC使用Modbus TCP,而生物反應器支持
    的頭像 發表于 06-17 18:34 ?614次閱讀
    生物制藥自動化升級:Modbus <b class='flag-5'>TCP</b>與Ethernet/<b class='flag-5'>IP</b><b class='flag-5'>協議</b>轉換實踐

    老牌協議再升級,Ethernet IP轉Modbus TCP網關橋接精準灌裝系統

    在本次網絡研討會中,我們將探討穩聯技術的ethernet ip轉modbus tcp(WL-ABC2004)如何幫助制造商實現精準的產品灌裝并達成其生產自動化目標。為您揭秘Ethernet/IP
    的頭像 發表于 05-28 16:49 ?446次閱讀
    老牌<b class='flag-5'>協議</b>再升級,Ethernet <b class='flag-5'>IP</b>轉Modbus <b class='flag-5'>TCP</b>網關橋接精準灌裝系統

    51+單片機TCP-IP+協議棧ZLIP源碼

    概述 單片機上網技術,是當前的一個熱門技術。單片機上網技術中的一個重要部分是在單片上實現 TCP/IP 協議棧。現在可獲得的 TCP/IP
    發表于 04-22 15:11

    EtherNet/IP轉Modbus借助網關模塊達成羅克韋爾PLC和變頻器協議轉換通信

    的空壓機采用 MODBUS TCP 協議進行數據傳輸,但企業的自動化控制系統主要基于 Ethernet IP 協議構建。為了實現空壓機與現有控制系統的無縫連接,我們選用了捷米特 JM-
    的頭像 發表于 03-10 11:02 ?804次閱讀
    EtherNet/<b class='flag-5'>IP</b>轉Modbus借助網關模塊達成羅克韋爾PLC和變頻器<b class='flag-5'>協議</b>轉換通信