首页 >Java >java教程 > 正文

redis为什么是单线程的

原创2020-04-29 14:05:1802233

Redis是单线程的,为上下文切换线程节省了大量时间。

为什么redis是单线程的?

一、官网解释

由于Redis是基于内存的操作,因此CPU并不是Redis的瓶颈。 Redis的瓶颈很可能是机器内存或网络带宽的大小。 既然单线程易于实现并且CPU不会成为瓶颈,那采用单线程解决方案是合乎逻辑的了。

(视频教程推荐:java视频

二、性能指标

普通笔记本可以轻松地每秒处理数十万个请求。

三、详细原因

1、不需要各种锁的性能消耗

Redis的数据结构并非全都是简单的键值(Key-Value),而是有复杂的结构,如列表(list)和哈希(hash)。 这些结构可以执行细粒度的操作,例如在长列表后面添加元素并将其添加到哈希(hash)或删除对象。

这些操作可能需要非常大量的锁,从而导致同步开销显著增加。 简而言之,在单线程的情况下,不需要考虑各种锁,没有锁释放操作,也没有由于可能的死锁而导致的性能消耗。

2、单线程多进程集群方案

单线程的功能实际上非常强大,每个内核的效率也很高。 与单线程相比,多线程自然可以具有更高的性能限制。 但是,在当今的计算环境中,甚至单机多线程限制通常也无法满足。需要进一步探索的是多服务器群集群方案,并且这些方案中的多线程技术仍然是不可用的。

所以单线程、多进程的集群不失为一个不错的解决方案。

推荐教程:java入门程序

以上就是redis为什么是单线程的的详细内容,更多请关注php中文网其它相关文章!

php中文网最新课程二维码

声明:本文原创发布php中文网,转载请注明出处,感谢您的尊重!如有疑问,请联系admin@php.cn处理

  • 相关标签:redis 单线程
  • 相关文章

    相关视频


    网友评论

    文明上网理性发言,请遵守 新闻评论服务协议

    我要评论
  • 专题推荐

    推荐视频教程
  • 极客学院Java视频教程极客学院Java视频教程
  • JAVA 初级入门视频教程JAVA 初级入门视频教程
  • 全面解析Java注解全面解析Java注解
  • 最新Java完整视频教程最新Java完整视频教程
  • 视频教程分类