epoll哪些觸發模式_5.epoll的水平觸發和邊緣觸發

本篇是多路復用的第五篇,主要來講解epoll的水平觸發和邊緣觸發是怎么回事。

一、概念介紹

EPOLL事件有兩種模型,水平出發和邊緣觸發,如下所示:

1. Level Triggered (LT) 水平觸發

1. socket接收緩沖區不為空 有數據可讀 讀事件一直觸發2. socket發送緩沖區不滿 可以繼續寫入數據 寫事件一直觸發備注:符合思維習慣,epoll_wait返回的事件就是socket的狀態

例子介紹:

1.?accept一個連接,添加到epoll中監聽EPOLLIN事件2.?當EPOLLIN事件到達時,read?fd中的數據并處理3.?當需要寫出數據時,把數據write到fd中;如果數據較大,無法一次性寫出,那么在epoll中監聽EPOLLOUT事件4.?當EPOLLOUT事件到達時,繼續把數據write到fd中;如果數據寫出完畢,那么在epoll中關閉EPOLLOUT事件

2. Edge Triggered (ET) 邊沿觸發

1. socket的接收緩沖區狀態變化時觸發讀事件,即空的接收緩沖區剛接收到數據時觸發讀事件2. socket的發送緩沖區狀態變化時觸發寫事件,即滿的緩沖區剛空出空間時觸發讀事件備注:僅在狀態變化時觸發事件

例子介紹:

1.?accept一個一個連接,添加到epoll中監聽EPOLLIN|EPOLLOUT事件2.?當EPOLLIN事件到達時,read?fd中的數據并處理,read需要一直讀,直到返回EAGAIN為止3.?當需要寫出數據時,把數據write到fd中,直到數據全部寫完,或者write返回EAGAIN4.?當EPOLLOUT事件到達時,繼續把數據write到fd中,直到數據全部寫完,或者write返回EAGAIN

3.LT和ET兩者比較:

1. 從ET的處理過程中可以看到,ET的要求是需要一直讀寫,直到返回EAGAIN,否則就會遺漏事件。ET的編程可以做到更加簡潔,某些場景下更加高效,但另一方面容易遺漏事件,容易產生bug。2. LT的處理過程中,直到返回EAGAIN不是硬性要求,但通常的處理過程都會讀寫直到返回EAGAIN,但LT比ET多了一個開關EPOLLOUT事件的步驟。LT的編程與poll/select接近,符合一直以來的習慣,不易出錯。

二?、內核調度實現方式

  • 在epoll_wait的時候,阻塞等待事件發生, 事件發生時通過回調掛到ready list鏈表中

  • epoll_wait返回, 處理ready list, 返回事件給調用者

  • 此時ET模式已經將事件從ready list中刪除,LT模式中還存在

  • 此時假設應用程序處理完了事件, 再次epoll_wait. ?ET模式繼續阻塞

  • LT模式由于ready list中依然存在事件則不會阻塞, 對這些socket調用poll方法獲取最新的事件信息,如果確認沒事件了才會刪除。

c15cf90f72ba58da6af63cf2e4226836.png

三、?水平觸發和邊緣觸發的常見問題

1. 水平觸發的問題:不必要的喚醒

  1. 內核:收到一個新建連接的請求

  2. 內核:由于 “驚群效應” ,喚醒兩個正在 epoll_wait() 的線程 A 和線程 B

  3. 線程A:epoll_wait() 返回

  4. 線程B:epoll_wait() 返回

  5. 線程A:執行 accept() 并且成功

  6. 線程B:執行 accept() 失敗,accept() 返回 EAGAIN

2. 邊緣觸發的問題:不必要的喚醒以及饑餓

1)不必要的喚醒:

1.內核:收到第一個連接請求。線程 A 和 線程 B 兩個線程都在 epoll_wait() 上等待。由于采用邊緣觸發模式,所以只有一個線程會收到通知。這里假定線程 A 收到通知2.線程A:epoll_wait() 返回3.線程A:調用 accpet() 并且成功4.內核:此時 accept queue 為空,所以將邊緣觸發的 socket 的狀態從可讀置成不可讀5.內核:收到第二個建連請求6.內核:此時,由于線程 A 還在執行 accept() 處理,只剩下線程 B 在等待 epoll_wait(),于是喚醒線程 B。7.線程A:繼續執行 accept() 直到返回 EAGAIN8.線程B:執行 accept(),并返回 EAGAIN,此時線程 B 可能有點困惑(“明明通知我有事件,結果卻返回 EAGAIN”)9.線程A:再次執行 accept(),這次終于返回 EAGAIN

