国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

Linux高性能網絡編程十談 | TCP底層的收發過程

系統 Linux
談完上一篇《Linux高性能網絡編程十談|網絡篇》,我們繼續探索高性能網絡編程,但是我覺得在談系統API之前可以先講一些Linux底層的收發包過程,如下這是一個簡單的socket編程代碼:

談完上一篇《Linux高性能網絡編程十談|網絡篇》,我們繼續探索高性能網絡編程,但是我覺得在談系統API之前可以先講一些Linux底層的收發包過程,如下這是一個簡單的socket編程代碼:

int main() {
    ... 

    fd = socket(AF_INET, SOCKET_STREAM, 0);
    bind(fd, ...);
    listen(fd, ...);

    // 如何建立連接
    ...
    afd = accept(fd, ...);

    // 如何接收數據
    ...
    read(afd, ...);

    // 如何發送數據
    ...
    send(afd, ...);

    // 如何關閉連接
    ...
    close(fd);
    ...
}

第一部分:如何建立連接

從上一篇文章我們介紹了網絡協議,我們知道TCP/IP協議族劃分了應用層、TCP傳輸層、IP網絡層、鏈路層(以太層驅動)。

如上圖看應用層,通常在網絡編程中我們需要調用accept的API建立TCP連接,那TCP如何做的呢?

從上圖的流程可以看到:

(1)client端發起TCP握手,發送syn包;

(2)內核收到包以后先將當前連接的信息插入到網絡的SYN隊列;

(3)插入成功后會返回握手確認(SYN+ACK);

(4)client端如果繼續完成TCP握手,回復ACK確認;

(5)內核會將TCP握手完成的包,先將對應的連接信息從SYN隊列取出;

(6)將連接信息丟入到ACCEPT隊列;

(7)應用層sever通過系統調用accept就能拿到這個連接,整個網絡套接字連接完成;

那基于這個圖,我想問問讀者這里會有什么問題么?

細心的讀者應該可以看出:

1、這里有兩個隊列,必然會有滿的情況,那如果遇到這種情況內核是怎么處理的呢?

(1)如果SYN隊列滿了,內核就會丟棄連接;

(2)如果ACCEPT隊列滿了,那內核不會繼續將SYN隊列的連接丟到ACCEPT隊列,如果SYN隊列足夠大,client端后續收發包就會超時;

(3)如果SYN隊列滿了,就會和(1)一樣丟棄連接;

2、如何控制SYN隊列和ACCEPT隊列的大小?

(1)內核2.2版本之前通過listen的backlog可以設置SYN隊列(半連接狀態SYN_REVD)和ACCEPT隊列(完全連接狀態ESTABLISHED)的上限;

(2)內核2.2版本以后backlog只是表示ACCEPT隊列上限,SYN隊列的上限可以通過/proc/sys/net/ipv4/tcp_max_syn_backlog設置;

3、server端通過accept一直等,豈不是會卡住收包的線程?

在linux網絡編程中我們都會追求高性能,accept如果卡住接收線程,性能會上不去,所以socket編程中就會有阻塞和非阻塞模式。

(1)阻塞模式下的accept就會卡住,當前線程什么事情都干不了;

(2)非阻塞模式下,可以通過輪詢accept去處理其他的事情,如果返回EAGAIN,就是ACCEPT隊列為空,如果返回連接信息,就是可以處理當前連接;

第二部分:接收數據

(1)當網卡接收到報文并判斷為TCP協議后,將會調用到內核的tcp_v4_rcv方法,如果數據按順序收到S1數據包,則直接插入receive隊列中;

(2)當收到了S3數據包,在第1步結束后,應該收到S2序號,但是報文是亂序進來的,則將S3插入out_of_order隊列(這個隊列存儲亂序報文);

(3)接下來收到S2數據包,如第1步直接進入receive隊列,由于此時out_of_order隊列不像第1步是空的,所以引發了接來的第4步;

(4)每次向receive隊列插入報文時都會檢查out_of_order隊列,如果遇到期待的序號S3,則從out_of_order隊列摘除,寫入到receive隊列;

(5)現在應用程序開始調用recv方法;

(6)經過層層封裝調用,接收TCP消息最終會走到tcp_recvmsg方法;

(7)現在需要拷貝數據從內核態到用戶態,如果receive隊列為空,會先檢查SO_RCVLOWAT這個閥值(0表示收到指定的數據返回,1表示只要讀取到數據就返回,系統默認是1),如果已經拷貝的字節數到現在還小于它,那么可能導致進程會休眠,等待拷貝更多的數據;

(8)將數據從內核態拷貝到用戶態,recv返回拷貝數據的大小;

(9)為了選擇降低網絡包延時或者提升吞吐量,系統提供了tcp_low_latency參數,如果為0值,用戶暫時沒有讀數據則數據包進入prequeue隊列,提升吞吐量,否則不使用prequeue隊列,進入tcp_v4_do_rcv,降低延時;

第三部分:發送數據

(1)假設調用send方法來發送大于一個MSS(比如2K)的數據;

