Redis一些问题

Redis的两种写

CPU 内存 磁盘这三种访问的速度是由快到慢的,它们之间的容量是从小到大的,因此就有了只读缓存和读写缓存两种模式。

第一种是写在数据库中,然后缓存未命中则去查数据库,查到了之后再写入缓存。

第二种是同时写Redis和数据库,但是就有了同步写和异步写。

同步写要缓存和数据库同时写完。

异步写只需要写好缓存,缓存满了之后,写进数据库就可以了。

缓存雪崩,击穿,穿透

缓存雪崩

大量缓存同一时刻过期,查询全到数据库,导致数据库层的压力激增,可以设置过期值不同。

缓存击穿

热点key过期后,查询全到数据库,设置热点key不过期。

缓存穿透

缓存和数据库都不存在这个数据,可以返回null值回缓存,或者用布隆过滤器。

所有三种方法都可以用熔断,限流。

LRU和LFU

LRU

删除掉最早访问的数据,但是有一个缺点,如果数据是每一个都进行查询的话,也是会这些数据造成污染的。

LFU

从最早访问和访问次数两方面对LRU进行了优化。

Redis并发

在并发领域,如果需要把一些命令同时执行,那么就需要使用lua命令,它可以保证Redis执行命令的原子性。

往期文章

Redis核心技术

Redis主从同步和哨兵

Redis实战

Redis为什么会阻塞

相关推荐
赵丙双1 分钟前
spring boot 排除自动配置类的方式和原理
java·spring boot·自动配置
8Qi89 分钟前
LeetCode热题100--45.跳跃游戏 II
java·算法·leetcode·贪心算法·编程
bilI LESS19 分钟前
Spring Boot接收参数的19种方式
java·spring boot·后端
刘~浪地球28 分钟前
Redis 从入门到精通(四):字符串操作详解
数据库·redis·缓存
荒川之神44 分钟前
MySQL 商品拉链表 完整最终版(配备了全套存储过程)
数据库·mysql
admin and root1 小时前
从资产收集FUZZ接口到SQL注入案例
网络·数据库·sql·安全·web安全·渗透测试·log4j
我真会写代码1 小时前
MySQL关键词全面总结(含用法+避坑指南)
数据库·mysql·索引
九皇叔叔1 小时前
004-SpringSecurity-Demo 拆分环境
java·springboot3·springsecurity
rainy雨1 小时前
精益数据分析系统功能拆解:如何用精益数据分析解决指标虚高难题与初创期验证场景
大数据·数据库·人工智能·信息可视化·数据挖掘·数据分析·精益工程
tycooncool1 小时前
QT数据库(三):QSqlQuery使用
数据库·qt·oracle