加入收藏 | 设为首页 | 会员中心 | 我要投稿 孝感站长网 (https://www.0712zz.com.cn/)- 运营、云管理、管理运维、云计算、大数据!
当前位置: 首页 > 站长资讯 > 动态 > 正文

Redis中的全局命令

发布时间:2021-03-16 16:05:56 所属栏目:动态 来源:互联网
导读:为什么Redis要这样设计数据结构及底层编码呢。首先第一个好处就是可以改进内部编码。当这样做时,而不需要改变内部的数据结构,也就无需修改外部结构及命令了。第二个好处就是,我们知道不同的内部编码有着不同的性能,当这样设计时,如果我们要改变底层的内

为什么Redis要这样设计数据结构及底层编码呢。首先第一个好处就是可以改进内部编码。当这样做时,而不需要改变内部的数据结构,也就无需修改外部结构及命令了。第二个好处就是,我们知道不同的内部编码有着不同的性能,当这样设计时,如果我们要改变底层的内部编码时,我们只需要根据Redis配置选项就可以,将我们曾经存储过的key的底层编码更改,这样就可以针对不同的业务场景,个性化配置,进而提升性能。

  • 单线程架构

我们知道Redis使用了单线程架构和I/O多路复用模型来实现高性能的内存服务。

  • 单线程模型

每当客户端调用命令时都会经历3个步骤:发送命令、执行命令、返回结果3个过程。我们之前介绍过Redis是单线程的,所以每一条命令从客户端发送到服务端,命令不会立即执行,而是将所有的命令都会进入一个队列中,然后在顺序执行。这样,当我们客户端启动多个时执行命令时,不用考虑并发的问题,因为它们都会进入队列,顺序执行。

  1. 为什么单线程处理速度这么快 第一,我们知道Redis是将数据都存储到内存中的,内存的处理速度,要比纯硬盘IO的速度要快的多。
  2. 第二,非阻塞I/O,Redis使用epoll作为I/O多路复用技术实现的,在加上Redis自身的事件处理模型将epoll中的连接、读写、关闭都转换为事件,不在网络I/O上浪费过多的时间。
  3. 单线程避免线程切换等消耗

第一,我们知道做项目开发时,如果要对多线程做兼容,那么它要比单线程要复杂多了,代码变复杂了,出现BUG的可能性也就多了。

(编辑:孝感站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读