(2)內核調用tcp_sendmsg,實現復制數據,寫入隊列和組裝tcp協議頭;

(3)在調用tcp_sendmsg先需要在內核獲取skb,將用戶態數據拷貝到內核態,內核真正執行報文的發送,與send方法的調用并不是同步的,即send方法返回成功,也不一定把IP報文都發送到網絡中了。因此,需要把用戶需要發送的用戶態內存中的數據,拷貝到內核態內存中,不依賴于用戶態內存,也使得進程可以快速釋放發送數據占用的用戶態內存。但這個拷貝操作并不是簡單的復制,而是把待發送數據,按照MSS來劃分成多個盡量達到MSS大小的分片報文段,復制到內核中的sk_buff結構來存放;

(4)將數據拷貝到發送隊列中tcp_write_queue;

(5)調用tcp_push發送數據到IP層,這里主要滑動窗口,慢啟動,擁塞窗口的控制和判斷是否使用Nagle算法合并小報文(上一篇已經有介紹);

(6)組裝IP報文頭,通過經過iptables或者tcpdump等netfilter模塊過濾,將數據交給鄰居子系統(主要功能是查找需要發送的MAC地址,發送arp請求,封裝MAC頭等);

(7)調用網卡驅動程序將數據發送出去;

第四部分:關閉連接

關閉連接就是TCP揮手過程,我們都知道TCP連接是一種可靠的連接,那如何才能完整可靠的完成關閉連接呢?linux系統提供了兩個函數:

close對應tcp_close方法,通過減少socket的引用次數實現關閉,僅當引用計數為0時才會觸發tcp_close;

shutdown對應tcp_shutdown方法,不關心socket被引用次數,直接關閉對應的連接;

(1)shutdown可攜帶一個參數,取值有3個,分別意味著:只關閉讀、只關閉寫、同時關閉讀寫;

(2)若shutdown的是半打開的連接,則發出RST來關閉連接;

(3)若shutdown的是正常連接,那么關閉讀其實與對端是沒有關系的;

(4)若參數中有標志位為關閉寫,那么下面做的事與close是一致的,發出FIN包,告訴對方本機不會再發消息了;

第五部分:思考題

基于本文留幾個思考題,下一篇文章解答。

(1)發送方法返回成功后,數據一定發送到了TCP的對端么?

(調用了IP層的方法返回后,也未必就保證此時數據一定發送成功)

(2)1個socket套接字可能被多個進程在使用,出現并發訪問時,內核是怎么處理這種狀況的?

(3)若socket為默認的阻塞套接字,調用recv方法傳入的len參數,如果網絡包的數據小于len,recv會返回么?

(4)當socket被多進程或者多線程共享時,關閉連接時有何區別?

責任編輯:華軒 來源: 周末程序猿
相關推薦

2024-03-18 13:43:20

Linux架構

2023-11-01 11:59:13

2023-11-01 10:38:46

Linux高性能網絡編程

2023-11-01 10:58:31

系統調用高性能網絡編程Linux

2023-11-01 11:40:46

Linux高性能網絡編程工具

2023-11-01 11:27:10

Linux協程

2023-11-01 11:51:08

Linux性能優化

2023-11-01 11:07:05

Linux高性能網絡編程線程

2023-11-01 11:20:57

2023-11-01 11:13:58

Linux信號處理定時器

2025-06-26 01:27:00

2020-11-06 18:51:17

LinuxTCP服務器

2024-10-06 14:37:52

2024-09-03 09:15:37

2024-08-06 08:22:18

2024-10-16 11:03:30

Linux高性能編程

2012-09-25 15:02:50

C#網絡協議

2022-03-21 14:13:22

Go語言編程

2021-02-06 09:40:11

LinuxCPU高性能

2023-04-14 14:35:35

網絡
點贊
收藏

51CTO技術棧公眾號

