redis 哨兵模式配置与spring集成

本文详细介绍了如何从源码编译并配置Redis主从环境,包括配置文件的设置、启动命令及Spring Data Redis的集成示例。通过具体步骤与代码,读者可以学习如何实现Redis的高可用性和数据持久化。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最低安装 redis 2.8以上版本 以下流程 为redis3.2.11版本上建立

1、编译redis源码

make make PREFIX=/usr/local/redis install
mkdir conf
mkdir data
mkdir log

2、将redis 源码下的 redis.conf和sentinel.conf 复制到 redis/conf/ 下,修改 redis.conf

bind 172.16.5.58
protected-mode no
tcp-backlog 511
timeout 0
tcp-keepalive 300
daemonize yes
supervised no
pidfile "/var/run/redis_16382.pid"
loglevel notice
logfile "/usr/local/redis-16382/log/redis-16382.log"
databases 16
save 900 1
save 300 10
save 60 10000
stop-writes-on-bgsave-error yes
rdbcompression yes
rdbchecksum yes
dbfilename "redis-16382.rdb"
dir "/usr/local/redis-16382/data"
slave-serve-stale-data yes
slave-read-only yes
repl-diskless-sync no
repl-diskless-sync-delay 5
repl-disable-tcp-nodelay no
slave-priority 100
requirepass "ucpaas.com"
appendonly yes
appendfilename "appendonly.aof"
appendfsync everysec
no-appendfsync-on-rewrite no
auto-aof-rewrite-percentage 100
auto-aof-rewrite-min-size 64mb
aof-load-truncated yes
lua-time-limit 5000
slowlog-log-slower-than 10000
slowlog-max-len 128
latency-monitor-threshold 0
notify-keyspace-events ""
hash-max-ziplist-entries 512
hash-max-ziplist-value 64
list-max-ziplist-size -2
list-compress-depth 0
set-max-intset-entries 512
zset-max-ziplist-entries 128
zset-max-ziplist-value 64
hll-sparse-max-bytes 3000
activerehashing yes
client-output-buffer-limit normal 0 0 0
client-output-buffer-limit slave 256mb 64mb 60
client-output-buffer-limit pubsub 32mb 8mb 60
hz 10
aof-rewrite-incremental-fsync yes
slaveof 172.16.5.58 16384


如果该redis 为主,则以上配置文件按需修改
如果该redis 为从, 则需要redis.conf中加入 slaveof 172.16.5.58 16382

修改 sentinel.conf

bind 172.16.5.58
protected-mode no
port 6382
dir "/var/lib/sentinel-6382"
sentinel myid 1e83bb84814cb8493682d5078ef922cbfeeaed61
sentinel monitor master-16382 172.16.5.58 16382 2
sentinel auth-pass master-16382 ucpaas.com
sentinel config-epoch master-16382 1
sentinel leader-epoch master-16382 1
sentinel current-epoch 1
如果配置多个 sentinel 则复制该sentinel.conf文件即可

 

启动主从redis ./bin/redis-server /conf/redis.conf &

启动sentinel ./bin/redis-sentinel /conf/sentinel.conf &

 

spring-data-redis 使用该模式

<bean id="stringRedisSerializer" class="org.springframework.data.redis.serializer.StringRedisSerializer" />

<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="master-16382" />
        </bean>
    </property>

    <property name="sentinels">
        <set>
            <bean class="org.springframework.data.redis.connection.RedisNode">
                <constructor-arg name="host" value="172.16.5.58" />
                <constructor-arg name="port" value="6382" />
            </bean>

            <bean class="org.springframework.data.redis.connection.RedisNode">   
                <constructor-arg name="host" value="172.16.5.58" />
                <constructor-arg name="port" value="6383" />
            </bean>

            <bean class="org.springframework.data.redis.connection.RedisNode ">
                <constructor-arg name="host" value="172.16.5.58" />
                <constructor-arg name="port" value="6384" />
            </bean>
        </set>

    </property>

</bean>

<!-- 公共redis配置 -->

<bean id="commonRedisPoolConfig" class="redis.clients.jedis.JedisPoolConfig">
    <property name="maxIdle" value="${common.redis.maxIdle}" />
    <property name="maxTotal" value="${common.redis.maxTotal}" />
    <property name="maxWaitMillis" value="${common.redis.maxWaitMillis}" />
    <property name="testOnBorrow" value="${common.redis.testOnBorrow}" />
</bean>


<bean id="commonRedisConnectionFactory" class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory">
    <property name="password" value="ucpaas.com" />
    <constructor-arg name="sentinelConfig" ref="redisSentinelConfiguration" />
    <constructor-arg name="poolConfig" ref="commonRedisPoolConfig" />
</bean>


<bean id="commonRedisTemplate" name="commonRedisTemplate" class="org.springframework.data.redis.core.RedisTemplate">
    <property name="connectionFactory" ref="commonRedisConnectionFactory" />
    <property name="defaultSerializer" ref="stringRedisSerializer" />
    <property name="enableTransactionSupport" value="true"/>
</bean>

 

 

转载于:https://my.oschina.net/TonyTaotao/blog/3000653

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值