数据库的工作模式按存储方式可分为:硬盘数据库和内存数据库。Redis 将数据储存在内存里面,读写数据的时候都不会受到硬盘 I/O 速度的限制,所以速度极快。
(1)硬盘数据库的工作模式:
(2)内存数据库的工作模式:
注:图片转自博客:https://blog.csdn.net/chenyao1994/article/details/79491337
redis客户端与服务端请求方式
redis的客户端与服务器端的模型简化,每次客户端调用都经历:发送命令,执行命令,返回结果
所有的命令都会在一个队列里面等待被执行
redis是单线程来处理命令的,所以一条命令从客户端发送到了服务端不会立即执行,所有的命令都会进入一个队列,然后逐个被执行。
为什么单线程处理那么快
(1)纯内存访问,redis的所有数据都是在内存里面的,内存的相应时间约在100纳秒。
(2)非阻塞IO,redis使用epoll作为IO多路复用技术的实现,在加上redis自身的事件处理模型将epoll中连接、读写、关闭都转换为事件,不在网络IO上浪费过多的时间。
(3)数据结构简单,对数据操作也简单,Redis中的数据结构是专门进行设计的
(4)采用单线程,避免了不必要的上下文切换和竞争条件,也不存在多进程或者多线程导致的切换而消耗 CPU,不用去考虑各种锁的问题,不存在加锁释放锁操作,没有因为可能出现死锁而导致的性能消耗
(5)使用底层模型不同,它们之间底层实现方式以及与客户端之间通信的应用协议不一样,Redis直接自己构建了VM 机制 ,因为一般的系统调用系统函数的话,会浪费一定的时间去移动和请求
为什么redis是单线程的
因为Redis是基于内存的操作,CPU不是Redis的瓶颈,Redis的瓶颈最有可能是机器内存的大小或者网络带宽。既然单线程容易实现,而且CPU不会成为瓶颈,那就顺理成章地采用单线程的方案了(毕竟采用多线程会有很多麻烦!)。