Redis使用单进程单线程方式的优缺点分析
[转] http://www.syyong.com/db/Redis-why-the-use-of-single-process-and-single-threaded-way-so-fast.html
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
最新文章
- Node基础篇(模块和NPM)
- 小议ARM寄存器
- C# 禁止程序多个实例运行
- ios 关于UIView 的multipleTouchEnabled 和 exclusiveTouch
- ThreadLocal工作原理
- int方法
- Android文件保存和读取
- Python装饰器与面向切面编程
- To Use Ubuntuubunt
- CF_91B
- Polyfills
- Sublime Text插件之Emmet
- php使用 _before_index() 来实现访问页面前,判断登录
- iframe参数
- Android中的WeakReference 弱引用
- 2018-2019-20175302实验二《Java面向对象程序设计》实验报告
- C_C++变量命名规则
- 第四次作业 重写equals方法
- JUnit4 基本用法实例
- C#/Net代码精简优化技巧
热门文章
- mysql进阶(十九)SQL语句如何精准查找某一时间段的数据
- 安全退出app,activoty栈管理
- Netflix Recommendations
- Android UI技巧(一)——Android中伸缩自如的9patch图片切法,没有美工自给自足
- 未能加载文件或程序集“file:///C:\Program Files (x86)\SAP BusinessObjects\Crystal Reports for .NET Framework 4.0
- ruby读取源代码自身的一种方法
- asp.net core选项配置的研究
- java main方法执行sql语句
- 深入浅出Java concurrent
- java 如何使的float保留2位或者多位小数 (转载)