• redis配置主从备份以及主备切换方案配置(转)


    版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
    本文链接:https://blog.csdn.net/gsying1474/article/details/48302565
    前提:redis中,主从切换场景中,没有绝对的主和从,只有初始化的主和从,然后当主down后,从就变成主了,而主即使连接上,也是从,不会变为主

    1、redis-server的主备关系:
        需要配置的机器,以及主备关系如下
        master:10.118.36.10
        slave1:10.118.36.74
        slave2:10.118.36.161
    2、修改redis-server的配置文件:
        切换到redis的根目录
        # cd /home/admin/Downloads/redis-3.0.3

        master配置不变,
        两台slave修改配置文件(# vi redis-3.0.3/redis.conf),添加如下语句,其余用默认配置:
            slaveof 10.118.36.10 6379
    3、修改redis-sentinel的配置文件(# vi redis-3.0.3/sentinel.conf),但是这里我使用一个新的文件(# vi redis-3.0.3/sentinel-test.conf):
     
        切换到redis的根目录
        # cd /home/admin/Downloads/redis-3.0.3
        # vi redis-3.0.3/sentinel-test.conf
        三台机器配置相同,如下:
    ############################代码区域,begin############################
    port 26379
    #MyMaster
    sentinel monitor MyMaster 10.118.36.10 6379 1
    sentinel down-after-milliseconds MyMaster 5000
    sentinel failover-timeout MyMaster 900000
    sentinel parallel-syncs MyMaster 2
    ############################代码区域,end############################

    4、启动redis-server服务和redis-sentinel服务
        切换到redis的根目录
        # cd /home/admin/Downloads/redis-3.0.3

        启动redis-server
        # ./src/redis-server redis.conf 

        启动redis-sentinel
        # ./src/redis-sentinelsentinel-test.conf 

    5、检查redis状态(三台都执行)
        切换到redis的根目录
        # cd /home/admin/Downloads/redis-3.0.3
        查询命令
        # ./src/redis-cli
        查询状态信息
        > ping
        返回的结果如果是PONG,则表示服务运行正常
        然后继续执行命令,检查主备是否正常
        > info Replication
        查看返回结果(关键点)
        master应为(offset和lag无所谓):
    role:master
    connected_slaves:2
    slave0:ip=10.118.36.74,port=6379,state=online,offset=1241704,lag=0
    slave1:ip=10.118.36.161,port=6379,state=online,offset=1241704,lag=0

        slave应为:
    role:slave
    master_host:10.118.36.10
    master_port:6379
    master_link_status:up

    6、检查sentinel状态(三台都执行)
        切换到redis的根目录
        # cd /home/admin/Downloads/redis-3.0.3
        
        执行命令
        # ./src/redis-cli -p 26379
        查询状态信息
        > info
        查看结果如果有如下所示,即表示正常集群配置正常运行
    # Sentinel
    sentinel_masters:1
    sentinel_tilt:0
    sentinel_running_scripts:0
    sentinel_scripts_queue_length:0
    master0:name=MyMaster,status=ok,address=10.118.36.10:6379,slaves=2,sentinels=3    

    ————————————————
    版权声明:本文为CSDN博主「刘迎光-萤火虫工作室」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
    原文链接:https://blog.csdn.net/gsying1474/article/details/48302565

  • 相关阅读:
    关于 锁的四种状态与锁升级过程 图文详解
    悲观锁与乐观锁的实现(详情图解)
    面试三轮我倒在了一道sql题上——sql性能优化
    我的程序跑了60多小时,就是为了让你看一眼JDK的BUG导致的内存泄漏。
    快来!我从源码中学习到了一招Dubbo的骚操作!
    我从LongAdder中窥探到了高并发的秘籍,上面只写了两个字...
    震惊!ConcurrentHashMap里面也有死循环,作者留下的“彩蛋”了解一下?
    mybatis 逆向工程使用姿势不对,把表清空了,心里慌的一比,于是写了个插件。
    吐血输出:2万字长文带你细细盘点五种负载均衡策略。
    mybatis开发,你用 xml 还是注解?我 pick ...
  • 原文地址:https://www.cnblogs.com/muxi0407/p/11650012.html
Copyright © 2020-2023  润新知