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

Redis Plus 來了,性能炸裂!

數據庫 Redis
KeyDB項目是從redis fork出來的分支。眾所周知redis是一個單線程的kv內存存儲系統,而KeyDB在100%兼容Redis API的情況下將redis改造成多線程。

KeyDB項目是從Redis fork出來的分支。眾所周知Redis是一個單線程的kv內存存儲系統,而KeyDB在100%兼容Redis API的情況下將Redis改造成多線程。

線程模型

KeyDB將Redis原來的主線程拆分成了主線程和worker線程。每個worker線程都是io線程,負責監聽端口,accept請求,讀取數據和解析協議。如圖所示:

KeyDB使用了SO_REUSEPORT特性,多個線程可以綁定監聽同個端口。

每個worker線程做了cpu綁核,讀取數據也使用了SO_INCOMING_CPU特性,指定cpu接收數據。

解析協議之后每個線程都會去操作內存中的數據,由一把全局鎖來控制多線程訪問內存數據。

主線程其實也是一個worker線程,包括了worker線程的工作內容,同時也包括只有主線程才可以完成的工作內容。在worker線程數組中下標為0的就是主線程。

主線程的主要工作在實現serverCron,包括:

  • 處理統計
  • 客戶端鏈接管理
  • db數據的resize和reshard
  • 處理aof
  • replication主備同步
  • cluster模式下的任務

鏈接管理

在Redis中所有鏈接管理都是在一個線程中完成的。在KeyDB的設計中,每個worker線程負責一組鏈接,所有的鏈接插入到本線程的鏈接列表中維護。鏈接的產生、工作、銷毀必須在同個線程中。每個鏈接新增一個字段。

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

用來表示鏈接屬于哪個線程接管。

KeyDB維護了三個關鍵的數據結構做鏈接管理:

  • clients_pending_write:線程專屬的鏈表,維護同步給客戶鏈接發送數據的隊列;
  • clients_pending_asyncwrite:線程專屬的鏈表,維護異步給客戶鏈接發送數據的隊列;
  • clients_to_close:全局鏈表,維護需要異步關閉的客戶鏈接。

分成同步和異步兩個隊列,是因為redis有些聯動api,比如pub/sub,pub之后需要給sub的客戶端發送消息,pub執行的線程和sub的客戶端所在線程不是同一個線程,為了處理這種情況,KeyDB將需要給非本線程的客戶端發送數據維護在異步隊列中。同步發送的邏輯比較簡單,都是在本線程中完成,以下圖來說明如何同步給客戶端發送數據:

如上文所提到的,一個鏈接的創建、接收數據、發送數據、釋放鏈接都必須在同個線程執行。異步發送涉及到兩個線程之間的交互。KeyDB通過管道在兩個線程中傳遞消息:

int fdCmdWrite; //寫管道
int fdCmdRead; //讀管道

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

Redis有些關閉客戶端的請求并非完全是在鏈接所在的線程執行關閉,所以在這里維護了一個全局的異步關閉鏈表。

鎖機制

KeyDB實現了一套類似spinlock的鎖機制,稱之為fastlock。

fastlock的主要數據結構有:

struct ticket
{
    uint16_t m_active;  //解鎖+1
    uint16_t m_avail;  //加鎖+1
};
struct fastlock
{
    volatile struct ticket m_ticket;

    volatile int m_pidOwner; //當前解鎖的線程id
    volatile int m_depth; //當前線程重復加鎖的次數
};

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

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

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

在KeyDB中將try_lock和事件結合起來,來避免忙等的情況發生。每個客戶端有一個專屬的lock,在讀取客戶端數據之前會先嘗試加鎖,如果失敗,則退出,因為數據還未讀取,所以在下個epoll_wait處理事件循環中可以再次處理。

Active-Replica

KeyDB實現了多活的機制,每個replica可設置成可寫非只讀,replica之間互相同步數據。主要特性有:

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

項目地址:https://github.com/JohnSully/KeyDB

責任編輯:趙寧寧 來源: 碼猿技術專欄
相關推薦

2025-05-26 04:10:00

2025-02-24 09:10:00

前端VueDOM

2025-06-18 10:02:06

H3前端開發

2025-04-07 03:00:00

SpringBoot數據庫

2023-11-09 08:46:24

2025-05-06 13:42:16

微軟Phi-4模型

2025-02-17 02:00:00

Vue性能Vapor

2025-02-12 09:04:20

2022-06-27 09:48:15

H5移動互聯網頁面性能

2025-02-25 09:44:27

PreactReact前端

2025-07-17 13:05:35

2025-12-15 01:00:00

2016-10-11 11:48:54

iPhone 7

2016-07-29 00:53:58

云計算高性能計算市場

2021-11-29 09:48:35

Redis 對象映射

2022-09-12 08:01:21

GreatSQLMySQL性能

2023-03-13 00:01:10

數據庫性能MySQL

2023-09-22 11:48:37

2024-03-12 09:47:10

Redis數據庫
點贊
收藏

51CTO技術棧公眾號

