当前位置: 首页 > news >正文

Redis 服务器线程与事件循环解析

文章目录

  • 事件循环线程
  • 事件循环相关源码文件
  • 事件主循环机制
  • 睡眠钩子(Hooks)机制
  • 睡眠钩子的实现
  • Epoll 实战:键盘输入监听

事件循环线程

众所周知,Redis 服务器启动时会开启六个线程:

  1. Thread-1 [redis-server](主线程)
  2. Thread-2 [bio_close_file](后台 I/O 线程 - 文件关闭)
  3. Thread-3 [bio_aof](后台 I/O 线程 - AOF 刷盘)
  4. Thread-4 [bio_lazy_free](后台 I/O 线程 - 惰性删除)
  5. Thread-5 [jemalloc_bg_thd](内存整理线程)
  6. Thread-6 [jemalloc_bg_thd](内存整理线程)

而事件循环则位于Thread-1 [redis-server](主线程)中。

事件循环相关源码文件

源码文件说明
ae.c事件驱动循环核心
ae_epoll.cLinux 系统实现(epoll)
ae_evport.cSolaris 专用
ae_kqueue.cmacOS 专用
ae_select.c老旧 Linux 或兼容模式使用
ebuckets.c事件桶管理
eventnotifier.c事件通讯器

事件主循环机制

Redis 的事件主循环位于ae.c中,核心代码如下:

voidaeMain(aeEventLoop*eventLoop){eventLoop->stop=0;while(!eventLoop->stop){aeProcessEvents(eventLoop,AE_ALL_EVENTS|AE_CALL_BEFORE_SLEEP|AE_CALL_AFTER_SLEEP);}}

但死循环非常消耗 CPU,Redis 是如何让线程进入睡眠等待的呢?

真正的“睡眠”发生在aeApiPoll中,其核心是调用系统epoll_wait

staticintaeApiPoll(aeEventLoop*eventLoop,structtimeval*tvp){aeApiState*state=eventLoop->apidata;intretval,numevents=0;retval=epoll_wait(state->epfd,state->events,eventLoop->setsize,tvp?(tvp->tv_sec*1000+(tvp->tv_usec+999)/1000):-1);if(retval>0){intj;numevents=retval;for(j=0;j<numevents;j++){intmask=0;structepoll_event*e=state->events+j;if(e->events&EPOLLIN)mask|=AE_READABLE;if(e->events&EPOLLOUT)mask|=AE_WRITABLE;if(e->events&EPOLLERR)mask|=AE_WRITABLE|AE_READABLE;if(e->events&EPOLLHUP)mask|=AE_WRITABLE|AE_READABLE;eventLoop->fired[j].fd=e->data.fd;eventLoop->fired[j].mask=mask;}}elseif(retval==-1&&errno!=EINTR){panic("aeApiPoll: epoll_wait, %s",strerror(errno));}returnnumevents;}
  • epoll_wait就是实现“睡眠”的系统调用。
  • 当没有事件时,线程在此阻塞,不消耗 CPU。

睡眠钩子(Hooks)机制

为了在睡眠前后执行必要逻辑,Redis 提供了钩子函数。

initServer函数中注册:

aeSetBeforeSleepProc(server.el, beforeSleep); aeSetAfterSleepProc(server.el, afterSleep);

aeProcessEvents中调用:

if (eventLoop->beforesleep != NULL && (flags & AE_CALL_BEFORE_SLEEP)) eventLoop->beforesleep(eventLoop); if (eventLoop->aftersleep != NULL && flags & AE_CALL_AFTER_SLEEP) eventLoop->aftersleep(eventLoop);

作用

  • beforeSleep:处理客户端写回、检查阻塞超时、计算下一次epoll_wait的超时时间等。
  • afterSleep:清理或重置休眠期间的状态。

这些钩子避免了无限循环中 CPU 空转,是 Redis 高效的核心之一。


睡眠钩子的实现

beforeSleep钩子和afterSleep钩子的实现都在server.c中,分别是void beforeSleep(struct aeEventLoop *eventLoop)和void afterSleep(struct aeEventLoop *eventLoop)。
实现上beforeSleep远比afterSleep复杂。

