美文网首页Cache
Redis-都说它快为什么那么快

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

作者: 夜阑人儿未静 | 来源:发表于2019-04-04 23:10 被阅读0次

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

Memcache:代码层次类似Hash

  • 支持简单数据类型
  • 不支持数据持久化存储
  • 不支持主从
  • 不支持分片

Redis

  • 数据类型丰富
  • 支持数据磁盘持久化存储
  • 支持主从
  • 支持分片

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

  • 完全基于内存,绝大部分请求是纯粹的内存操作,执行效率高
  • 数据结构简单,对数据操作也简单
  • 采用单线程,单线程也能处理高并发,想多核也可以启动多实例
  • 使用多路I/O复用模型,非阻塞IO

多路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

  • 因地制宜
  • 优先选择时间复杂度为O(1)的I/O多路复用函数作为底层实现
  • 以时间复杂度为O(n)的select作为保底
  • 基于reactor设计模式监听I/O事件

select

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

poll--select的优化版

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

kqueue--BSD版epoll

相关文章

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

    现在主流NoSql要数Redis、Memcache,但仍有Redis一家独大的趋势,这可能也是因为Redis拥有强...

  • 那些生活中的理解偏差(NO.11)……

    NO.1 读书快,是因为手眼速度快——其实,是因为理解能力强。快速输入,也是有效输入。要不,手眼那么快为了干嘛? ...

  • 看好书,好好看书,把书看透

    在当今这个追求快速的时代,一切都以快为标准,工作上以快为标准,生活里以快为标准,仿佛当今社会就成了一个快鱼吃慢鱼的...

  • redis-为什么速度快?

    基于内存 单线程 resp 协议 :协议格式:*311jamesLength$13

  • 情绪失控的那么快为什么?

    我朝那小人儿发了脾气。 原因挺复杂的,又挺可笑的,羞于提起。 我多疑又吝啬。暴躁又懦弱。把宝贵的时间用在怎么都不会...

  • 一晃三年了

    离上次注册简书写作已是三年了,三年三个365天,都恍如昨日,说它快,快的好像什么都没有发生,说它慢,好像是有说不完...

  • 使用过Redis,我竟然还不知道Rdb

    使用过Redis,那就先说说使用过那些场景吧 字符串缓存 //举例$redis->set();$redis->ge...

  • Redis学习之路(12)- 杂记

    Redis-过期删除策略 Redis-删除策略: 1、定时删除:对内存友好, 但是占用cpu 2、惰性删除:对cp...

  • 时间说它都记得

    一直有人告诉我 说时间是个好东西 能治愈人的心灵 让人永远向往未来 是啊,应该是这样的 曾经好的坏的念念不忘的 热...

  • 眼泪的味道

    眼泪是什么?有人说它是水,有人说它比水要咸,有人说它是甜的,又有人说它是苦的,为什么同样的东西每个人的理解都...

网友评论

    本文标题:Redis-都说它快为什么那么快

    本文链接:https://www.haomeiwen.com/subject/mcmciqtx.html