日本福利片高清在线观看| 99视频免费在线观看| 天堂资源在线中文精品| 欧美日韩成人在线视频| 91福利在线免费| 欧美性一级生活| 自拍av在线| 亚洲人精品午夜| 无码aⅴ精品一区二区三区浪潮| 精品亚洲aⅴ乱码一区二区三区| 国产精品乱子乱xxxx| 成人激情免费视频| 热草久综合在线| aaa国产精品| 久久久久这里只有精品| 在这里有精品| 久久久天堂国产精品女人| 久久综合给合| 久久久久一本一区二区青青蜜月| 国产精品3区| 久久久久亚洲精品国产| 老司机凹凸av亚洲导航| 欧美壮男野外gaytube| 欧美三级电影在线| 国产精品视频久久久久| 四虎成人av| 亚洲va欧美va在线观看| 亚洲欧美伊人| 欧美污视频久久久| 日本色综合中文字幕| 综合国产精品久久久| 国产精品一区不卡| 欧美性久久久久| 亚洲欧美日韩中文播放| 在线看片免费人成视久网| 在线看日本不卡| 影音先锋在线播放| 丝袜亚洲欧美日韩综合| 国产乱人伦丫前精品视频| 国产成人精品在线| 怡红院精品视频在线观看极品| 欧美另类一区| 国产不卡免费视频| 欧美一级特黄a| 亚洲色欲色欲www在线观看| 免费看成年人视频在线观看| 在线免费观看日韩欧美| 国产传媒在线观看| 欧美老女人性视频| 亚洲精品网址| 色乱码一区二区三在线看| av福利精品导航| 嫩草影院官网| 91精品国产综合久久精品麻豆| 麻豆视频在线看| 午夜精品一区二区三区视频免费看 | 日韩欧美久久一区| 午夜精品久久久久久久久久蜜桃| 欧美二区在线播放| 亚洲成人资源| 人人妻人人添人人爽欧美一区| 亚洲二区在线视频| 午夜伦理福利在线| 国产精品亚洲片夜色在线| 久久精品国产成人一区二区三区| 少妇一级淫免费放| 欧美zozo另类异族| 欧美女优在线视频| 成人手机视频在线| 亚洲成av人在线观看| 忘忧草在线影院两性视频| 国产成人啪精品视频免费网| 免费高清在线一区| 人与动性xxxxx免费视频| 日韩精品中文字幕在线| 国内精品久久久久久久久电影网| 日本不卡一区| 亚洲品质自拍视频| 国产色播av在线| 国产日本欧美在线观看| www.成人在线| 黄视频网站在线看| 日韩免费观看网站| 成人手机在线视频| 麻豆网在线观看| 日本精品视频网站| 国产成a人亚洲精| 成人免费看片| 91网站在线免费观看| 欧美激情一区二区| 男女羞羞在线观看| 韩国成人一区| 性感美女极品91精品| 亚洲三区欧美一区国产二区| 亚洲一区美女| 欧美日韩成人综合在线一区二区 | 亚洲欧美激情在线视频| 亚洲精品国产成人影院| 日韩精品一区二区三区色欲av| 欧美一区二区三区四区视频| 成人网18免费网站| 欧美一级黄色影院| 亚洲性线免费观看视频成熟| 国产亚洲欧洲| 欧美日韩激情视频一区二区三区| 午夜精品在线观看| xnxx国产精品| 国产精品极品美女在线观看| 国模精品一区二区三区| 天天色天天操综合| 国产99久久| 国产乱xxⅹxx国语对白| 久久综合久久美利坚合众国| 精品一区二区三区免费| 尤物在线网址| 日本精品国语自产拍在线观看| 欧美三级电影在线观看| 国产精品久久久久久久久久10秀| 亚洲一区在线不卡| 久久99国产精品久久久久久久久| 成人激情免费网站| 黄色亚洲网站| 久久av秘一区二区三区| 精品国产一区二区三区不卡| 亚洲三级影院| 黄网址在线观看| 久久精品国产99精品国产亚洲性色| 天天亚洲美女在线视频| 日韩在线二区| 欧洲一区av| 国产自产精品| 欧美成人一级视频| 久久爱www久久做| 日韩不卡免费高清视频| 国产freexxxx性播放麻豆 | 国产精品色婷婷视频| 亚洲精品国产无天堂网2021 | 亚洲丝袜一区在线| 国产精品99久久久久久久vr | 午夜免费福利小电影| 中文字幕综合在线| 91色在线porny| 国产精品任我爽爆在线播放| 婷婷色播视频| 91精品国产综合久久久久久蜜臀 | 亚洲网站在线播放| 99精品国产一区二区三区不卡| 二区三区精品| 成人综合网址| 国产欧美精品日韩| 欧美色综合影院| 老司机午夜精品| 国产精品美女久久久久| 国产成人综合美国十次| 成人黄色大片在线免费观看| 欧美视频中文字幕| 精久久久久久久久久久| 日本伊人久久| 一二三区在线视频| 视频一区二区在线| 九九九久久国产免费| 亚洲大片在线观看| 久久精品动漫| 精品亚洲a∨一区二区三区18| 高清孕妇孕交╳╳交| 国产高清精品一区二区三区| 亚洲第一中文字幕| 中文字幕乱码亚洲精品一区 | 欧美一区二区三区图| 在线观看视频91| 奇米精品一区二区三区在线观看 | 色综合久久中文字幕综合网小说| 亚洲三级在线观看| 亚洲三级毛片| 免费一区二区三区四区| 高清国语自产在线观看| 欧美91福利在线观看| 在线观看国产视频一二三| 97超碰人人看人人| 亚洲少妇中文在线| 亚洲成人综合网站| 日韩精品国产精品| 日本精品国产| 日韩伦理在线观看| 亚洲人成无码www久久久| 91免费版黄色| 揄拍成人国产精品视频| 亚洲国产综合人成综合网站| 免费看欧美女人艹b| 欧美大片网址| av资源新版天堂在线| 成人av视屏| 伊人色综合影院| 国产一区二区在线免费| 国产丝袜精品视频| 午夜精品久久久久久不卡8050| 国产中文一区二区三区| 五月激情久久久| 亚洲午夜免费| 成人av免费电影网站|