redis是单线程模型,为啥效率这么高,速度这么快?

  1. redis访问内存,数据库(mysql,oracle…)则是访问硬盘。
  2. redis核心功能,比数据库核心功能更简单。(数据库对于数据的插入,删除,查询这样的功能势必要花费更多的开销)

比如说针对插入删除,数据库中的各种约束,都会使数据库做额外的工作

  1. redis采取的单线模型,避免了一些不必要的线程竞争开销(redis的每个基本操作,都是短平快的,就是简单的操作一下内存数据,不是什么特别消耗CPU的操作,就算搞多个线程,也提升不大)
  2. redis在处理网络IO,使用了 epoll 这样的IO多路复用机制(IO多路复用机制:一个线程就可以管理多个socket(针对TCP来说,服务器这边每次要服务客户端,都需要给这个客户安排一个socket))

一个服务器服务多个客户端,同时就有多个socket
这些socket上不是无时不刻的在传输数据,大部分时间都是静默的,上面是没有数据需要传输
很多情况下,每个客户端和服务器之间的通信业没那么频繁(业务场景)

同一时间,只有少数的socket是活跃的

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值