美文网首页
redis 主从

redis 主从

作者: AGEGG | 来源:发表于2023-08-19 14:21 被阅读0次

    查看状态
    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 :当内存已使用率到达,则开始清理缓存
    • noeviction:旧缓存永不过期,新缓存设置不了,返回错误
    • allkeys-lru:清除最少用的旧缓存,然后保存新的缓存(推荐使用)
    • allkeys-random:在所有的缓存中随机删除(不推荐)
    • volatile-lru:在那些设置了expire过期时间的缓存中,清除最少用的旧缓存,然后保存新的缓存
    • volatile-random:在那些设置了expire过期时间的缓存中,随机删除缓存
    • volatile-ttl:在那些设置了expire过期时间的缓存中,删除即将过期的

    内存淘汰管理机制 LIMITS

    # 清理不常用的
    maxmemory-policy allkeys-lru
    

    相关文章

      网友评论

          本文标题:redis 主从

          本文链接:https://www.haomeiwen.com/subject/smrjmdtx.html