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

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

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

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

TCP協(xié)議基礎知識

0BFC_eet_china ? 來源:互聯(lián)網(wǎng) ? 作者:佚名 ? 2017-10-16 10:29 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

TCP 是互聯(lián)網(wǎng)核心協(xié)議之一,本文介紹它的基礎知識。

一、TCP 協(xié)議的作用

互聯(lián)網(wǎng)由一整套協(xié)議構成。TCP 只是其中的一層,有著自己的分工。

TCP協(xié)議基礎知識

(圖片說明:TCP 是以太網(wǎng)協(xié)議和 IP 協(xié)議的上層協(xié)議,也是應用層協(xié)議的下層協(xié)議。)

最底層的以太網(wǎng)協(xié)議(Ethernet)規(guī)定了電子信號如何組成數(shù)據(jù)包(packet),解決了子網(wǎng)內(nèi)部的點對點通信

TCP協(xié)議基礎知識

(圖片說明:以太網(wǎng)協(xié)議解決了局域網(wǎng)的點對點通信。)

但是,以太網(wǎng)協(xié)議不能解決多個局域網(wǎng)如何互通,這由 IP 協(xié)議解決。

TCP協(xié)議基礎知識

(圖片說明:IP 協(xié)議可以連接多個局域網(wǎng)。)

IP 協(xié)議定義了一套自己的地址規(guī)則,稱為 IP 地址。它實現(xiàn)了路由功能,允許某個局域網(wǎng)的 A 主機,向另一個局域網(wǎng)的 B 主機發(fā)送消息。

(圖片說明:路由器就是基于 IP 協(xié)議。局域網(wǎng)之間要靠路由器連接。)

路由的原理很簡單。市場上所有的路由器,背后都有很多網(wǎng)口,要接入多根網(wǎng)線。路由器內(nèi)部有一張路由表,規(guī)定了 A 段 IP 地址走出口一,B 段地址走出口二,。..。..通過這套“指路牌”,實現(xiàn)了數(shù)據(jù)包的轉(zhuǎn)發(fā)。

TCP協(xié)議基礎知識

(圖片說明:本機的路由表注明了不同 IP 目的地的數(shù)據(jù)包,要發(fā)送到哪一個網(wǎng)口(interface)。)

IP 協(xié)議只是一個地址協(xié)議,并不保證數(shù)據(jù)包的完整。如果路由器丟包(比如緩存滿了,新進來的數(shù)據(jù)包就會丟失),就需要發(fā)現(xiàn)丟了哪一個包,以及如何重新發(fā)送這個包。這就要依靠 TCP 協(xié)議。

簡單說,TCP 協(xié)議的作用是,保證數(shù)據(jù)通信的完整性和可靠性,防止丟包。

二、TCP 數(shù)據(jù)包的大小

以太網(wǎng)數(shù)據(jù)包(packet)的大小是固定的,最初是1518字節(jié),后來增加到1522字節(jié)。其中, 1500 字節(jié)是負載(payload),22字節(jié)是頭信息(head)。

IP 數(shù)據(jù)包在以太網(wǎng)數(shù)據(jù)包的負載里面,它也有自己的頭信息,最少需要20字節(jié),所以 IP 數(shù)據(jù)包的負載最多為1480字節(jié)。

TCP協(xié)議基礎知識

(圖片說明:IP 數(shù)據(jù)包在以太網(wǎng)數(shù)據(jù)包里面,TCP 數(shù)據(jù)包在 IP 數(shù)據(jù)包里面。)

TCP 數(shù)據(jù)包在 IP 數(shù)據(jù)包的負載里面。它的頭信息最少也需要20字節(jié),因此 TCP 數(shù)據(jù)包的最大負載是 1480 - 20 = 1460 字節(jié)。由于 IP 和 TCP 協(xié)議往往有額外的頭信息,所以 TCP 負載實際為1400字節(jié)左右。

