zoukankan      html  css  js  c++  java
  • 利用Redis Sentinel实现redis主从自动切换

    redis主从配置很简单,只需要在slave的配置里加slaveof 192.168.0.100 6379(master的ip和端口)

    如果master有密码再设置 masterauth password。主从设置以后要提高可靠性就要用到Sentinel.

    Sentinel主要作用有

    • 监控。Sentinel不断检查Master和Slave是否工作正常。
    • 通知。Sentinel可以通过API通知系统管理员,另一台计算机程序,受监控的Redis实例有问题。
    • 自动故障切换。如果主机不按预期工作,Sentinel自动切换master。 

    Sentinel常见配置

    #master 7000

    sentinel monitor master1 127.0.0.1 7000 2                #配置master名、ipport、需要多少个sentinel才能判断[客观下线]2

    sentinel down-after-milliseconds master-7000 30000      #配置sentinelmaster发出ping,最大响应时间、超过则认为主观下线

    sentinel parallel-syncs master-7000 1                   #配置在进行故障转移时,运行多少个slave进行数据备份同步(越少速度越快)

    sentinel failover-timeout master-7000 180000            #配置当出现failover时下一个sentinel与上一个sentinel[同一个master监测的时间间隔](最后设置为客观下线)

    Spring配置文件

    <bean id="sentinelConfiguration"
            class="org.springframework.data.redis.connection.RedisSentinelConfiguration">
            <property name="master">
                <bean class="org.springframework.data.redis.connection.RedisNode">
                    <property name="name" value="${redis.sentinel.masterName}"></property>
                </bean>
            </property>
            <property name="sentinels">
                <set>
                    <bean class="org.springframework.data.redis.connection.RedisNode">
                        <constructor-arg name="host"
                            value="${redis.sentinel1.host}"></constructor-arg>
                        <constructor-arg name="port"
                            value="${redis.sentinel1.port}"></constructor-arg>
                    </bean>
                    <bean class="org.springframework.data.redis.connection.RedisNode" >
                        <constructor-arg name="host"
                            value="${redis.sentinel2.host}"></constructor-arg>
                        <constructor-arg name="port"
                            value="${redis.sentinel2.port}"></constructor-arg>
                    </bean>
                </set>
            </property>
        </bean>

    有几个redis就添加几个bean。

  • 相关阅读:
    CnForums1.0 Alpha 开始试运行
    asp.net Forums2.0修改密码后无法登陆问题——都是Cache惹的祸
    CnForums1.0 Alpha RC1 发布
    Docker: Nvidia Driver, Nvidia Docker 推荐安装步骤
    Docker: docker pull, wget, curl, git clone 等如何更快?
    DL4J实战之三:经典卷积实例(LeNet5)
    纯净Ubuntu16安装CUDA(9.1)和cuDNN
    DL4J实战之四:经典卷积实例(GPU版本)
    JAVA 中静态块、静态变量加载顺序详解
    设计模式之单例模式
  • 原文地址:https://www.cnblogs.com/akaneblog/p/6754559.html
Copyright © 2011-2022 走看看