99精品伊人亚洲|最近国产中文炮友|九草在线视频支援|AV网站大全最新|美女黄片免费观看|国产精品资源视频|精彩无码视频一区|91大神在线后入|伊人终合在线播放|久草综合久久中文

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

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

3天內(nèi)不再提示

詳解TCP/IP協(xié)議總結(jié)

傳感器技術(shù) ? 來源:面包板社區(qū) ? 作者:面包板社區(qū) ? 2020-10-18 11:02 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

TCP/IP協(xié)議

TCP/IP不是一個協(xié)議,而是一個協(xié)議族的統(tǒng)稱。里面包括IP協(xié)議、IMCP協(xié)議、TCP協(xié)議。

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

互聯(lián)網(wǎng)地址:也就是IP地址,一般為網(wǎng)絡(luò)號+子網(wǎng)號+主機號

域名系統(tǒng):通俗的來說,就是一個數(shù)據(jù)庫,可以將主機名轉(zhuǎn)換成IP地址

RFC:TCP/IP協(xié)議的標準文檔

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

Socket:應(yīng)用編程接口

數(shù)據(jù)鏈路層的工作特性:

為IP模塊發(fā)送和接收IP數(shù)據(jù)報

為ARP模塊發(fā)送ARP請求和接收ARP應(yīng)答(ARP:地址解析協(xié)議,將IP地址轉(zhuǎn)換成MAC地址)

為RARP發(fā)送RARP請求和接收RARP應(yīng)答

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

數(shù)據(jù)鏈路層從ARP得到數(shù)據(jù)的傳遞信息,再從IP得到具體的數(shù)據(jù)信息

IP協(xié)議

更多C/C++學(xué)習(xí)資料,請私信我“代碼”,即可獲取

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

IP路由選擇

更多C/C++學(xué)習(xí)資料,請私信我“代碼”,即可獲取

ARP協(xié)議工作原理

更多C/C++學(xué)習(xí)資料,請私信我“代碼”,即可獲取

ICMP協(xié)議(網(wǎng)絡(luò)控制文協(xié)議)

將IP數(shù)據(jù)包不能傳送的錯誤信息傳送給主機

查詢報文

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

子網(wǎng)掩碼

時間戳:獲得當前時間

差錯報文

不產(chǎn)生的情況:

ICMP差錯報文不產(chǎn)生差錯報文

源地址為零地址、環(huán)目地址、廣播地址、多播地址

IP路由器選擇協(xié)議

靜態(tài)路由選擇

更多C/C++學(xué)習(xí)資料,請私信我“代碼”,即可獲取

靜態(tài)路由選擇

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

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

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

RIP(路由信息協(xié)議)

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

router承擔的工作:

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

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

接受回應(yīng),更新路由表

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

OSPF(開放最短路徑優(yōu)先協(xié)議)

分布式鏈路狀態(tài)(和這兩個路由器都有接口的網(wǎng)絡(luò))協(xié)議

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

最終會建立一個全網(wǎng)的拓撲結(jié)構(gòu)圖

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

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

更多C/C++學(xué)習(xí)資料,請私信我“代碼”,即可獲取

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

ACK:確認序號有效

RST:重置連接

SYN:發(fā)起了一個新連接

FIN:釋放一個連接

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

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

更多C/C++學(xué)習(xí)資料,請私信我“代碼”,即可獲取

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

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

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

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

簡單來說,就是

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

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

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

在此穿插一個知識點就是SYN攻擊,那么什么是SYN攻擊?發(fā)生的條件是什么?怎么避免?

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

#netstat -nap | grep SYN_RECV

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

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

前提:A主動關(guān)閉,B被動關(guān)閉

更多C/C++學(xué)習(xí)資料,請私信我“代碼”,即可獲取

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

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

A發(fā)送一個FIN,用來關(guān)閉A到B的數(shù)據(jù)傳送,A進入FIN_WAIT_1狀態(tài)。

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

B發(fā)送一個FIN,用來關(guān)閉B到A的數(shù)據(jù)傳送,B進入LAST_ACK狀態(tài)。

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

簡單來說就是

客戶端A發(fā)送一個FIN,用來關(guān)閉客戶A到服務(wù)器B的數(shù)據(jù)傳送(報文段4)。

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

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

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

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

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

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

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

三次握手流程

客戶端發(fā)個請求“開門吶,我要進來”給服務(wù)器

服務(wù)器發(fā)個“進來吧,我去給你開門”給客戶端

客戶端有很客氣的發(fā)個“謝謝,我要進來了”給服務(wù)器

四次揮手流程

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

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