因此,一條1500字節(jié)的信息需要兩個 TCP 數(shù)據(jù)包。HTTP/2 協(xié)議的一大改進, 就是壓縮 HTTP 協(xié)議的頭信息,使得一個 HTTP 請求可以放在一個 TCP 數(shù)據(jù)包里面,而不是分成多個,這樣就提高了速度。

TCP協(xié)議基礎知識

(圖片說明:以太網(wǎng)數(shù)據(jù)包的負載是1500字節(jié),TCP 數(shù)據(jù)包的負載在1400字節(jié)左右。)

三、TCP 數(shù)據(jù)包的編號(SEQ)

一個包1400字節(jié),那么一次性發(fā)送大量數(shù)據(jù),就必須分成多個包。比如,一個 10MB 的文件,需要發(fā)送7100多個包。

發(fā)送的時候,TCP 協(xié)議為每個包編號(sequence number,簡稱 SEQ),以便接收的一方按照順序還原。萬一發(fā)生丟包,也可以知道丟失的是哪一個包。

第一個包的編號是一個隨機數(shù)。為了便于理解,這里就把它稱為1號包。假定這個包的負載長度是100字節(jié),那么可以推算出下一個包的編號應該是101。這就是說,每個數(shù)據(jù)包都可以得到兩個編號:自身的編號,以及下一個包的編號。接收方由此知道,應該按照什么順序?qū)⑺鼈冞€原成原始文件。

TCP協(xié)議基礎知識

(圖片說明:當前包的編號是45943,下一個數(shù)據(jù)包的編號是46183,由此可知,這個包的負載是240字節(jié)。)

四、TCP 數(shù)據(jù)包的組裝

收到 TCP 數(shù)據(jù)包以后,組裝還原是操作系統(tǒng)完成的。應用程序不會直接處理 TCP 數(shù)據(jù)包。

對于應用程序來說,不用關心數(shù)據(jù)通信的細節(jié)。除非線路異常,收到的總是完整的數(shù)據(jù)。應用程序需要的數(shù)據(jù)放在 TCP 數(shù)據(jù)包里面,有自己的格式(比如 HTTP 協(xié)議)。

TCP 并沒有提供任何機制,表示原始文件的大小,這由應用層的協(xié)議來規(guī)定。比如,HTTP 協(xié)議就有一個頭信息Content-Length,表示信息體的大小。對于操作系統(tǒng)來說,就是持續(xù)地接收 TCP 數(shù)據(jù)包,將它們按照順序組裝好,一個包都不少。

操作系統(tǒng)不會去處理 TCP 數(shù)據(jù)包里面的數(shù)據(jù)。一旦組裝好 TCP 數(shù)據(jù)包,就把它們轉(zhuǎn)交給應用程序。TCP 數(shù)據(jù)包里面有一個端口(port)參數(shù),就是用來指定轉(zhuǎn)交給監(jiān)聽該端口的應用程序。

TCP協(xié)議基礎知識

(圖片說明:系統(tǒng)根據(jù) TCP 數(shù)據(jù)包里面的端口,將組裝好的數(shù)據(jù)轉(zhuǎn)交給相應的應用程序。上圖中,21端口是 FTP 服務器,25端口是 SMTP 服務,80端口是 Web 服務器。)

應用程序收到組裝好的原始數(shù)據(jù),以瀏覽器為例,就會根據(jù) HTTP 協(xié)議的Content-Length字段正確讀出一段段的數(shù)據(jù)。這也意味著,一次 TCP 通信可以包括多個 HTTP 通信。

五、慢啟動和 ACK

服務器發(fā)送數(shù)據(jù)包,當然越快越好,最好一次性全發(fā)出去。但是,發(fā)得太快,就有可能丟包。帶寬小、路由器過熱、緩存溢出等許多因素都會導致丟包。線路不好的話,發(fā)得越快,丟得越多。

