Redis为什么使用单进程单线程方式也这么快
来源:互联网 发布:linux 颜色函数 编辑:程序博客网 时间:2024/06/06 01:16
Redis采用的是基于内存的采用的是单进程单线程模型的KV数据库,由C语言编写。官方提供的数据是可以达到100000+的qps。这个数据不比采用单进程多线程的同样基于内存的KV数据库Memcached差。
Redis快的主要原因是:
- 完全基于内存
- 数据结构简单,对数据操作也简单
- 使用多路 I/O 复用模型
第一、二点不细讲,主要围绕第三点采用多路 I/O 复用技术来展开。
多路 I/O 复用模型是利用select、poll、epoll可以同时监察多个流的 I/O 事件的能力,在空闲的时候,会把当前线程阻塞掉,当有一个或多个流有I/O事件时,就从阻塞态中唤醒,于是程序就会轮询一遍所有的流(epoll是只轮询那些真正发出了事件的流),并且只依次顺序的处理就绪的流,这种做法就避免了大量的无用操作。这里“多路”指的是多个网络连接,“复用”指的是复用同一个线程。采用多路 I/O 复用技术可以让单个线程高效的处理多个连接请求(尽量减少网络IO的时间消耗),且Redis在内存中操作数据的速度非常快(内存内的操作不会成为这里的性能瓶颈),主要以上两点造就了Redis具有很高的吞吐量。
和Memcached不同,Redis并没有直接使用Libevent,而是自己完成了一个非常轻量级的对select、epoll、evport、kqueue这些通用的接口的实现。在不同的系统调用选用适合的接口,linux下默认是epoll。因为Libevent比较重更通用代码量也就很庞大,拥有很多Redis用不上的功能,Redis为了追求“轻巧”并且去除依赖,就选择自己去封装了一套。
单进程单线程好处
- 代码更清晰,处理逻辑更简单
- 不用去考虑各种锁的问题,不存在加锁释放锁操作,没有因为可能出现死锁而导致的性能消耗
- 不存在多进程或者多线程导致的切换而消耗CPU
单进程单线程弊端
- 无法发挥多核CPU性能,不过可以通过在单机开多个Redis实例来完善;
其他一些优秀的开源软件采用的模型
- 多进程单线程模型:Nginx
- 单进程多线程模型:Memcached
参考链接
- https://en.wikipedia.org/wiki/Epoll
- https://segmentfault.com/a/1190000003063859#articleHeader6
- [http://www.ibm.com/developerworks/cn/linux/l-async/]http://www.ibm.com/developerworks/cn/linux/l-async/
- http://www.syyong.com/db/Redis-why-the-use-of-single-process-and-single-threaded-way-so-fast.html
阅读全文
0 0
- Redis为什么使用单进程单线程方式也这么快
- Redis 为什么使用单进程单线程方式也这么快
- Redis为什么使用单进程单线程方式也这么快
- Redis为什么使用单进程单线程方式也这么快?
- Redis为什么使用单进程单线程方式也这么快
- 10033---Redis 为什么使用单进程单线程方式也这么快
- Redis为什么使用单进程单线程方式也这么快
- Redis为什么使用单进程单线程方式也这么快
- Redis为什么使用单进程单线程方式也这么快
- Redis为什么使用单进程单线程方式也这么快
- 单进程单线程的Redis如何能够高并发,redis是个单线程的程序,为什么会这么快呢?
- Redis为什么这么快?
- Redis为什么是单线程
- 多线程为什么比单线程快呢?
- redis是个单线程的程序,为什么会这么快呢?
- 单进程单线程的Redis如何能够高并发
- QUIC和TCP--为什么多线程下载比单线程快
- 为什么GUI框架都使用单线程
- PyQt5学习教程2:给窗体加上图标
- Hibernate入门(一)
- win10下java环境变量设置(解决在cmd中运行javac、 java)
- Java集合之HashMap
- 电磁波的产生实验
- Redis为什么使用单进程单线程方式也这么快
- include和require区别
- 欧拉筛法 && 欧拉函数
- Git :git bash 出现vim的时候怎么退出
- Mr. Panda and Crystal HDU
- Android AM命令行启动程序的方法
- linux脚本明明定义了变量,但是引用的时候报错(原因:shell定义变量的时候,“等号”两边不要加空格)
- 欣的无线轮播!
- 创建一个用于上传文件的表单