久久精品视频免费播放| 日韩在线欧美| 日韩av在线综合| 一级毛片久久久| 2017亚洲天堂1024| 欧美高清日韩| 在线视频国内自拍亚洲视频| 91亚洲永久免费精品| 成人女人a毛片在线看| 国产精品香蕉| 亚洲一区二区欧美激情| 日本视频久久久| xxxx影院| 国内久久视频| 欧美成人伊人久久综合网| 久久香蕉综合色| 黄色网页在线看| 亚洲激情二区| 日韩成人激情视频| 国产日韩亚洲欧美在线| 亚洲精品aⅴ| 午夜精品123| 国产经典一区二区三区| 在线播放免费av| 国产美女精品一区二区三区| 久久九九亚洲综合| 亚洲女同av| 中文字幕一区二区三区不卡 | 日韩aⅴ视频一区二区三区| 波多野结衣久久| 久久久欧美精品sm网站| 国产成人一区二区| 伊人在我在线看导航| 4438亚洲最大| 免费成人在线视频网站| 亚洲女娇小黑人粗硬| 欧美日韩五月天| 国产传媒久久久| 日韩黄色大片| 国产91亚洲精品一区二区三区| 日韩视频免费| 欧美激情免费在线| 日本免费一区二区三区最新| 国产一区二区免费在线| 欧美一性一乱一交一视频| 污视频网站在线免费| 嫩草伊人久久精品少妇av杨幂| 精一区二区三区| 精品久久一区二区三区| 2020av在线| 亚洲免费资源在线播放| 日本在线观看一区二区| 久久精品国产色蜜蜜麻豆| 久久久伊人日本| 毛片网站在线看| 一区二区理论电影在线观看| 亚洲自拍偷拍一区二区三区| 九九在线高清精品视频| 亚洲精品久久久久久久久久久| 一个人看的免费网站www视频| 国产精品影视在线| 日日噜噜夜夜狠狠| 日韩在线一区二区| 国产成人一区二区三区| 国产精品综合| 国产美女91呻吟求| 久久亚洲精精品中文字幕| 精品精品国产高清a毛片牛牛 | heyzo在线| 国语自产偷拍精品视频偷| 91青娱乐在线视频| 国产91精品精华液一区二区三区 | 欧美二级三级| 不卡一区2区| 亚洲视频在线观看免费| av基地在线| 久久成人一区二区| 1区2区在线| 国产成人精品一区二区在线| 免费高清视频精品| 免费在线成人av| 国产欧美日韩综合精品一区二区| 黄色影视在线观看| 青青国产91久久久久久 | 欧美久久综合性欧美| 久久久国产综合精品女国产盗摄| 欧美拍拍视频| 亚洲国产日产av| 爆操妹子视频在线观看| 欧美成人r级一区二区三区| 日韩中出av| 91精品国产色综合久久不卡98口| 欧美aaa级| 综合国产在线视频| 亚洲第一成年免费网站| 中文字幕第一区综合| 亚洲激情在线观看视频| 久久精品人人做人人综合| 日韩黄色碟片| 久久精品在线观看| 中文字幕2019第三页| 日韩欧美中文字幕制服| 日韩精品一二| 精品国模在线视频| 亚洲一区二区三区高清不卡| 2020国产精品视频| 老司机免费视频一区二区| 三级做a全过程在线观看| 欧美日韩xxxxx| 亚洲精品555| 精品蜜桃传媒| 国产免费成人| 中文字幕在线资源| 亚洲图片欧美视频| 日本在线一区二区| 亚洲高清在线播放| 精品在线你懂的| 神马久久精品| 欧美一级大片在线观看| 91视频免费看| 8x8x视频在线| 久久精品视频导航| 成熟亚洲日本毛茸茸凸凹| 日本a在线天堂| 懂色中文一区二区在线播放| 四虎久久免费| 欧美精品一区二区三区蜜桃视频| 国产不卡网站| 伊人av成人| 最美情侣韩剧在线播放| 亚洲老司机av| 欧美三区四区| 俺去了亚洲欧美日韩| 高清日韩中文字幕| ww国产内射精品后入国产| 亚洲成人av片在线观看| 日日av拍夜夜添久久免费| 日韩尤物视频| 日韩欧美的一区| 国产成人精品亚洲日本在线观看| 日韩国产精品一区二区三区| 在线精品视频小说1| 亚洲九九视频| 亚洲欧美国产一区二区| 日韩视频一区二区| 久久在线精品| 草草视频在线免费观看| 亚洲视频在线观看免费| 精品一区二区免费| 一区二区三区入口| 欧美高清视频一区二区| 日本一区二区高清| 99亚洲乱人伦aⅴ精品| 91久久精品www人人做人人爽| 日韩中文字幕亚洲一区二区va在线| 日本综合在线| 日韩欧美精品在线不卡| 日韩av在线导航| 国产精品18久久久久久久久| 九七影院97影院理论片免费| 欧美日韩卡一卡二| 久九九久频精品短视频| 热这里只有精品| 亚洲无限av看| 日韩黄色大片网站| 青青免费在线视频| 久久99热只有频精品91密拍| 欧美一区二区视频17c| 日韩精品一区二区三区视频播放 | 欧美在线视频网| 欧美视频福利| 欧美国产亚洲一区| 热久久视久久精品18亚洲精品| 欧美午夜无遮挡| 99热这里有精品| 国产伦精品一区二区三区在线 | 超碰资源在线| 国产精品欧美日韩久久| 国产毛片精品视频| 国产美女精品视频免费播放软件 | 人人网欧美视频| 麻豆传媒一区| 中文字幕久热精品在线视频| 日韩美女精品在线| 激情丁香婷婷| 国产精品嫩草在线观看| 国产一区二区成人| 精品久久久久久久大神国产| 视频二区欧美| 男人的天堂成人| 久久久久久久久久国产| 久久精品999| 久久99国产精品久久99大师| 天堂а√在线中文在线| 性视频1819p久久| 日韩三级.com| 亚洲精品中文字幕乱码三区| 久久丁香综合五月国产三级网站| 成人午夜国产| 成人在线分类|