成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

這個(gè)比 Redis 快 5 倍的中間件,怎么做到的?

開發(fā) 開發(fā)工具 Redis
今天給大家介紹的是KeyDB,KeyDB項(xiàng)目是從redis fork出來的分支。眾所周知redis是一個(gè)單線程的kv內(nèi)存存儲(chǔ)系統(tǒng),而KeyDB在100%兼容redis API的情況下將redis改造成多線程。上次也跟大家說了,redis多線程正式版將在今年底發(fā)布,大家拭目以待

 [[314345]] 

今天給大家介紹的是KeyDB,KeyDB項(xiàng)目是從redis fork出來的分支。眾所周知redis是一個(gè)單線程的kv內(nèi)存存儲(chǔ)系統(tǒng),而KeyDB在100%兼容redis API的情況下將redis改造成多線程。

上次也跟大家說了,redis多線程正式版將在今年底發(fā)布,大家拭目以待

線程模型

KeyDB將redis原來的主線程拆分成了主線程和worker線程。每個(gè)worker線程都是io線程,負(fù)責(zé)監(jiān)聽端口,accept請求,讀取數(shù)據(jù)和解析協(xié)議。如圖所示:  

 

KeyDB使用了SO_REUSEPORT特性,多個(gè)線程可以綁定監(jiān)聽同個(gè)端口。

每個(gè)worker線程做了cpu綁核,讀取數(shù)據(jù)也使用了SO_INCOMING_CPU特性,指定cpu接收數(shù)據(jù)。

解析協(xié)議之后每個(gè)線程都會(huì)去操作內(nèi)存中的數(shù)據(jù),由一把全局鎖來控制多線程訪問內(nèi)存數(shù)據(jù)。

主線程其實(shí)也是一個(gè)worker線程,包括了worker線程的工作內(nèi)容,同時(shí)也包括只有主線程才可以完成的工作內(nèi)容。在worker線程數(shù)組中下標(biāo)為0的就是主線程。

主線程的主要工作在實(shí)現(xiàn)serverCron,包括:

  • 處理統(tǒng)計(jì)
  • 客戶端鏈接管理
  • db數(shù)據(jù)的resize和reshard
  • 處理aof
  • replication主備同步
  • cluster模式下的任務(wù)

鏈接管理

在redis中所有鏈接管理都是在一個(gè)線程中完成的。在KeyDB的設(shè)計(jì)中,每個(gè)worker線程負(fù)責(zé)一組鏈接,所有的鏈接插入到本線程的鏈接列表中維護(hù)。鏈接的產(chǎn)生、工作、銷毀必須在同個(gè)線程中。每個(gè)鏈接新增一個(gè)字段。

  1. int iel; /* the event loop index we're registered with */ 

用來表示鏈接屬于哪個(gè)線程接管。

KeyDB維護(hù)了三個(gè)關(guān)鍵的數(shù)據(jù)結(jié)構(gòu)做鏈接管理:

  • clients_pending_write:線程專屬的鏈表,維護(hù)同步給客戶鏈接發(fā)送數(shù)據(jù)的隊(duì)列
  • clients_pending_asyncwrite:線程專屬的鏈表,維護(hù)異步給客戶鏈接發(fā)送數(shù)據(jù)的隊(duì)列
  • clients_to_close:全局鏈表,維護(hù)需要異步關(guān)閉的客戶鏈接

分成同步和異步兩個(gè)隊(duì)列,是因?yàn)閞edis有些聯(lián)動(dòng)api,比如pub/sub,pub之后需要給sub的客戶端發(fā)送消息,pub執(zhí)行的線程和sub的客戶端所在線程不是同一個(gè)線程,為了處理這種情況,KeyDB將需要給非本線程的客戶端發(fā)送數(shù)據(jù)維護(hù)在異步隊(duì)列中。

同步發(fā)送的邏輯比較簡單,都是在本線程中完成,以下圖來說明如何同步給客戶端發(fā)送數(shù)據(jù): 

 

如上文所提到的,一個(gè)鏈接的創(chuàng)建、接收數(shù)據(jù)、發(fā)送數(shù)據(jù)、釋放鏈接都必須在同個(gè)線程執(zhí)行。異步發(fā)送涉及到兩個(gè)線程之間的交互。KeyDB通過管道在兩個(gè)線程中傳遞消息: 

  1. int fdCmdWrite; //寫管道 
  2. int fdCmdRead; //讀管道 

本地線程需要異步發(fā)送數(shù)據(jù)時(shí),先檢查client是否屬于本地線程,非本地線程獲取到client專屬的線程ID,之后給專屬的線程管到發(fā)送AE_ASYNC_OP::CreateFileEvent的操作,要求添加寫socket事件。專屬線程在處理管道消息時(shí)將對應(yīng)的請求添加到寫事件中,如圖所示:

 

redis有些關(guān)閉客戶端的請求并非完全是在鏈接所在的線程執(zhí)行關(guān)閉,所以在這里維護(hù)了一個(gè)全局的異步關(guān)閉鏈表。  

 

