首页 > 文档
Redi是如何处理容易超时的系统调用的?
- 2024-05-30
- 1185 ℃
BIO 线程简介
Redis 在运行过程中,不可避免的会产生一些运行慢的、容易引发阻塞的任务,如将内核中的文件缓冲同步到磁盘中、关闭文件,都会引发短时阻塞,还有一些大 key,如一些元素数高达万级或更多的聚合类元素,在删除时,由于所有元素需要逐一释放回收,整个过程耗时也会比较长。而 Redis 的核心处理线程是单进程单线程模型,所有命令的接受与处理、数据淘汰等都在主线程中进行,这些任务处理速度非常快。如果核心单线程还要处理那些慢任务,在处理期间,势必会阻塞用户的正常请求,导致服务卡顿。为此,Redis 引入了 BIO 后台线程,专门处理那些慢任务,从而保证和提升主线程的处理能力。
Redis 的 BIO 线程采用生产者-消费者模型。主线程是生产者,生产各种慢任务,然后存放到任务队列中。BIO 线程是消费者,从队列获取任务并进行处理。如果生产者生产任务过快,队列可用于缓冲这些任务,避免负荷过载或数据丢失。如果消费者处理速度很快,处理完毕后就可以安静的等待,不增加额外的性能开销。再次,有新任务时,主线程通过条件变量来通知 BIO 线程,这样 BIO 线程就可以再次执行任务。
下一篇:Redi是如何进行主从复制的?
相关内容
像计算机科学家一样思考...
人工智能:改变世界,重建未来
中医综合历年真题
幼小初高教案设计范例
山香教育教师资格证考试资料
Linux程序设计
Redi是如何淘汰key的?
2012政治,思想品德专业...
-
设计足够可靠的分布式缓存体系,以满足大中型移动互联网系统的需要
2024-05-24 1183
-
JavaScript核心参考手册
2024-05-24 1302
-
伟哥的python私房菜
2024-05-24 1264
-
2025新文道余丙森 数学基础阶段测评
2024-08-19 1338
-
LAMP从入门到精通
2024-05-24 1246
-
响应式Web设计:HTML5和CSS3实战
2024-05-24 1021
-
张国静热点作文精讲班 热点作文课 考研英语
2024-08-20 2058
-
Java 8 实战
2024-05-28 1648
-
为海量计数场景设计缓存体系
2024-05-24 1155
-
根据业务来选择缓存模式和组件
2024-05-24 1290
文章评论 (0)
- 这篇文章还没有收到评论,赶紧来抢沙发吧~


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