1 redis持久化
-mysql的Dump
-redis的RDB
-mysql的 Binlog
-Redis的 AOF
1.1 RDB
-save:客户端执行save命令----》redis服务端----》同步创建RDB二进制文件,如果老的RDB存在,会替换老的
-bgsave:客户端执行save命令----》redis服务端----》异步创建RDB二进制文件,如果老的RDB存在,会替换老的
-配置文件
save 900 1
save 300 10
save 60 10000
如果60s中改变了1w条数据,自动生成rdb
如果300s中改变了10 条数据,自动生成rdb
如果900s中改变了1 条数据,自动生成rdb
1.2 aof
always:redis–》写命令刷新的缓冲区—》每条命令fsync到硬盘—》AOF文件
everysec(默认值):redis——》写命令刷新的缓冲区—》每秒把缓冲区fsync到硬盘–》AOF文件
no:redis——》写命令刷新的缓冲区—》操作系统决定,缓冲区fsync到硬盘–》AOF文件
-本质:本质就是把过期的,无用的,重复的,可以优化的命令,来优化
-使用:
-在客户端主动输入:bgrewriteaof
-配置文件:
appendonly yes
appendfilename "appendonly.aof"
appendfsync everysec
dir ./data
no-appendfsync-on-rewrite yes
2 主从复制(一主一从一主多从)
方式一:
-在从库执行 SLAVEOF 127.0 .0 .1 6379 ,
-断开关系 slaveof no one
方式二:配置文件(配在从库的配置文件中)
slaveof 127.0 .0 .1 6379
slave-read-only yes
3 哨兵
1 搭一个一主两从
daemonize yes
pidfile /var/run/redis.pid
port 6379
dir "/opt/soft/redis/data"
logfile “6379. log”
daemonize yes
pidfile /var/run/redis2.pid
port 6378
dir "/opt/soft/redis/data2"
logfile “6378. log”
slaveof 127.0 .0 .1 6379
slave-read-only yes
daemonize yes
pidfile /var/run/redis3.pid
port 6377
dir "/opt/soft/redis/data3"
logfile “6377. log”
slaveof 127.0 .0 .1 6379
slave-read-only yes
./src/redis-server redis_6379.conf
./src/redis-server redis_6378.conf
./src/redis-server redis_6377.conf
2 搭建哨兵
创建三个配置文件分别叫sentinel_26379.conf sentinel_26378.conf sentinel_26377.conf
port 26379
daemonize yes
dir ./data3
protected-mode no
bind 0.0 .0 .0
logfile "redis_sentinel3.log"
sentinel monitor mymaster 127.0 .0 .1 6379 2
sentinel down-after-milliseconds mymaster 30000
sentinel parallel-syncs mymaster 1
sentinel failover-timeout mymaster 180000
./src/redis-sentinel sentinel_26379.conf
./src/redis-sentinel sentinel_26378.conf
./src/redis-sentinel sentinel_26377.conf
./src/redis-cli -p 26377
redis-cli -p 6379
shutdown
客户端连接
import redis
from redis.sentinel import Sentinel
sentinel = Sentinel([('10.0.0.101' , 26379 ),
('10.0.0.101' , 26378 ),
('10.0.0.101' , 26377 )
],
socket_timeout=5 )
print (sentinel)
master = sentinel.discover_master('mymaster' )
print (master)
slave = sentinel.discover_slaves('mymaster' )
print (slave)
4 集群
redis-cli --cluster create --cluster-replicas 1 127.0 .0 .1 :7000 127.0 .0 .1 :7001 127.0 .0 .1 :7002 127.0 .0 .1 :7003 127.0 .0 .1 :7004 127.0 .0 .1 :7005
CLUSTER NODES # 集群节点信息
cluster slots # 查看槽的信息
redis-cli -p 7007 cluster replicate 16 c49dd91001529792f0425b46c6757080125732
redis-cli --cluster reshard --cluster-from 16 c49dd91001529792f0425b46c6757080125732 --cluster-to 4 ee63c79b7ab594414068099c12668ffc6698dbc --cluster-slots 1366 127.0 .0 .1 :7000
redis-cli --cluster reshard --cluster-from 16 c49dd91001529792f0425b46c6757080125732 --cluster-to 4 ee63c79b7ab594414068099c12668ffc6698dbc --cluster-slots 1366 127.0 .0 .1 :7000
redis其他
1 先更新数据库,再更新缓存(一般不用)
2 先删缓存,再更新数据库(在存数据的时候,请求来了,缓存不是最新的)
3 先更新数据库,再删缓存(推荐用)
- LRU/LFU/FIFO算法剔除
-maxmemory-policy,超过最大内存,新的放不进去了,淘汰策略
LRU -Least Recently Used,没有被使用时间最长的(保证热点数据)
LFU -Least Frequenty User,一定时间段内使用次数最少的
FIFO -First In First Out,先进先出
-配置文件中:maxmemory-policy:volatile-lru
-配置
maxmemory-policy:volatile-lfu
lfu-log-factor 10
lfu-decay-time 1
>
>
-自由发挥
缓存穿透是指缓存和数据库中都没有的数据,而用户不断发起请求,如发起为id 为“-1 ”的数据或id 为特别大不存在的数据。这时的用户很可能是攻击者,攻击会导致数据库压力过大。
1 接口层增加校验,如用户鉴权校验,id 做基础校验,id <=0 的直接拦截;
2 从缓存取不到的数据,在数据库中也没有取到,这时也可以将key-value对写为key-null,缓存有效时间可以设置短点,如30 秒(设置太长会导致正常情况也没法使用)。这样可以防止攻击用户反复用同一个id 暴力攻击
3 通过布隆过滤器实现,mysql中所有数据都放到布隆过滤器,请求来了,先去布隆过滤器查,如果没有,表示非法,直接返回
缓存击穿是指缓存中没有但数据库中有的数据(一般是缓存时间到期),这时由于并发用户特别多,同时读缓存没读到数据,又同时去数据库去取数据,引起数据库压力瞬间增大,造成过大压力
设置热点数据永远不过期。
缓存雪崩是指缓存中数据大批量到过期时间,而查询数据量巨大,引起数据库压力过大甚至down机。和缓存击穿不同的是, 缓存击穿指并发查同一条数据,缓存雪崩是不同数据都过期了,很多数据都查不到从而查数据库。
1 缓存数据的过期时间设置随机,防止同一时间大量数据过期现象发生。
2 如果缓存数据库是分布式部署,将热点数据均匀分布在不同搞得缓存数据库中。
3 设置热点数据永远不过期。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 25岁的心里话
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现