博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Redis 为什么是单线程?
阅读量:3926 次
发布时间:2019-05-23

本文共 527 字,大约阅读时间需要 1 分钟。

Redis单线程解析

redis是单线程,线程安全

redis可以能够快速执行的原因:

(1) 绝大部分请求是纯粹的内存操作(非常快速)

(2) 采用单线程,避免了不必要的上下文切换和竞争条件
(3) 非阻塞IO - IO多路复用(IO 多路复用是什么意思?)

IO多路复用中有三种方式:select,poll,epoll。需要注意的是,select,poll是线程不安全的,epoll是线程安全的

redis内部实现采用epoll,采用了epoll+自己实现的简单的事件框架。epoll中的读、写、关闭、连接都转化成了事件,然后利用epoll的多路复用特性,绝不在io上浪费一点时间,这3个条件不是相互独立的,特别是第一条,如果请求都是耗时的,采用单线程吞吐量及性能可想而知了。应该说redis为特殊的场景选择了合适的技术方案。

在这里插入图片描述在这里插入图片描述
根据上述说法是redis中io多路复用器模块是单线程执行,事件处理器也是单线程执行,两个线程不一样

依靠队列保证顺序。这样的好处是io多路复用线程接受和响应 和事件处理之间不会来回切换上下文进行处理

结论 单线程只是针对redis中的模块来说 比如 接受请求和响应是单线程,处理事件也是单线程 。但是线程不是同一个

参考:

转载地址:http://bdugn.baihongyu.com/

你可能感兴趣的文章
codeforces 395 B1. iwiwi(待续)
查看>>
hdu 4283 You Are the One(区间DP)题目转换难,状态难,。。。
查看>>
poj 2299 Ultra-QuickSort(树状数组+离散化的题目)据说是简单题,不过还是觉得好难。。。
查看>>
codeforces 397B. On Corruption and Numbers
查看>>
SqlMapConfig.xml中的setting属性设置
查看>>
hdu 3172 Virtual Friends(简单并查集)
查看>>
find the most comfortable road(并查集加贪心)
查看>>
Junk-Mail Filter(并查集,删除结点,虚父节点)
查看>>
A Bug's Life (并查集,同性恋问题,注意处理性别)
查看>>
选美大赛(线段树)
查看>>
超级玛丽(简单模拟超时)
查看>>
BlueZ介绍:
查看>>
关于socket()(转)
查看>>
Linux系统调用之send/sendto/sendmsg函数解析
查看>>
蓝牙传关文件
查看>>
主控制器接口
查看>>
#define 的特别用法
查看>>
obex_io.c
查看>>
Linux程序开发基础概念
查看>>
Linux系统环境变量详谈
查看>>