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

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

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

TCP協(xié)議基礎(chǔ)知識(shí)

0BFC_eet_china ? 來(lái)源:互聯(lián)網(wǎng) ? 作者:佚名 ? 2017-10-16 10:29 ? 次閱讀

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

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

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

TCP協(xié)議基礎(chǔ)知識(shí)

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

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

TCP協(xié)議基礎(chǔ)知識(shí)

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

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

TCP協(xié)議基礎(chǔ)知識(shí)

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

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

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

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

TCP協(xié)議基礎(chǔ)知識(shí)

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

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

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

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

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

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

TCP協(xié)議基礎(chǔ)知識(shí)

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

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

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

TCP協(xié)議基礎(chǔ)知識(shí)

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

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

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

發(fā)送的時(shí)候,TCP 協(xié)議為每個(gè)包編號(hào)(sequence number,簡(jiǎn)稱(chēng) SEQ),以便接收的一方按照順序還原。萬(wàn)一發(fā)生丟包,也可以知道丟失的是哪一個(gè)包。

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

TCP協(xié)議基礎(chǔ)知識(shí)

(圖片說(shuō)明:當(dāng)前包的編號(hào)是45943,下一個(gè)數(shù)據(jù)包的編號(hào)是46183,由此可知,這個(gè)包的負(fù)載是240字節(jié)。)

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

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

對(duì)于應(yīng)用程序來(lái)說(shuō),不用關(guān)心數(shù)據(jù)通信的細(xì)節(jié)。除非線(xiàn)路異常,收到的總是完整的數(shù)據(jù)。應(yīng)用程序需要的數(shù)據(jù)放在 TCP 數(shù)據(jù)包里面,有自己的格式(比如 HTTP 協(xié)議)。

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

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

TCP協(xié)議基礎(chǔ)知識(shí)

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

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

五、慢啟動(dòng)和 ACK

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

最理想的狀態(tài)是,在線(xiàn)路允許的情況下,達(dá)到最高速率。但是我們?cè)趺粗?,?duì)方線(xiàn)路的理想速率是多少呢?答案就是慢慢試。

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

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

默認(rèn)情況下,接收方每收到兩個(gè) TCP 數(shù)據(jù)包,就要發(fā)送一個(gè)確認(rèn)消息?!按_認(rèn)”的英語(yǔ)是 acknowledgement,所以這個(gè)確認(rèn)消息就簡(jiǎn)稱(chēng) ACK。

ACK 攜帶兩個(gè)信息。

期待要收到下一個(gè)數(shù)據(jù)包的編號(hào)

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

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

TCP協(xié)議基礎(chǔ)知識(shí)

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

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

TCP協(xié)議基礎(chǔ)知識(shí)

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

即使對(duì)于帶寬很大、線(xiàn)路很好的連接,TCP 也總是從10個(gè)數(shù)據(jù)包開(kāi)始慢慢試,過(guò)了一段時(shí)間以后,才達(dá)到最高的傳輸速率。這就是 TCP 的慢啟動(dòng)。

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

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

前面說(shuō)過(guò),每一個(gè)數(shù)據(jù)包都帶有下一個(gè)數(shù)據(jù)包的編號(hào)。如果下一個(gè)數(shù)據(jù)包沒(méi)有收到,那么 ACK 的編號(hào)就不會(huì)發(fā)生變化。

舉例來(lái)說(shuō),現(xiàn)在收到了4號(hào)包,但是沒(méi)有收到5號(hào)包。ACK 就會(huì)記錄,期待收到5號(hào)包。過(guò)了一段時(shí)間,5號(hào)包收到了,那么下一輪 ACK 會(huì)更新編號(hào)。如果5號(hào)包還是沒(méi)收到,但是收到了6號(hào)包或7號(hào)包,那么 ACK 里面的編號(hào)不會(huì)變化,總是顯示5號(hào)包。這會(huì)導(dǎo)致大量重復(fù)內(nèi)容的 ACK。

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

TCP協(xié)議基礎(chǔ)知識(shí)

(圖片說(shuō)明:Host B 沒(méi)有收到100號(hào)數(shù)據(jù)包,會(huì)連續(xù)發(fā)出相同的 ACK,觸發(fā) Host A 重發(fā)100號(hào)數(shù)據(jù)包。)

七、參考鏈接

Network protocols for programmers who know at least one programming language

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

    關(guān)注

    1

    文章

    89

    瀏覽量

    12044

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

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