2)饑餓:

1.內核:接收到兩個建連請求。線程 A 和 線程 B 兩個線程都在等在 epoll_wait()。由于采用邊緣觸發模式,只有一個線程會被喚醒,我們這里假定線程 A 先被喚醒2.線程A:epoll_wait() 返回3.線程A:調用 accpet() 并且成功4.內核:收到第三個建連請求。由于線程?A?還沒有處理完(沒有返回?EAGAIN),當前?socket?還處于可讀的狀態,由于是邊緣觸發模式,所有不會產生新的事件5.線程A:繼續執行 accept() 希望返回 EAGAIN 再進入 epoll_wait() 等待,然而它又 accept() 成功并處理了一個新連接6.內核:又收到了第四個建連請求7.線程A:又繼續執行 accept(),結果又返回成功

參考文檔:

https://blog.csdn.net/dongfuye/article/details/50880251

https://www.zhihu.com/question/20502870

https://blog.lucode.net/linux/epoll-tutorial.html

https://plantegg.github.io/2019/12/09/epoll%E7%9A%84LT%E5%92%8CET/

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/396276.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/396276.shtml
英文地址,請注明出處:http://en.pswp.cn/news/396276.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

HC系列藍牙模塊連接單片機與電腦,傳輸數據(藍牙心電測試)

畢設做無線心電監護。有線的做出來了,AD8232MCULabVIEW上位機。pcb還沒時間搞,這個9*7*2.5cm拿來測試能用。 自己做了AD8232的模擬前端,打的板子還沒到沒法測試。 雖然比較水,但看起來任務也完成的差不多了,于是就想加…

java實現社交平臺_GitHub - akpaul9527/symphony: 一款用 Java 實現的現代化社區(論壇/BBS/社交網絡/博客)平臺。...

下一代的社區系統,為未來而構建簡介Symphony([?s?mf?ni],n.交響樂)是一個現代化的社區平臺,因為它:實現了面向內容討論的論壇實現了面向知識問答的社區包含了面向用戶分享、交友、游戲的社交網絡100% 開源動機很多社區論壇系統…

遠程連接本地mongodb 數據庫

綁定本地IP即可 start mongod --dbpath D:\mongodb\data\db --bind_ip 192.168.31.143 轉載于:https://www.cnblogs.com/yang-xiansen/p/9884598.html

qt日志實現

qt的日志有四個級別&#xff1a;qDebug&#xff1a; 調試信息qWarning&#xff1a; 警告信息qCritical&#xff1a; 嚴重錯誤qFatal&#xff1a; 致命錯誤可以通過<QtGlobal>下的void qCritical ( const char * msg, ... );void qDebug ( const char *…

mvc 視圖和模型的對應_通過在酒吧訂購飲料來解釋模型視圖控制器(MVC)

mvc 視圖和模型的對應by Kevin Kononenko凱文科諾年科(Kevin Kononenko) 通過在酒吧訂購飲料來解釋模型視圖控制器(MVC) (Model-View-Controller (MVC) Explained Through Ordering Drinks At The Bar) 如果您去過酒吧&#xff0c;那么MVC并不難。 (If you have been to a bar…

nodejs計算時間間隔_Javascript計算時間差的函數分享

