首页 > 文档
Redi是如何处理容易超时的系统调用的?
- 2024-05-30
- 1209 ℃
BIO 线程简介
Redis 在运行过程中,不可避免的会产生一些运行慢的、容易引发阻塞的任务,如将内核中的文件缓冲同步到磁盘中、关闭文件,都会引发短时阻塞,还有一些大 key,如一些元素数高达万级或更多的聚合类元素,在删除时,由于所有元素需要逐一释放回收,整个过程耗时也会比较长。而 Redis 的核心处理线程是单进程单线程模型,所有命令的接受与处理、数据淘汰等都在主线程中进行,这些任务处理速度非常快。如果核心单线程还要处理那些慢任务,在处理期间,势必会阻塞用户的正常请求,导致服务卡顿。为此,Redis 引入了 BIO 后台线程,专门处理那些慢任务,从而保证和提升主线程的处理能力。
Redis 的 BIO 线程采用生产者-消费者模型。主线程是生产者,生产各种慢任务,然后存放到任务队列中。BIO 线程是消费者,从队列获取任务并进行处理。如果生产者生产任务过快,队列可用于缓冲这些任务,避免负荷过载或数据丢失。如果消费者处理速度很快,处理完毕后就可以安静的等待,不增加额外的性能开销。再次,有新任务时,主线程通过条件变量来通知 BIO 线程,这样 BIO 线程就可以再次执行任务。
下一篇:Redi是如何进行主从复制的?
相关内容
ASP.NET 4权威指南
微服务架构(Micro Servi...
历年考研数学一真题
考研英语阅读方法论
供应商管理单据 - 企业...
2012年七月月教师招聘试题资料
缓存,你真的用对了吗?
缓存数据不一致和并发竞...
-
1~6年级小学生古诗词阶梯阅读训练
2024-07-13 1224
-
JBPM开发指南
2024-05-28 961
-
百川育人教师资格证考试资料
2024-08-19 1305
-
实战Java虚拟机 JVM故障诊断与性能优化
2024-05-28 1219
-
教师资格证考试作文【模板、范例、素材】
2024-08-19 1109
-
教师资格证考试-小学
2024-08-19 1451
-
完整学习MC协议及优化client访问
2024-05-24 1182
-
人工智能:改变世界,重建未来
2024-05-28 1464
-
三味·小学必背古诗文三四五六年级
2024-07-13 1298
-
如何为社交feed场景设计缓存体系
2024-05-24 1225
文章评论 (0)
- 这篇文章还没有收到评论,赶紧来抢沙发吧~


下载完整资料
点击分享文章