简介
Redis是一种非结构化的数据库,将数据采用键值对的形式存储在内存中,由于存储在内存中,所以运行很快。
为什么快?
- 所有的数据都是放在内存中进行管理的,当然比存储在外存的结构化数据库快
- 是用C语言实现的,更接近操作系统,运行更快
- 采用单线程架构,避免了多线程产生的资源竞争问题
- 源代码特别精简
Redis单线程架构
Redis使用了单线程架构和I/O多路复用模型来实现高性能的内存数据库 服务.Redis是单线程来处理命令的,一
条命令从客户端达到服务端不会立刻被执行,所有命令都会进入一个队列
中,然后逐个被执行。
Redis采用单线程还很快的原因
第一,纯内存访问
第二,非阻塞I/O,Redis使用epoll作为I/O多路复用技术的实现,再加上 Redis自身的事件处理模型将epoll中的连接、读写、关闭都转换为事件,不 在网络I/O上浪费过多的时间
第三,单线程避免了线程切换和竞态产生的消耗
数据结构
Redis都是采用键值对的形式存储,但是在底层有5种不同的数据结构,用于存储value值,分别是string、hash、list、set、sort-set
- string 就跟普通的键值对无区别,value是一个字符串
- hash被存储的value又是一个键值对
- list是一个链表,分别有zipList、linkedList(底层编码方式)
- set是存储字符串类型的无序集