Redis知识点汇总

在这里插入图片描述

Redis介绍

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

Redis数据结构

  1. Redis的数据类型有:
    • String
    • list
    • set
    • zset(相当于有序set)
    • hash

Redis实际使用

  1. Redis可以存放一些有时效的数据,例如短信验证码等。
  2. Redis可以用作为服务中的锁

Redis的事务

Redis的发布和订阅

Redis的淘汰策略

Redis的缓存穿透、击穿、雪崩

Redis的机制

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值