Redis学习笔记八、Redis速度

Redis速度

1. Redis单线程模型

  我们都知道Redis是缓存数据库,数据存放在内存中,然而Redis却使用单线程模型设计,这与我们的固有观念相冲突,为什么单线程的程序可以经受住百万级并发的考验呢?

   事实上,Redis4.0之后的版本开始抛弃单线程模型这一设计,这样一来,原本使用单线程模型的Redis,也开始选择性的使用多线程模型。

1.1. Redis最初版本为什么使用单线程模型进行设计?

  1. Redis服务中运行的绝大多数操作的性能瓶颈都不是CPU。

  我们在一个普通的 Linux 服务器上启动 Redis 服务,它也能在 1s 的时间内处理 1,000,000 个用户请求。

  1. 使用单线程也可以并发处理客户端请求(IO多路复用)。
  2. 使用单线程模型更好维护。

1.2. 引入多线程

  Redis 在最新的几个版本中加入了一些可以被其他线程异步处理的删除操作,如 UNLINK、FLUSHALL ASYNC 和 FLUSHDB ASYNC,为什么这些删除操作需要通过多线程的方式异步处理?
  如果删除的键值占用的内存空间较小,可以用DEL命令删除一个键对应的值,这种情况下同步的删除这些键值也不会消耗太多时间。问题是Redis有些超大键值对占用空间非常大,几十MB甚至几百MB的数据不能在几毫秒的时间内处理完,此时Redis在释放内存空间上消耗较多时间,这些操作会阻塞待处理任务。

2. 总结

为什么Redis使用单线程,速度还会这么快呢?
因为Redis速度很快,快到没必要使用多线程。(1秒100万)

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值