Redis 单线程模型分析

JSON 2016-08-22 16:41:21 5512

Redis  采用自己实现的事件分离器,效率比较高,内部采用非阻塞的执行方式,吞吐能力比较大。

题外话,服务端编程的3大性能杀手:

1、大量线程导致的线程切换开销。

2、各种锁。

3、非必要的内存拷贝。

不过,因为一般的内存操作都是简单存取操作,线程占用时间相对较短,主要问题在io上,因此, redis  这种模型是合适的,但是如果某一个线程出现问题导致线程占用很长时间,那么 reids  单线程  模型效率可想而知。

总体来说快速的原因如下:

  • 绝大部分请求是纯粹的内存操作(非常快速)
  • 采用单线程,避免了不必要的上下文切换和竞争条件
  • 非阻塞IO

内部实现采用epoll ,采用了epoll  + 自己实现的简单的事件框架。epoll 中的读、写、关闭、连接都转化成了事件,然后利用epoll的多路复用特性,绝不在 IO 上浪费一点时间 。

这3个条件不是相互独立的,特别是第一条,如果请求都是耗时的,采用单线程吞吐量及性能可想而知了。应该说redis 为特殊的场景选择了合适的技术方案。

关于线程安全问题

redis实际上是采用了线程封闭的观念,把任务封闭在一个线程,自然避免了线程安全问题,不过对于需要依赖多个 redis 操作的复合操作来说,依然需要锁,而且有可能是分布式锁。

版权所属:SO JSON在线解析

原文地址:https://www.sojson.com/blog/107.html

转载时必须以链接形式注明原始出处及本声明。

本文主题:

如果本文对你有帮助,那么请你赞助我,让我更有激情的写下去,帮助更多的人。

关于作者
是谁,在敲打我窗。
相关文章
SEO实战分析-排名最近突然掉光了问题排查,几个大站关键词下降SEO问题分析
Java Redis线程池ShardedJedisPool 使用方法,Java Jedis连接池的使用
Java获取浏览器请求头(User-Agent),分析浏览器信息,系统信息的几种办法。
关于微信weixin.com,价值3000万域名腾讯仲裁“0元”得手实际分析
QUIC / HTTP3 协议详细分析讲解
JSOUP 教程,JSOUP爬虫教程,JSOUP超时分析与处理
TCP 和 UDP协议详细讲解,优缺点分析讲解
Redis教程,Redis集群搭建与Spring-data-redis的使用(Spring-data-redis使用篇)
Redis的理解,Redis是什么,Redis和Memcache谁快?
Shiro教程(四)Shiro + Redis配置
最新文章
XML内部实体和外部实体 146
Java面向对象编程概念 111
PHP回显语句 91
Linux—文件树 116
C语言while循环和do while循环 131
Python元组剖析 200
MySQL触发器教程 296
sql使用布尔运算符和关系运算符 241
C语言的变量和常量 296
PostgreSQL:数据库角色 123
最热文章
最新MyEclipse8.5注册码,有效期到2020年 (已经更新) 681984
苹果电脑Mac怎么恢复出厂系统?苹果系统怎么重装系统? 674712
免费天气API,全国天气 JSON API接口,可以获取五天的天气预报 602004
免费天气API,天气JSON API,不限次数获取十五天的天气预报 576769
Jackson 时间格式化,时间注解 @JsonFormat 用法、时差问题说明 552904
我为什么要选择RabbitMQ ,RabbitMQ简介,各种MQ选型对比 509353
Elasticsearch教程(四) elasticsearch head 插件安装和使用 479956
Jackson 美化输出JSON,优雅的输出JSON数据,格式化输出JSON数据... ... 264463
Java 信任所有SSL证书,HTTPS请求抛错,忽略证书请求完美解决 244246
Elasticsearch教程(一),全程直播(小白级别) 225520
支付扫码

所有赞助/开支都讲公开明细,用于网站维护:赞助名单查看

查看我的收藏

正在加载... ...