redis 主從複製

Spring 版本兼容性問題 3.2.5

1.master
主redis默認配置就可以。
redis.conf
直接寫:port 6379

2.slave
修改redis.conf配置
port 6379
slaveof 10.6.60.166 6379 //主redis地址配置好主從最好測試一下
3.監控配置
配置 sentinel.conf 如下:
port 26379
sentinel monitor mymaster 10.6.60.166 6379 1 1是幾臺判斷master odowen
sentinel down-after-milliseconds mymaster 1000 報文返回時間限制超過odowen
sentinel config-epoch mymaster 17
sentinel known-slave mymaster 10.6.60.169 6379

./redis-cli -h 10.6.60.166 info Replication 查看複製信息
./redis-cli -h 10.6.60.167 -p 26379 info Sentinel 查看監控信息

spring-redis.xml spring版本2.3.5低版本有問題

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:mvc="http://www.springframework.org/schema/mvc"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="
    http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.2.xsd
    http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-3.2.xsd
    http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.2.xsd
    ">

<!-- jedis pool配置 -->
<bean id="jedisPoolConfig" class="redis.clients.jedis.JedisPoolConfig">
      <property name="maxTotal" value="30" />
      <property name="maxIdle" value="200" />
      <property name="maxWaitMillis" value="3000" />
      <property name="testOnBorrow" value="true" />
   </bean>
<!-- spring data redis -->
<bean id="jedisConnectionFactory"
class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory">
      <property name="poolConfig" >
         <ref bean="jedisPoolConfig"/>
      </property>
      <constructor-arg name="sentinelConfig" ref="redisSentinelConfiguration"/>
      <property name="timeout" value="30000"/>
   </bean>

   <bean id="redisSentinelConfiguration" class="org.springframework.data.redis.connection.RedisSentinelConfiguration">
      <property name="master">
         <bean class="org.springframework.data.redis.connection.RedisNode">
            <property name="name" value="mymaster"/>
         </bean>
      </property>
      <property name="sentinels">
         <set>
            <bean class="org.springframework.data.redis.connection.RedisNode">
               <constructor-arg name="host" value="10.6.60.167"></constructor-arg>
               <constructor-arg name="port" value="26379"></constructor-arg>
            </bean>
         </set>
      </property>
   </bean>

<!-- Redis Template -->
<bean id="redisTemplate" class="org.springframework.data.redis.core.RedisTemplate">
      <property name="connectionFactory" ref="jedisConnectionFactory" />
      <property name="keySerializer">
         <bean class="org.springframework.data.redis.serializer.StringRedisSerializer" />
      </property>
   </bean>
</beans>
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章