Epoll 实战:键盘输入监听

我们可以编写代码练习epoll的使用,模拟 Redis 的事件监听机制。

#include<stdio.h>#include<stdlib.h>#include<sys/epoll.h>#include<unistd.h>// 简单的错误处理宏#definepanic(fmt,...)\do{fprintf(stderr,"FATAL ERROR: "fmt" (%s:%d)\n",##__VA_ARGS__,__FILE__,__LINE__);\exit(1);}while(0)typedefstructepoll_eventEvent;intmain(void){intepfd=epoll_create(1);if(epfd<0){panic("epoll_create");return1;}// 设置监听标准输入(键盘)Event ev;ev.events=EPOLLIN;ev.data.fd=STDIN_FILENO;if(epoll_ctl(epfd,EPOLL_CTL_ADD,STDIN_FILENO,&ev)<0){panic("epoll_ctl");return1;}Event events[10];charbuf[1024];// 事件循环for(;;){intnfds=epoll_wait(epfd,events,10,-1);if(nfds<0){panic("epoll_wait");return1;}// 处理就绪事件for(inti=0;i<nfds;i++){if(events[i].data.fd==STDIN_FILENO){intnread=read(STDIN_FILENO,buf,sizeof(buf));if(nread>0){buf[nread]='\0';printf("键盘输入: %s",buf);}}}}close(epfd);return0;}

编译运行

gcc epoll_test.c -o epoll_test ./epoll_test

这个程序会在没有输入时“睡眠”,输入内容按回车后被唤醒,完美模拟了 Redis 的事件处理模型。

http://www.jsqmd.com/news/322173/

相关文章:

  • 烘箱市场2026年新格局:哪些品牌脱颖而出,真空烘箱/真空干燥箱/高温电热鼓风干燥箱/三维混合机,烘箱实力厂家推荐排行
  • KO细胞的应用有哪些?除了基因功能研究,还用于疾病机制、靶点验证与抗体筛选
  • 沙特阿拉伯将于2026年4月22日至23日主办世界经济论坛全球合作与增长会议:建立共识,重振增长
  • 本年度必看!最佳信息登记二维码推荐榜单
  • 黑芝麻智能华山A2000 BaRT工具链:全场景智驾模型高效编译与部署
  • I/O重定向程序
  • 使用C#调用Yolo26模型的ONNX
  • 数据库分库分表策略:水平拆分与垂直拆分指南
  • 分布式系统面试必问:CAP理论与BASE理论的核心区别与应用场景
  • 廊坊英语雅思培训机构推荐,2026权威测评出国雅思辅导机构口碑榜
  • 铜线绕桩防虫害古代园艺
  • 2026防水材料选购指南:防水涂料厂家排名?全屋卫士成优选
  • Adobe Flash Player 一款轻量级浏览器插件
  • 自动化测试框架:Selenium与Puppeteer选型建议
  • 车灯控制与报警系统设计
  • springer期刊提供的LaTex模板参考文献问题
  • 无人机飞行姿态稳不稳?关键看这个MEMS IMU
  • 2026年高端木作终极选型指南:TOP5预算60万+工艺落地与交付确定性融合的别墅大平层深度测评
  • AI 办公提效的关键是什么?5 个可复用工作流(含 Prompt 模板)
  • 2026气体检测仪市场行情及五大品牌盘点
  • 超声波深度测量仪设计与实现
  • 多项目并行管理四步法:从混沌到有序的系统化解决方案
  • 生成式AI催生GEO优化,如何成为其内容权威信源?
  • 安徽省管理咨询公司前十推荐:助力企业升级转型的专业智囊团
  • 元空AI+Clawdbot:7×24 AI办公智能体新形态详解(长期上下文/自动化任务/工具粘合)
  • 2026年高端木作推荐:真实案例可核验与效果参考路径融合的看图选型深度解析
  • 超声波测距设计研究
  • SCI制图——Origin信号处理:FFT变换与滤波降噪
  • 2026年市面上靠谱的气动吊定做厂家口碑排行榜单,0.5吨气动葫芦/10吨气动葫芦/风动葫芦,气动吊实力厂家哪家权威
  • Avalonia FuncValueConverter的使用