最理想的狀態(tài)是,在線路允許的情況下,達到最高速率。但是我們怎么知道,對方線路的理想速率是多少呢?答案就是慢慢試。

TCP 協(xié)議為了做到效率與可靠性的統(tǒng)一,設計了一個慢啟動(slow start)機制。開始的時候,發(fā)送得較慢,然后根據(jù)丟包的情況,調(diào)整速率:如果不丟包,就加快發(fā)送速度;如果丟包,就降低發(fā)送速度。

Linux 內(nèi)核里面設定了(常量TCP_INIT_CWND),剛開始通信的時候,發(fā)送方一次性發(fā)送10個數(shù)據(jù)包,即“發(fā)送窗口”的大小為10。然后停下來,等待接收方的確認,再繼續(xù)發(fā)送。

默認情況下,接收方每收到兩個 TCP 數(shù)據(jù)包,就要發(fā)送一個確認消息。“確認”的英語是 acknowledgement,所以這個確認消息就簡稱 ACK。

ACK 攜帶兩個信息。

期待要收到下一個數(shù)據(jù)包的編號

接收方的接收窗口的剩余容量

發(fā)送方有了這兩個信息,再加上自己已經(jīng)發(fā)出的數(shù)據(jù)包的最新編號,就會推測出接收方大概的接收速度,從而降低或增加發(fā)送速率。這被稱為“發(fā)送窗口”,這個窗口的大小是可變的。

TCP協(xié)議基礎知識

(圖片說明:每個 ACK 都帶有下一個數(shù)據(jù)包的編號,以及接收窗口的剩余容量。雙方都會發(fā)送 ACK。)

注意,由于 TCP 通信是雙向的,所以雙方都需要發(fā)送 ACK。兩方的窗口大小,很可能是不一樣的。而且 ACK 只是很簡單的幾個字段,通常與數(shù)據(jù)合并在一個數(shù)據(jù)包里面發(fā)送。

TCP協(xié)議基礎知識

(圖片說明:上圖一共4次通信。第一次通信,A 主機發(fā)給B 主機的數(shù)據(jù)包編號是1,長度是100字節(jié),因此第二次通信 B 主機的 ACK 編號是 1 + 100 = 101,第三次通信 A 主機的數(shù)據(jù)包編號也是 101。同理,第二次通信 B 主機發(fā)給 A 主機的數(shù)據(jù)包編號是1,長度是200字節(jié),因此第三次通信 A 主機的 ACK 是201,第四次通信 B 主機的數(shù)據(jù)包編號也是201。)

即使對于帶寬很大、線路很好的連接,TCP 也總是從10個數(shù)據(jù)包開始慢慢試,過了一段時間以后,才達到最高的傳輸速率。這就是 TCP 的慢啟動。

六、數(shù)據(jù)包的遺失處理

TCP 協(xié)議可以保證數(shù)據(jù)通信的完整性,這是怎么做到的?

前面說過,每一個數(shù)據(jù)包都帶有下一個數(shù)據(jù)包的編號。如果下一個數(shù)據(jù)包沒有收到,那么 ACK 的編號就不會發(fā)生變化。

舉例來說,現(xiàn)在收到了4號包,但是沒有收到5號包。ACK 就會記錄,期待收到5號包。過了一段時間,5號包收到了,那么下一輪 ACK 會更新編號。如果5號包還是沒收到,但是收到了6號包或7號包,那么 ACK 里面的編號不會變化,總是顯示5號包。這會導致大量重復內(nèi)容的 ACK。

如果發(fā)送方發(fā)現(xiàn)收到三個連續(xù)的重復 ACK,或者超時了還沒有收到任何 ACK,就會確認丟包,即5號包遺失了,從而再次發(fā)送這個包。通過這種機制,TCP 保證了不會有數(shù)據(jù)包丟失。

TCP協(xié)議基礎知識

