Redis一些问题

Redis的两种写

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

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

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

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

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

缓存雪崩,击穿,穿透

缓存雪崩

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

缓存击穿

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

缓存穿透

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

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

LRU和LFU

LRU

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

LFU

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

Redis并发

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

往期文章

Redis核心技术

Redis主从同步和哨兵

Redis实战

Redis为什么会阻塞

相关推荐
玛卡巴卡ldf6 分钟前
【Springboot5】审批流工作流引擎(业务、审批分离)排除if else
java·springboot
真心喜欢你吖6 分钟前
OpenClaw安装部署Mac操作系统版 - 打造你的专属AI助理
java·人工智能·macos·ai·语言模型·智能体·openclaw
LSL666_10 分钟前
JVM面试题——垃圾收集器
java·jvm·面试·垃圾收集器
MC皮蛋侠客11 分钟前
C++中使用Redis指南:基于redis-plus-plus库
开发语言·c++·redis
Elastic 中国社区官方博客13 分钟前
LINQ 到 ES|QL:使用 C# 查询 Elasticsearch
大数据·数据库·sql·elasticsearch·搜索引擎·全文检索·linq
_深海凉_15 分钟前
LeetCode热题100-LRU 缓存
算法·leetcode·缓存
Via_Neo18 分钟前
今天是周六,两天后是周几?
java·数据结构·算法
星晨雪海18 分钟前
Redis-逻辑查询详情讲解
java·开发语言
Code-Porter21 分钟前
记录关于Flutter ObjectBox数据库使用ObjectBoxBrowser插件,在同一个局域网内电脑无法访问查看数据问题
android·数据库·flutter·dart
AI精钢21 分钟前
什么是面向 Agent 的 LLM?从 Qwen3.6-Plus 看大模型的新分水岭
网络·数据库·人工智能·云原生·aigc