redis 主从

2023-08-19  本文已影响0人  AGEGG

查看状态
info replication

"# Replication
role:master
connected_slaves:0
master_repl_offset:0
repl_backlog_active:0
repl_backlog_size:1048576
repl_backlog_first_byte_offset:0
repl_backlog_histlen:0
"

修改配置文件 REPLICATION

# 打开前面的#注释开启 master 的ip和端口号
# slaveof <masterip> <masterport>
slaveof 192.168.1.191 6379

# master的密码
# masterauth <master-password>
masterauth 123456

#从节点只读
slave-read-only yes

无磁盘化同步 DISKLESS (磁盘慢,网速高,测试中,目前不推荐使用)

#目前在测试阶段
#WARNING: DISKLESS REPLICATION IS EXPERIMENTAL CURRENTLY

# yes开启
repl-diskless-sync no
# 同步之前等待多少秒
repl-diskless-sync-delay 5

已过期的key如何处理?

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

  1. (主动)定时删除
    定时随机的检查过期的key,如果过期则清理删除。(每秒检查次数在redis.conf中的hz配置)
每秒10次
hz 10
  1. (被动)惰性删除
    当客户端请求一个已经过期的key的时候,那么redis会检查这个key是否过期,如果过期了,则删除,然后返回一个nil。这种策略
    友好,不会有太多的损耗,但是内存占用会比较高。
    所以,虽然key过期了,但是只要没有被redis清理,那么其实内存还是会被占用着的。
    那么如果内存被Redis缓存占用慢了咋办?
    内存占满了,可以使用硬盘,来保存,但是没意义,因为硬盘没有内存快,会影响redis性能。
    所以,当内存占用满了以后,redis提供了一套缓存淘汰机制:MEMORY MANAGEMENT
    maxmemory :当内存已使用率到达,则开始清理缓存

内存淘汰管理机制 LIMITS

# 清理不常用的
maxmemory-policy allkeys-lru
上一篇下一篇

猜你喜欢

热点阅读