(圖片說明:Host B 沒有收到100號數(shù)據(jù)包,會連續(xù)發(fā)出相同的 ACK,觸發(fā) Host A 重發(fā)100號數(shù)據(jù)包。)

七、參考鏈接

Network protocols for programmers who know at least one programming language

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

    關注

    1

    文章

    101

    瀏覽量

    12767

原文標題:五分鐘讀懂TCP 協(xié)議

文章出處:【微信號:eet-china,微信公眾號:電子工程專輯】歡迎添加關注!文章轉(zhuǎn)載請注明出處。

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

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

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

    TCP/IP協(xié)議作為互聯(lián)網(wǎng)通信的基礎架構,其核心機制Socket編程承載著全球數(shù)據(jù)交換的使命。本文將深入剖析這一協(xié)議的七層架構、三次握手與四次揮手的精妙設計、流量控制與擁塞控制的動態(tài)平衡,以及現(xiàn)代互聯(lián)網(wǎng)環(huán)境下面臨的挑戰(zhàn)與演進方向
    的頭像 發(fā)表于 03-03 17:06 ?459次閱讀

    阻燃系列基礎知識

    我很榮幸有機會在這里與大家分享我對阻燃系列基礎知識的研究。今天,我們將探討的主題是“阻燃系列基礎知識”。在我們?nèi)粘I钪校馂氖鹿暑l發(fā),造成巨大的財產(chǎn)損失和人員傷亡。因此,了解阻燃材料的基礎知識對于
    的頭像 發(fā)表于 02-06 08:07 ?245次閱讀
    阻燃系列<b class='flag-5'>基礎知識</b>

    無刷電機驅(qū)動器的基礎知識

    本文將從技術角度出發(fā),對三相無刷電機的電機驅(qū)動器的作用、種類和規(guī)格進行介紹。通過本文,您可以學習到電機驅(qū)動器選型所需的基礎知識
    的頭像 發(fā)表于 12-10 14:13 ?6677次閱讀
    無刷電機驅(qū)動器的<b class='flag-5'>基礎知識</b>

    為什么會有TCP/IP協(xié)議

    見了面,完全不能交流信息。因而他們需要定義一些共通的東西來進行交流,TCP/IP就是為此而生。TCP/IP不是一個協(xié)議,而是一個協(xié)議族的統(tǒng)稱。 里面包括了IP
    發(fā)表于 12-03 06:28

    智能物流立體倉庫通訊困境:基于協(xié)議轉(zhuǎn)換的Modbus TCP 轉(zhuǎn) Modbus RTU解決方案

    在工業(yè)自動化領域的智能物流自動化立體倉庫中,塔訊 TX 131-RE-RS/TCP在某企業(yè)采用研華工控機(Modbus RTU 協(xié)議)負責倉儲管理系統(tǒng)(WMS)的訂單下發(fā)、庫存統(tǒng)計,搭配三菱 Q 系列 PLC(Modbus TCP
    的頭像 發(fā)表于 11-08 11:25 ?377次閱讀
    智能物流立體倉庫通訊困境:基于<b class='flag-5'>協(xié)議</b>轉(zhuǎn)換的Modbus <b class='flag-5'>TCP</b> 轉(zhuǎn) Modbus RTU解決方案

    Modbus TCP與RTU協(xié)議詳解:網(wǎng)關采集如何選?

    深控網(wǎng)關如何工作: 我們的高端系列網(wǎng)關具備多串口 + 網(wǎng)口的配置,可以同時接入RS-485總線上的RTU設備和網(wǎng)絡上的TCP設備。網(wǎng)關作為一個數(shù)據(jù)匯聚點,將不同協(xié)議的數(shù)據(jù)統(tǒng)一采集、處理,并轉(zhuǎn)換成標準協(xié)議(如MQTT、OPC UA
    的頭像 發(fā)表于 11-04 10:34 ?389次閱讀

    視覺工程師必須知道的工業(yè)相機基礎知識

    工業(yè)相機基礎知識概述。
    的頭像 發(fā)表于 09-19 17:04 ?1265次閱讀
    視覺工程師必須知道的工業(yè)相機<b class='flag-5'>基礎知識</b>

    Profinet從轉(zhuǎn)Modbus(TCP)主總線協(xié)議轉(zhuǎn)換網(wǎng)關

    和Modbus(TCP)從站網(wǎng)絡網(wǎng)絡設備連接,?從而實現(xiàn)不同工業(yè)通信協(xié)議之間的相互轉(zhuǎn)換。可支持Modbus TCP Client和Modbus TCP Server。即將Modbus設
    的頭像 發(fā)表于 09-18 14:57 ?591次閱讀
    Profinet從轉(zhuǎn)Modbus(<b class='flag-5'>TCP</b>)主總線<b class='flag-5'>協(xié)議</b>轉(zhuǎn)換網(wǎng)關

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

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

    什么是Modbus TCP協(xié)議

    Modbus TCP是一種基于TCP/IP協(xié)議的Modbus通信協(xié)議,用于在客戶機和服務器之間進行數(shù)據(jù)通信。它常用于工業(yè)自動化控制、電力監(jiān)控與管理、溫濕度監(jiān)測等領域。Modbus
    的頭像 發(fā)表于 07-23 17:18 ?4260次閱讀
    什么是Modbus <b class='flag-5'>TCP</b><b class='flag-5'>協(xié)議</b>

    Modbus TCP轉(zhuǎn)Profibus DP主站網(wǎng)關:跨協(xié)議集成的核心樞紐

    一、產(chǎn)品定位:主站級協(xié)議融合 在工業(yè)自動化系統(tǒng)中,如何實現(xiàn)不同通信協(xié)議設備的高效協(xié)同一直是技術難點。三格電子推出的Modbus TCP轉(zhuǎn)Profibus DP主站網(wǎng)關,以強大的協(xié)議轉(zhuǎn)換
    的頭像 發(fā)表于 04-17 16:04 ?839次閱讀
    Modbus <b class='flag-5'>TCP</b>轉(zhuǎn)Profibus DP主站網(wǎng)關:跨<b class='flag-5'>協(xié)議</b>集成的核心樞紐

    直播回顧 | 核心協(xié)議精講!TSN基礎知識理論培訓,虹科帶你劃重點!

    當工業(yè)4.0與智能汽車、航空航天技術碰撞實時性、確定性通信成為跨越行業(yè)的共同需求4月1日虹科直播間虹科TSN工程師羅工帶來「TSN基礎知識理論培訓」帶大家系統(tǒng)回顧了TSN技術發(fā)展歷程深度解析了
    的頭像 發(fā)表于 04-02 17:33 ?960次閱讀
    直播回顧 | 核心<b class='flag-5'>協(xié)議</b>精講!TSN<b class='flag-5'>基礎知識</b>理論培訓,虹科帶你劃重點!

    效果器的基礎知識

    電子發(fā)燒友網(wǎng)站提供《效果器的基礎知識.doc》資料免費下載
    發(fā)表于 03-26 14:30 ?7次下載

    開關電源的基礎知識題目及答案(免積分)

    本文含有開關電源的基礎知識題目及答案,下載附件即可查看!
    發(fā)表于 03-06 15:52

    【北京迅為】iTOP-RK3568OpenHarmony系統(tǒng)南向驅(qū)動開發(fā)GPIO基礎知識

    【北京迅為】iTOP-RK3568OpenHarmony系統(tǒng)南向驅(qū)動開發(fā)GPIO基礎知識
    的頭像 發(fā)表于 03-06 11:23 ?1252次閱讀
    【北京迅為】iTOP-RK3568OpenHarmony系統(tǒng)南向驅(qū)動開發(fā)GPIO<b class='flag-5'>基礎知識</b>