Redis系統(tǒng)支持適配

原因1:

引用
Linux內(nèi)核會(huì)給每個(gè)進(jìn)程維護(hù)一個(gè)文件描述符表。而POSIX標(biāo)準(zhǔn)對(duì)于文件描述符進(jìn)行了以下約束:

  1. fd為0遥巴、1、2分別表示標(biāo)準(zhǔn)輸入、標(biāo)準(zhǔn)輸出和錯(cuò)誤輸出
  2. 每次新打開(kāi)的fd,必須使用當(dāng)前進(jìn)程中最小可用的文件描述符艾杏。
    Redis充分利用了文件描述符的這些特點(diǎn),來(lái)存儲(chǔ)每個(gè)fd對(duì)應(yīng)的事件盅藻。

原因2:

因?yàn)閞edis 是單線程高性能的购桑。
所以redis需要單線程輪詢汹族。
操作系統(tǒng)機(jī)制的輪詢是不太一樣的。
簡(jiǎn)而言之 linxu輪詢用epoll其兴,window 用selector
但是性能上來(lái)說(shuō) epoll是高于selector 的顶瞒。

原因3

redis-windows是由微軟開(kāi)發(fā)的。
Redis不僅支持Linux下的epoll元旬,還支持其他的IO復(fù)用方式榴徐,目前支持如下四種: 1. epoll:支持Linux系統(tǒng) 2. kqueue:支持FreeBSD系統(tǒng)(如macOS) 3. select 4. evport: 支持Solaris

幾個(gè)IO復(fù)用方式使用的判斷順序如下:

#ifdef HAVE_EVPORT
#include "ae_evport.c"
#else
    #ifdef HAVE_EPOLL
    #include "ae_epoll.c"
    #else
        #ifdef HAVE_KQUEUE
        #include "ae_kqueue.c"
        #else
        #include "ae_select.c"
        #endif
    #endif
#endif

這個(gè)順序其實(shí)也代表了四種IO復(fù)用方式的性能高低。

對(duì)于每種IO復(fù)用方式匀归,只要實(shí)現(xiàn)以下8個(gè)接口就可以正常對(duì)接Redis了:

int aeApiCreate(aeEventLoop *eventLoop);
void aeApiDelEvent(aeEventLoop *eventLoop, int fd, int delmask);
void aeApiResize(aeEventLoop *eventLoop, int setsize);
void aeApiFree(aeEventLoop *eventLoop);
int aeApiAddEvent(aeEventLoop *eventLoop, int fd, int mask);
void aeApiDelEvent(aeEventLoop *eventLoop, int fd, int delmask);
int aeApiPoll(aeEventLoop *eventLoop, struct timeval *tvp);
char *aeApiName(void);

在這個(gè)8個(gè)接口下面坑资,其實(shí)底層并沒(méi)有做太多的優(yōu)化,只是簡(jiǎn)單的對(duì)原有API封裝而已穆端。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末袱贮,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子体啰,更是在濱河造成了極大的恐慌攒巍,老刑警劉巖,帶你破解...
    沈念sama閱讀 212,029評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件荒勇,死亡現(xiàn)場(chǎng)離奇詭異柒莉,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)沽翔,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,395評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門兢孝,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人仅偎,你說(shuō)我怎么就攤上這事跨蟹。” “怎么了橘沥?”我有些...
    開(kāi)封第一講書(shū)人閱讀 157,570評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵窗轩,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我威恼,道長(zhǎng)品姓,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,535評(píng)論 1 284
  • 正文 為了忘掉前任箫措,我火速辦了婚禮腹备,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘斤蔓。我一直安慰自己植酥,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,650評(píng)論 6 386
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著友驮,像睡著了一般漂羊。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上卸留,一...
    開(kāi)封第一講書(shū)人閱讀 49,850評(píng)論 1 290
  • 那天走越,我揣著相機(jī)與錄音,去河邊找鬼耻瑟。 笑死旨指,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的喳整。 我是一名探鬼主播谆构,決...
    沈念sama閱讀 39,006評(píng)論 3 408
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼框都!你這毒婦竟也來(lái)了搬素?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 37,747評(píng)論 0 268
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤魏保,失蹤者是張志新(化名)和其女友劉穎熬尺,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體囱淋,經(jīng)...
    沈念sama閱讀 44,207評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡猪杭,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,536評(píng)論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了妥衣。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,683評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡戒傻,死狀恐怖税手,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情需纳,我是刑警寧澤芦倒,帶...
    沈念sama閱讀 34,342評(píng)論 4 330
  • 正文 年R本政府宣布,位于F島的核電站不翩,受9級(jí)特大地震影響兵扬,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜口蝠,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,964評(píng)論 3 315
  • 文/蒙蒙 一器钟、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧妙蔗,春花似錦傲霸、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,772評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)穆役。三九已至,卻和暖如春梳凛,著一層夾襖步出監(jiān)牢的瞬間耿币,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,004評(píng)論 1 266
  • 我被黑心中介騙來(lái)泰國(guó)打工韧拒, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留掰读,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,401評(píng)論 2 360
  • 正文 我出身青樓叭莫,卻偏偏與公主長(zhǎng)得像蹈集,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子雇初,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,566評(píng)論 2 349

推薦閱讀更多精彩內(nèi)容

  • IO多路復(fù)用 Redis客戶端對(duì)服務(wù)端的每次調(diào)用都經(jīng)歷了發(fā)送命令拢肆,執(zhí)行命令,返回結(jié)果三個(gè)過(guò)程靖诗。其中執(zhí)行命令階段郭怪,由...
    wh4763閱讀 2,472評(píng)論 0 4
  • Redis的高性能和他的事件模型是密不可分的,最大程度上利用了單線程刊橘、非阻塞IO模型來(lái)快速的處理請(qǐng)求(單線程處理多...
    鄒志全閱讀 455評(píng)論 0 2
  • 發(fā)布訂閱模式 列表的局限 通過(guò)隊(duì)列的rpush 和lpop 可以實(shí)現(xiàn)消息隊(duì)列(隊(duì)尾進(jìn)隊(duì)頭出)促绵,但是消費(fèi)者需要不停地...
    WEIJAVA閱讀 557評(píng)論 0 1
  • Redis原理篇 1.發(fā)布 訂閱模式 1.1列表 的局限 ? 前面我們說(shuō)通過(guò)隊(duì)列的 rpush 和 lpop ...
    Java小窩閱讀 347評(píng)論 0 0
  • 發(fā)布訂閱模式 列表的局限性 通過(guò)隊(duì)列的 rpush 和 lpop 可以實(shí)現(xiàn)消息隊(duì)列(隊(duì)尾進(jìn)隊(duì)頭出)攒庵,但是消費(fèi)者需要...
    vincent浩哥閱讀 235評(píng)論 0 0