Redis主从复制和过期淘汰

Redis的主从复制,只需要在 从节点做配置

# 配置主节点的IP和端口
replicaof 192.168.3.70 6379
# 配置密码
masterauth 121321

# 配置从节点只读(默认就是只读)
replica-read-only yes

在这里插入图片描述

# 查询主节点或者从节点的信息
info replication

主:
在这里插入图片描述
从:
在这里插入图片描述
Redis的主从复制同步数据:默认的是:Redis会创建一个子进程,子进程会在磁盘上写RDB文件,稍后,该文件由父进程以增量方式传输到子节点,这种方式是依赖磁盘的。
第二种方式:无磁盘化复制:Redis会创建一个子进程,子进程会在内存中写RDB文件,这个文件会依靠sockets传递给子节点,这个过程中不会依赖磁盘(警告:无磁盘复制还在测试中

2:Redis的过期淘汰

已过期的key如何处理?
设置了expire的key缓存过期了,但是服务器的内存还是会被占用,这是因为redis所基于的两种删除策略
redis有两种策略:

  1. (主动)定时删除
    ●定时随机的检查过期的key,如果过期则清理删除。(每秒检查次数在redis. conf中的hz配置)
    在这里插入图片描述

  2. (被动) 惰性删除
    ●当客户端请求-一个已经过期的key的时候,那么redis会检查这 个key是否过期,如果过期了,则删除,然后返回-个nil。这种策略对cpu此
    较友好,不会有太多的损耗,但是内存占用会比较高。
    所以,虽然key过期了,但是只要没有被redis清理,但是其实内存还是 会被占用着的。

那么如果内存被Redis缓存占用满了咋办?
内存占满了,可以使用硬盘,来保存,但是没意义,因为硬盘没有内存快,会影响redis性能。
所以,当内存占用满了以后,redis提供了一套缓存淘汰机制: MEMORY MANAGEMENT
maxmemory :当内存已使用率到达,则开始清理缓存

  • noeviction: 旧缓存永不过期,新缓存设置不了,返回错误
  • allkeys-lru: 清除最少用的旧缓存,然后保存新的缓存(推荐使用)
  • allkeys-random:在所有的缓存中随机删除(不推荐)
  • volatile-lru: 在那些设置了expire过期时间的缓存中,清除最少用的旧缓存,然后保存新的缓存
  • volatile-random: 在那些设置了expire过期时间的缓存中,随机删除缓存
  • volatile-tt1: 在那些设置了expire过期时间的缓存中,删除即将过期的
# 默认是noeviction
maxmemory-policy allkeys-lfu
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值