Cache

Redis-都说它快为什么那么快

2019-04-04  本文已影响0人  夜阑人儿未静

现在主流NoSql要数Redis、Memcache,但仍有Redis一家独大的趋势,这可能也是因为Redis拥有强大的性能和主从丰富的数据类型

Memcache:代码层次类似Hash

Redis

为什么Redis能那么快?--10w+QPS

多路I/O复用模型 ( I/O multiplexing)

单个线程通过记录跟踪每一个Sock(I/O流)的状态(对应空管塔里面的Fight progress strip槽)来同时管理多个I/O流,可以是尽量多的提高服务器的吞吐能力。

解决了什么问题?

Redis是单线程的,所有操作都是顺序执行,当客户端连接较多时就会大大消耗服务器的资源,线程数量可能超过最大承受量

FD:File Descriptor,文件描述

一个打开的文件通过唯一的描述符进行引用,该描述符是打开文件的元数据到文件本身的映射


image.png

Redis采用的I/O多路复用函数:epoll/kqueue/evport/select

select

会修改入参的参数数组
多sock并不能确定那个通道返回
非线程安全
只能监听1024个链接

poll--select的优化版

去掉只能监听1024个链接的限制
不会修改参数数据
epoll--poll的升华版
线程安全
多sock链接可以精准返回
但只支持linux版本

kqueue--BSD版epoll

上一篇 下一篇

猜你喜欢

热点阅读