Redis的线程模型

Redis为什么这么快?

很大原因上是因为Redis是一个事件驱动的服务端

 

Redis是一个事件驱动程序,服务器需要处理两类事件:
文件事件:Reactor模式,file event handler,使用IO多路复用同时监听多个socket请求,然后分发给不同的事件处理器
                    监听的accept,read,write,close操作都对应的文件事件就会产生,这时文件事件处理器就会调用socket之前关联好的事件处理器处理
                    虽然文件处理器是单线程的方式运行,但是通过IO多路复用来监听多个socket,文件事件处理器既实现了高性能的网络通信模型,又可以很好地与Redis服务器中其他同样以单线程方式运行的模块进行对接,这保持了Redis内部单线程设计的简单性。

                    select epoll kqueue等,Redis会根据不同操作系统选择不同的内核指令。

时间事件:时间事件一般是有两种,一种是周期的,一种是定时的

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值