收藏 人收藏

    評(píng)論

    相關(guān)推薦

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

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

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

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

    通信必備知識(shí)!TCP與UDP協(xié)議介紹及使用

    TCP與UDP是兩個(gè)最常用的通訊協(xié)議。TCP是面向連接的協(xié)議,需要在收發(fā)數(shù)據(jù)前與對(duì)方建立可靠的連接,建立連接的過(guò)程為3次握手,斷開(kāi)連接的過(guò)程為4次揮手,確保數(shù)據(jù)傳輸?shù)目煽啃?。UDP是一
    的頭像 發(fā)表于 03-15 08:19 ?1541次閱讀
    通信必備<b class='flag-5'>知識(shí)</b>!<b class='flag-5'>TCP</b>與UDP<b class='flag-5'>協(xié)議</b>介紹及使用

    射頻與微波基礎(chǔ)知識(shí)

    射頻與微波基礎(chǔ)知識(shí)
    的頭像 發(fā)表于 01-16 10:05 ?674次閱讀
    射頻與微波<b class='flag-5'>基礎(chǔ)知識(shí)</b>

    關(guān)于TCP、HTTP的知識(shí)科普

    要說(shuō)http就繞不開(kāi)tcp,TCP協(xié)議對(duì)應(yīng)于傳輸層,而HTTP協(xié)議對(duì)應(yīng)于應(yīng)用層,從本質(zhì)上來(lái)說(shuō),二者沒(méi)有可比性。但是,http是基于tcp
    的頭像 發(fā)表于 12-21 09:31 ?860次閱讀
    關(guān)于<b class='flag-5'>TCP</b>、HTTP的<b class='flag-5'>知識(shí)</b>科普

    TCP協(xié)議面試常問(wèn)知識(shí)點(diǎn)總結(jié)

    TCP 作為傳輸層的協(xié)議,是一個(gè)IT工程師素養(yǎng)的體現(xiàn),也是面試中經(jīng)常被問(wèn)到的知識(shí)點(diǎn)。在此,我將 TCP 核心的一些問(wèn)題梳理了一下,希望能幫到各位。
    的頭像 發(fā)表于 12-15 10:38 ?653次閱讀
    <b class='flag-5'>TCP</b><b class='flag-5'>協(xié)議</b>面試常問(wèn)<b class='flag-5'>知識(shí)</b>點(diǎn)總結(jié)

    電氣技術(shù)基礎(chǔ)知識(shí)

    電氣技術(shù)基礎(chǔ)知識(shí)
    的頭像 發(fā)表于 12-14 09:11 ?1344次閱讀
    電氣技術(shù)<b class='flag-5'>基礎(chǔ)知識(shí)</b>

    TCP傳輸控制協(xié)議知識(shí)科普拓展

    傳輸控制協(xié)議TCP,Transmission Control Protocol)是一種面向連接的、可靠的、基于字節(jié)流的傳輸層通信協(xié)議,由IETF的RFC 793定義。
    的頭像 發(fā)表于 11-27 17:46 ?839次閱讀
    <b class='flag-5'>TCP</b>傳輸控制<b class='flag-5'>協(xié)議</b><b class='flag-5'>知識(shí)</b>科普拓展

    SPI協(xié)議基礎(chǔ)知識(shí)

    電子發(fā)燒友網(wǎng)站提供《SPI協(xié)議基礎(chǔ)知識(shí).pdf》資料免費(fèi)下載
    發(fā)表于 11-16 10:32 ?1次下載
    SPI<b class='flag-5'>協(xié)議</b><b class='flag-5'>基礎(chǔ)知識(shí)</b>

    TCP 協(xié)議的運(yùn)作機(jī)制

    今天我們將 從穩(wěn)定性角度深挖 TCP 協(xié)議的運(yùn)作機(jī)制 。 如今,大半個(gè)互聯(lián)網(wǎng)都建立在 TCP 協(xié)議之上,我們使用的 HTTP 協(xié)議、消息隊(duì)列
    的頭像 發(fā)表于 11-13 11:34 ?475次閱讀
    <b class='flag-5'>TCP</b> <b class='flag-5'>協(xié)議</b>的運(yùn)作機(jī)制

    TCP 協(xié)議深度解析

    從字面上來(lái)看,很多人會(huì)認(rèn)為 TCP/IP 是 TCP、IP 這兩種協(xié)議,實(shí)際上TCP/IP 協(xié)議族指的是在 IP
    的頭像 發(fā)表于 11-09 11:19 ?729次閱讀
    <b class='flag-5'>TCP</b> <b class='flag-5'>協(xié)議</b>深度解析

    TCP協(xié)議詳細(xì)解析

    TCPTCP/IP協(xié)議族中一個(gè)最核心的協(xié)議,它向下使用網(wǎng)絡(luò)層IP協(xié)議,向上為應(yīng)用層HTTP、FTP、SMTP、POP3、SSH、Telne
    的頭像 發(fā)表于 11-03 09:14 ?3575次閱讀
    <b class='flag-5'>TCP</b><b class='flag-5'>協(xié)議</b>詳細(xì)解析

    關(guān)于TCP/IP協(xié)議知識(shí)總結(jié)

    今天浩道跟大家分享關(guān)于TCP/IP協(xié)議的硬核干貨總結(jié),我常常跟小伙伴說(shuō),一個(gè)簡(jiǎn)短硬核的知識(shí)總結(jié),可以讓大家快速掌握這些知識(shí)體系,喜歡的小伙伴可以收藏起來(lái),隨時(shí)查看復(fù)習(xí)!
    的頭像 發(fā)表于 10-31 11:48 ?1116次閱讀
    關(guān)于<b class='flag-5'>TCP</b>/IP<b class='flag-5'>協(xié)議</b>的<b class='flag-5'>知識(shí)</b>總結(jié)

    TCP協(xié)議如何優(yōu)化

    的一些基礎(chǔ)知識(shí)。 TCP報(bào)文格式: 各部分的含義如下: 源端口,16bits 0~65525 目標(biāo)端口 16bits sequence number : 數(shù)據(jù)序號(hào),32 bi
    的頭像 發(fā)表于 10-08 15:15 ?1221次閱讀
    <b class='flag-5'>TCP</b><b class='flag-5'>協(xié)議</b>如何優(yōu)化

    LIN基礎(chǔ)知識(shí)和8位PIC單片機(jī)上實(shí)現(xiàn)的MCC LIN協(xié)議棧庫(kù)

    電子發(fā)燒友網(wǎng)站提供《LIN基礎(chǔ)知識(shí)和8位PIC單片機(jī)上實(shí)現(xiàn)的MCC LIN協(xié)議棧庫(kù).pdf》資料免費(fèi)下載
    發(fā)表于 09-25 14:56 ?12次下載
    LIN<b class='flag-5'>基礎(chǔ)知識(shí)</b>和8位PIC單片機(jī)上實(shí)現(xiàn)的MCC LIN<b class='flag-5'>協(xié)議</b>棧庫(kù)