核心代碼/** 獲得時間差,時間格式為 年-月-日 小時:分鐘:秒 或者 年/月/日 小時&#xff1a;分鐘&#xff1a;秒* 其中&#xff0c;年月日為全格式&#xff0c;例如 &#xff1a; 2010-10-12 01:00:00* 返回精度為&#xff1a;秒&#xff0c;分&#xff0c;小時&#xff0c;天*…

jQuery實現鼠標劃過展示大圖的方法

這篇文章主要介紹了jQuery實現鼠標劃過展示大圖的方法,實例分析了jQuery操作鼠標事件及圖片處理的技巧,具有一定參考借鑒價值,需要的朋友可以參考下 本文實例講述了jQuery實現鼠標劃過展示大圖的方法。分享給大家供大家參考。具體如下&#xff1a; 這里用css和jquery實現鼠標移…

精通java益處_你真的精通Java嗎?

簡歷和自我介紹上經常能夠讀到“精通Java”這樣的話&#xff0c;有人和我說&#xff0c;精通Java的人太多了&#xff0c;精通Java已經不能算亮點、不能給自己加分了。可是事實真是這樣嗎&#xff1f;對于語言的學習&#xff0c;我有一種觀點&#xff0c;一是縱向&#xff0c;即…

Luogu P2101 命運石之門的選擇(分治+搜索)

P2101 命運石之門的選擇 題意 題目描述 在某一條不知名世界線的岡倫今天突然接到了一條\(dmail\)&#xff0c;上面說世界線將會發生巨大變動&#xff0c;未來的他無論如何都無法扭轉這種變動回到原來的世界線。而世界線變動的原因是現在的他不久后錯過了與助手的約會。他約好要…

Java初級筆記-第五章

第五章 面向對象的特點 5.1 繼承 面向對象的重要特點之一就是繼承。類的繼承使得能夠在已有的類的基礎上構造新的類&#xff0c;新類除了具有被繼承類的屬性和方法外&#xff0c;還可以根據需要添加新的屬性和方法。繼承有利于代碼的復用&#xff0c;通過繼承可以更有效地組織程…

取模運算性質_求余、取模運算在RTOS中計算優先級的理解

uCOS3中的部分源碼&#xff1a;/* 置位優先級表中相應的位 */void OS_PrioInsert (OS_PRIO prio){CPU_DATA bit;CPU_DATA bit_nbr;OS_PRIO ix;/* 求模操作&#xff0c;獲取優先級表數組的下標索引 */ix prio / DEF_INT_CPU_NBR_BITS;//32bits//由于數據均為無符號數,prio為8位…

歸結原則_被聘為自由職業者歸結為一件事:信任。

歸結原則by I quit Medium我退出Medium 被聘為自由職業者歸結為一件事&#xff1a;信任。 (Getting hired as a freelancer comes down to one thing: trust.) When I ask freelancers what they think is the most important factor in landing a client project, they usual…

關于JS的傳遞方式的小理解

var test function() {//將其看成是創建了一個對象alert(1);}var otherTest test;//賦值導致test和otherTest指向同一個對象otherTest();test.sd 9;//對對象進行操作&#xff0c;兩者都發生改變alert(otherTest.sd);//9var test function() {//test重新創建了一個對象&…

java p代表哪種數據類型_java數據類型(八種基本數據類型+三種引用類型)

1、整型類型 占用字節 取值范圍byte 1 -128~127 (7次方)short 2 -32 768~32 767 (15次方)int …

python中的隨機函數

python--隨機函數&#xff08;random,uniform,randint,randrange,shuffle,sample&#xff09; 本文轉載自:[chamie] random() random()方法&#xff1a;返回隨機生成的一個實數&#xff0c;它在[0,1)范圍內 運用random()方法的語法&#xff1a; import random #random()方法不…

Setuptool+pip安裝

https://pypi.python.org/pypi/setuptools 1. 下載ez_setup.py文件&#xff0c;cmd進入安裝目錄&#xff1b; 2. python setup.py install https://pip.pypa.io/en/latest/index.html 1、cmd進入ez_setup.py文件目錄2、用setuptools安裝&#xff1a;easy_install pip轉載于:htt…

rss 閱讀源_如何使用RSS更有效地閱讀

rss 閱讀源by Naman Kamra通過納曼卡姆拉(Naman Kamra) 如何使用RSS更有效地閱讀 (How to read more efficiently with RSS) Rich Site Summary (RSS) was developed way back in 1999 as a way to quickly subscribe to blogs and newspapers, back before tools like Twitte…

python 遍歷usb設備_python程序員教你寫腳本玩微信跳一跳,只要有耐心,你就是王者!...

溫馨提示&#xff1a;微信已經開始檢測分數異常高的情況了&#xff0c;請大家不要跑太高哦游戲模式這是一個 2.5D 插畫風格的益智游戲&#xff0c;玩家可以通過按壓屏幕時間的長短來控制這個「小人」跳躍的距離。可能剛開始上手的時候&#xff0c;因為時間距離之間的關系把握不…

一個電腦同時運行 64bit 和 32bit 的eclipse 如何匹配 jdk環境

一個電腦同時運行 64bit 和 32bit 的 eclipse 如何匹配 jdk環境 1 eclipse 分 64bit 和 32bit 兩種. 64bit的eclipse 只能搭配 64bit的 jdk 使用. 32bit的eclipse 只能搭配 32bit的 jdk 使用. 2 電腦上安裝好 32bit 和 64bit 的 jdk ,分別安裝在不同的路徑中. 比如我的3…

基本數據類型(dict)

目錄: 1.字典的簡單介紹 2.字典增刪改查和其他操作 3.字典的嵌套 一.字典的簡單介紹 字典(dict)是python中唯一的一個映射類型,他是以{}括起來的鍵值對組成,在dict中key是唯一的,在保存的時候,根據key類計算出一個地址然后將key-value保存在這個地址中這種算法被稱作hash算法,所…