鎖機(jī)制

KeyDB實(shí)現(xiàn)了一套類似spinlock的鎖機(jī)制,稱之為fastlock。

fastlock的主要數(shù)據(jù)結(jié)構(gòu)有:

  1. struct ticket 
  2.  uint16_t m_active; //解鎖+1 
  3.  uint16_t m_avail; //加鎖+1 
  4. }; 
  5. struct fastlock 
  6.  volatile struct ticket m_ticket; 
  7.  volatile int m_pidOwner; //當(dāng)前解鎖的線程id 
  8.  volatile int m_depth; //當(dāng)前線程重復(fù)加鎖的次數(shù) 
  9. }; 

使用原子操作__atomic_load_2,__atomic_fetch_add,__atomic_compare_exchange來通過比較m_active=m_avail判斷是否可以獲取鎖。

fastlock提供了兩種獲取鎖的方式:

  • try_lock:一次獲取失敗,直接返回
  • lock:忙等,每1024 * 1024次忙等后使用sched_yield 主動(dòng)交出cpu,挪到cpu的任務(wù)末尾等待執(zhí)行。

在KeyDB中將try_lock和事件結(jié)合起來,來避免忙等的情況發(fā)生。每個(gè)客戶端有一個(gè)專屬的lock,在讀取客戶端數(shù)據(jù)之前會(huì)先嘗試加鎖,如果失敗,則退出,因?yàn)閿?shù)據(jù)還未讀取,所以在下個(gè)epoll_wait處理事件循環(huán)中可以再次處理。

 

Active-Replica

KeyDB實(shí)現(xiàn)了多活的機(jī)制,每個(gè)replica可設(shè)置成可寫非只讀,replica之間互相同步數(shù)據(jù)。主要特性有:

  • 每個(gè)replica有個(gè)uuid標(biāo)志,用來去除環(huán)形復(fù)制
  • 新增加rreplay API,將增量命令打包成rreplay命令,帶上本地的uuid
  • key,value加上時(shí)間戳版本號,作為沖突校驗(yàn),如果本地有相同的key且時(shí)間戳版本號大于同步過來的數(shù)據(jù),新寫入失敗。采用當(dāng)前時(shí)間戳向左移20位,再加上后44位自增的方式來獲取key的時(shí)間戳版本號。 

 

責(zé)任編輯:武曉燕 來源: Tomcat那些事兒
相關(guān)推薦

2019-10-14 09:50:52

KeyDBRedis中間件

2021-07-04 14:20:16

Redis中間件高性能

2024-03-08 07:58:13

QPShttpsync

2016-11-11 21:00:46

中間件

2024-12-09 00:00:15

Gin框架中間件

2015-02-07 21:52:45

PaaS中間件

2013-03-13 10:37:22

中間件Windows

2018-05-02 16:23:24

中間件RPC容器

2021-02-04 08:25:50

授權(quán)策略NET 5

2022-10-27 08:31:31

架構(gòu)

2018-03-19 15:26:23

數(shù)據(jù)庫Redis中間件

2022-11-18 07:54:02

Go中間件項(xiàng)目

2022-10-18 23:03:53

mysql架構(gòu)slave

2011-05-24 15:10:48

2021-02-11 08:21:02

中間件開發(fā)CRUD

2021-07-28 14:20:13

正則PythonFlashText

2024-03-26 10:13:54

日志引擎SigLens

2021-06-15 10:01:02

應(yīng)用系統(tǒng)軟件

2022-02-13 23:04:28

RedisRabbitMQKafka

2012-09-13 15:48:16

云計(jì)算中間件
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 国产免费一区二区三区网站免费 | 麻豆视频在线看 | 亚洲免费片 | 午夜看片 | 精品在线观看一区二区 | 91亚洲精 | 啪啪毛片 | 久久久亚洲成人 | 国产精品久久精品 | 精品国产一区二区国模嫣然 | 亚洲一区中文 | 91久久国产综合久久 | 久久久av中文字幕 | 国产日韩一区二区三区 | 中文精品一区二区 | 黄网站免费在线看 | 夜夜av| 在线观看视频中文字幕 | 日日摸夜夜爽人人添av | 日本成人在线观看网站 | 毛片免费在线观看 | 少妇精品亚洲一区二区成人 | 国产欧美日韩综合精品一区二区 | 国产精品国产三级国产aⅴ中文 | 黄色一级网 | 国产黄色小视频 | 日韩国产精品一区二区三区 | 天天综合久久网 | 精品久草 | 国产日产欧产精品精品推荐蛮挑 | 久久久久久久国产精品 | 日韩久久久一区二区 | 91麻豆精品国产91久久久久久久久 | 精品乱子伦一区二区三区 | 日本视频免费 | 亚洲国产高清在线 | 中文字幕欧美一区 | 久久躁日日躁aaaaxxxx | 久久国产成人精品国产成人亚洲 | 人操人免费视频 | 日韩高清在线观看 |