Redis—高性能

1.Redis是基于内存存储,内存读写速度快。

Redis所有数据基本存储在内存中,读写不需要磁盘I/O,因此读写速度非常快。

官方数据,读速度110000次/s,写速度81000次/s。

支持动态调整最大内存maxmemory(缓存淘汰策略)和回收策略来管理内存。

2. 使用了非阻塞的IO多路复用机制

网络编程中的IO模型:阻塞IO、非阻塞IO、IO多路复用、信号驱动IO、异步IO

IO多路复用:通过一种机制(系统内核缓冲I/O数据),让单个进程可以监视多个文件描述符,一旦某个描述符就绪(一般是读就绪或写就绪),能够通知程序进行相应的读写操作。

Redis中事件处理机制采用单线程的Reactor模式。非阻塞IO在调用时不会导致进程因为等待IO事件而阻塞。

属于IO多路复用的一种常见模式。基于事件驱动,当有事件触发时,才会调用处理器进行数据处理。

底层采用epoll方式实现,相比于select与poll,最大的好处在于它不会随着监听文件描述符数目的增加而降低效率。

3.Redis对请求的处理是单线程的,避免线程切换的上下文切换和资源竞争问题

Redis4.0之前, 获取 (socket 读)→解析→执行→内容返回 (socket 写) 等客户端请求都是由一个线程处理,所以说是单线程模式运行;

4.0以后引入了惰性删除,由额外的线程执行,减少主线程卡顿;

6.0之后引入了多线程IO,多线程用来处理网络数据的读

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值