服務(wù)器把門關(guān)上后,發(fā)個“我關(guān)門了”給客戶端,然后等客戶端走(尼瑪~矯情?。?/p>

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

OK,先到這吧

責任編輯:lq

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 模塊
    +關(guān)注

    關(guān)注

    7

    文章

    2788

    瀏覽量

    50423
  • IP
    IP
    +關(guān)注

    關(guān)注

    5

    文章

    1805

    瀏覽量

    152613
  • TCP
    TCP
    +關(guān)注

    關(guān)注

    8

    文章

    1402

    瀏覽量

    81069

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

文章出處:【微信號:WW_CGQJS,微信公眾號:傳感器技術(shù)】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

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

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    51+單片機TCP-IP+協(xié)議棧ZLIP源碼

    概述 單片機上網(wǎng)技術(shù),是當前的一個熱門技術(shù)。單片機上網(wǎng)技術(shù)中的一個重要部分是在單片上實現(xiàn) TCP/IP 協(xié)議?!,F(xiàn)在可獲得的 TCP/IP
    發(fā)表于 04-22 15:11

    EtherNet/IP轉(zhuǎn)Modbus TCP:新能源風電監(jiān)控與分析實用案例

    的控制系統(tǒng)、變流器等采用 MODBUS TCP 協(xié)議的設(shè)備以及基于 EtherNet/IP 協(xié)議的遠程監(jiān)控系統(tǒng)和數(shù)據(jù)分析系統(tǒng)均已正常運行且網(wǎng)絡(luò)連接正常。 二、硬件設(shè)備 風力發(fā)電機組變流
    的頭像 發(fā)表于 02-17 15:54 ?400次閱讀
    EtherNet/<b class='flag-5'>IP</b>轉(zhuǎn)Modbus <b class='flag-5'>TCP</b>:新能源風電監(jiān)控與分析實用案例

    什么是socket編程 socket與tcp/ip協(xié)議的關(guān)系

    基于TCP/IP協(xié)議族,這是一組用于網(wǎng)絡(luò)通信的協(xié)議,包括傳輸控制協(xié)議TCP)和互聯(lián)網(wǎng)
    的頭像 發(fā)表于 11-01 16:01 ?1210次閱讀

    Modbus RTU協(xié)議與Modbus TCP/IP協(xié)議的區(qū)別

    Modbus RTU和Modbus TCP/IP的本質(zhì)都是Modbus協(xié)議,都是通過Modbus寄存器地址來交換數(shù)據(jù)的,那么它們之間有什么區(qū)別呢?今天我們從以下幾個方面來探討一下。
    的頭像 發(fā)表于 10-18 17:44 ?1964次閱讀

    TCP協(xié)議是什么

    在網(wǎng)絡(luò)通信的廣闊領(lǐng)域中,TCP(Transmission Control Protocol,傳輸控制協(xié)議)扮演著舉足輕重的角色。作為TCP/IP協(xié)議
    的頭像 發(fā)表于 10-09 13:54 ?1809次閱讀

    EtherNet/IP主站轉(zhuǎn)Modbus-TCP協(xié)議網(wǎng)關(guān)

    捷米特JM-EIPM-TCP網(wǎng)關(guān)實現(xiàn)連接EtherNet/IP設(shè)備和網(wǎng)絡(luò)到Modbus TCP網(wǎng)絡(luò)系統(tǒng)。該網(wǎng)關(guān)可實現(xiàn)雙向數(shù)據(jù)交換,既允許現(xiàn)有的、低成本的EtherNet/IP設(shè)備集成到
    的頭像 發(fā)表于 09-25 11:49 ?514次閱讀
    EtherNet/<b class='flag-5'>IP</b>主站轉(zhuǎn)Modbus-<b class='flag-5'>TCP</b><b class='flag-5'>協(xié)議</b>網(wǎng)關(guān)

    EtherNet/IP轉(zhuǎn)Modbus-TCP協(xié)議轉(zhuǎn)換網(wǎng)關(guān)

    在工業(yè)自動化領(lǐng)域中,EtherNet/IP轉(zhuǎn)Modbus-TCP這兩種網(wǎng)絡(luò)協(xié)議的互通互聯(lián)非常重要。有一款優(yōu)秀的設(shè)備——遠創(chuàng)智控YC-EIP-TCP,能夠出色地解決這一難題。此設(shè)備性能優(yōu)
    的頭像 發(fā)表于 09-06 16:54 ?565次閱讀
    EtherNet/<b class='flag-5'>IP</b>轉(zhuǎn)Modbus-<b class='flag-5'>TCP</b><b class='flag-5'>協(xié)議</b>轉(zhuǎn)換網(wǎng)關(guān)

    深入了解 Windows 系統(tǒng) TCP/IP 參數(shù)配置

    ?Windows系統(tǒng)作為廣泛使用的操作系統(tǒng),正確地配置TCP/IP參數(shù)可以優(yōu)化網(wǎng)絡(luò)通信、提高數(shù)據(jù)傳輸效率、增強系統(tǒng)安全性,而錯誤的配置則可能導(dǎo)致網(wǎng)絡(luò)故障、性能下降甚至安全漏洞。 ? TCP/I
    的頭像 發(fā)表于 09-04 17:24 ?827次閱讀

    EtherNet/IP轉(zhuǎn)Modbus-TCP協(xié)議網(wǎng)關(guān)(EtherNet/IP轉(zhuǎn)Modbus-TCP

    /IP轉(zhuǎn)Modbus TCP從站協(xié)議網(wǎng)關(guān),可以實現(xiàn)對這些設(shè)備的集中管理和控制。 二,典型應(yīng)用拓撲圖 三,設(shè)備技術(shù)參數(shù) 捷米特JM-EIP-TCP設(shè)備在Et
    的頭像 發(fā)表于 09-04 11:09 ?869次閱讀
    EtherNet/<b class='flag-5'>IP</b>轉(zhuǎn)Modbus-<b class='flag-5'>TCP</b><b class='flag-5'>協(xié)議</b>網(wǎng)關(guān)(EtherNet/<b class='flag-5'>IP</b>轉(zhuǎn)Modbus-<b class='flag-5'>TCP</b>)

    EtherNet/IP轉(zhuǎn)Modbus-TCP協(xié)議網(wǎng)關(guān)(JM-EIP-TCP

    一,設(shè)備主要功能 捷米特JM-EIP-TCP型網(wǎng)關(guān)實現(xiàn)EtherNet/IP網(wǎng)絡(luò)與Modbus TCP網(wǎng)絡(luò)之間的數(shù)據(jù)通訊,可支持Modbus TCP主站Modbus
    的頭像 發(fā)表于 08-26 14:39 ?607次閱讀
    EtherNet/<b class='flag-5'>IP</b>轉(zhuǎn)Modbus-<b class='flag-5'>TCP</b><b class='flag-5'>協(xié)議</b>網(wǎng)關(guān)(JM-EIP-<b class='flag-5'>TCP</b>)

    串口服務(wù)器和TCP/IP協(xié)議棧是什么關(guān)系

    串口服務(wù)器與TCP/IP協(xié)議棧之間存在著緊密而復(fù)雜的關(guān)系。這種關(guān)系主要體現(xiàn)在串口服務(wù)器如何利用TCP/IP
    的頭像 發(fā)表于 08-25 17:35 ?2132次閱讀

    一文了解TCP/IP協(xié)議

    TCP/IP協(xié)議是現(xiàn)代計算機網(wǎng)絡(luò)通信的基礎(chǔ),是互聯(lián)網(wǎng)及局域網(wǎng)廣泛使用的一套協(xié)議TCP/IP
    的頭像 發(fā)表于 08-07 15:38 ?3547次閱讀
    一文了解<b class='flag-5'>TCP</b>/<b class='flag-5'>IP</b><b class='flag-5'>協(xié)議</b>

    華納云:TCP IP協(xié)議的發(fā)展和優(yōu)勢

    TCP/IP(Transmission Control Protocol/Internet Protocol,傳輸控制協(xié)議/互聯(lián)網(wǎng)協(xié)議)是互聯(lián)網(wǎng)和現(xiàn)代計算機網(wǎng)絡(luò)的基礎(chǔ)
    的頭像 發(fā)表于 07-25 16:49 ?849次閱讀

    PLC協(xié)議、Modbus RTU TCP 、DL T645、IEC101-104、BACnet 轉(zhuǎn)Modbus TCP RTU、OPC UA、MQTT、BACnet IP協(xié)議網(wǎng)關(guān)

    一、概述 BL110是一款物聯(lián)網(wǎng)無線工業(yè)智能網(wǎng)關(guān),支持各種PLC協(xié)議、Modbus RTU?、Modbus TCP、DL/T645、IEC101、IEC104、BACnet IP、BACnet MS
    的頭像 發(fā)表于 07-24 16:04 ?1152次閱讀
    PLC<b class='flag-5'>協(xié)議</b>、Modbus RTU  <b class='flag-5'>TCP</b> 、DL T645、IEC101-104、BACnet 轉(zhuǎn)Modbus <b class='flag-5'>TCP</b> RTU、OPC UA、MQTT、BACnet <b class='flag-5'>IP</b><b class='flag-5'>協(xié)議</b>網(wǎng)關(guān)

    TCP IP協(xié)議屬性設(shè)置中的IP配置

    在現(xiàn)代網(wǎng)絡(luò)中,TCP/IP協(xié)議是基礎(chǔ)架構(gòu)的重要組成部分。掌握TCP/IP協(xié)議屬性設(shè)置中的
    的頭像 發(fā)表于 07-23 10:10 ?1035次閱讀