
Redis介绍
- Redis是一种高速缓存数据库,主要是用于存储使用频率很高的数据,以加快查询速度,优化用户体验。
- Redis的存储逻辑为键值对的方式,属于一种key-value的存储系统。
- Redis的这种键值对的存储逻辑是基于哈希表思想的(并非完全基于哈希表)。
- 哈希表的设计,实际上就和字典非常相似:通过一个键值,按照相应的查找规则去寻找其所在的分类,进而获得其详细信息。因此在有些语言中也称哈希表为字典结构。
- Redis是基于C语言实现的。
- Redis存储的数据在内存中,比传统sql数据库快很多。
- Redis主要针对内存中的数据进行管理。
- 最新的Redis已经可以支持多线程并发了。
- Redis数据库的数据是存储在内存中的,是持久化的,断电或重启不会丢失。
- Redis的数据是磁盘中数据的一部分,每次服务器重启redis都会从数据库中获取部分热点数据。
- Redis存储方式有三种:
- 内存
- 磁盘
- 日志文件
- Redis支持主从模式,可以配置集群,支持分布式部署。
- Redis位于高速缓存区,其中的数据大部分是磁盘中存在的,也会有部分提交数据,提交的数据不会立刻同步到磁盘,但是前端面向的直接数据存储区就是高速缓存区,所以数据提交到高速缓存区之后,虽然没有马上同步到磁盘,但是用户仍可看到提交之后的结果,高速缓存区中的提交数据,最终也会存储到磁盘中。
- Redis是一种NoSql数据库,一种非关系型数据库。
- 非关系型数据库:数据存储没有固定格式,并且可以进行横向发展。
- 关系型数据库:列+行,同一个表下数据的结构是一样的。
- NoSQL:not only sql(不仅仅是SQL)。
- NoSQL数据库的特点:不仅仅是数据;没有固定的查询语言;存储方式多样。
- NoSQL数据库的存储方式:
- 键值对存储(redis)
- 列存储(HBase)
- 文档存储(MongoDB)
- 图形化数据库(不是存图形,存的是关系)(Neo4j)
- Redis的单线程为什么速度快?
- 数据存储在内存中读取速度很快
- redis的数据结构大多类似于HashMap,查询和操作的时间复杂度都是O(1)
- 数据结构简单,对数据操作也简单,Redis中的数据结构是专门进行设计的
- 采用单线程,避免了不必要的上下文切换和竞争条件,也不存在多进程或者多线程导致的切换而消耗CPU,不用去考虑各种锁的问题,不存在加锁释放锁操作,没有因为可能出现死锁而导致的性能消耗;
- 使用多路I/O复用模型,非阻塞I/O;
- Redis直接自己构建了VM 机制 ,因为一般的系统调用系统函数的话,会浪费一定的时间去移动和请求;
Redis数据结构
- Redis的数据类型有:
- String
- list
- set
- zset(相当于有序set)
- hash
Redis实际使用
- Redis可以存放一些有时效的数据,例如短信验证码等。
- Redis可以用作为服务中的锁
Redis是一种基于键值对的内存高速缓存数据库,用于存储高频数据以提升查询速度。它支持多线程并发,数据持久化,采用单线程模型以保证高效运行,并提供多种数据结构如String、List、Set和Hash。Redis还支持主从复制和集群部署,常用于缓存、事务、发布/订阅等功能,且能应对缓存穿透、击穿和雪崩等问题。
633

被折叠的 条评论
为什么被折叠?



