Redis主从+哨兵安装配置及在微服务中的使用

安装:

wget http://download.redis.io/releases/redis-5.0.9.tar.gz
tar xzf redis-5.0.9.tar.gz
mv redis-5.0.9 /usr/local/redis
cd /usr/local/redis
make
make install

配置(一主二从三哨兵):

主服务器用于数据的读写,当发生写入操作时,主服务器会自动将数据同步给从服务器。从服务器只负责读取,不能写入。如果主服务器宕机,哨兵(sentinel)会在从服务器中选举产生一个主服务器。此时该服务器具有读写权限。

master

创建文件夹

mkdir -p /usr/local/redis-master-slave/master
cp -rf /usr/local/redis/* /usr/local/redis-master-slave/master

修改配置文件

redis.conf

bind 192.168.9.128
port 6379
requirepass Occ2018
masterauth Occ2018
daemonize yes
pidfile /var/run/redis_6379.pid
logfile "/usr/local/redis-master-slave/master/redis.log"

sentinel.conf

port 26379
daemonize yes
pidfile "/var/run/redis-sentinel.26379.pid"
sentinel monitor mymaster 192.168.9.128 6379 2
sentinel auth-pass mymaster Occ2018
sentinel down-after-milliseconds mymaster 30000
sentinel parallel-syncs mymaster 1
sentinel failover-timeout mymaster 900000

salve1

创建文件夹

mkdir -p /usr/local/redis-master-slave/slave1
cp -rf /usr/local/redis/* /usr/local/redis-master-slave/slave1

修改配置文件

redis.conf

bind 192.168.9.128
port 6380
requirepass Occ2018
masterauth Occ2018
daemonize yes
pidfile /var/run/redis_6380.pid
logfile "/usr/local/redis-master-slave/slave1/redis.log"
slaveof 192.168.9.128 6379

sentinel.conf

port 26380
daemonize yes
pidfile "/var/run/redis-sentinel.26380.pid"
sentinel monitor mymaster 192.168.9.128 6379 2
sentinel auth-pass mymaster Occ2018
sentinel down-after-milliseconds mymaster 30000
sentinel parallel-syncs mymaster 1
sentinel failover-timeout mymaster 900000

salve2

创建文件夹

mkdir -p /usr/local/redis-master-slave/slave2
cp -rf /usr/local/redis/* /usr/local/redis-master-slave/slave2

修改配置文件

redis.conf

bind 192.168.9.128
port 6381
requirepass Occ2018
masterauth Occ2018
daemonize yes
pidfile /var/run/redis_6381.pid
logfile "/usr/local/redis-master-slave/slave2/redis.log"
slaveof 192.168.9.128 6379

sentinel.conf

port 26381
daemonize yes
pidfile "/var/run/redis-sentinel.26381.pid"
sentinel monitor mymaster 192.168.9.128 6379 2
sentinel auth-pass mymaster Occ2018
sentinel down-after-milliseconds mymaster 30000
sentinel parallel-syncs mymaster 1
sentinel failover-timeout mymaster 900000

启动运行所有节点:

cd /usr/local/redis-master-slave/master
./redis-server redis.conf
./redis-server sentinel.conf --sentinel

微服务配置

应用配置(application.yml)

spring:
    redis:
#        host: 192.168.9.128
#        port: 6379
        password: Occ2018
        database: 0
        pool:
            max-idle: 50
            min-idle: 0
            max-active: 50
            max-wait: -1
            max-total: 50
        sentinel:
            master: mymaster
            nodes: 192.168.9.128:26379,192.168.9.128:26380,192.168.9.128:26381

应用配置(application.properties)

#spring.redis.host=192.168.9.128
#spring.redis.port=6379
spring.redis.password=Occ2018
spring.redis.database=0
spring.redis.pool.max-idle=50
spring.redis.pool.min-idle=0
spring.redis.pool.max-active=50
spring.redis.pool.max-wait=-1
spring.redis.pool.max-total=50
spring.redis.sentinel.master=mymaster
spring.redis.sentinel.nodes=192.168.9.128:26379,192.168.9.128:26380,192.168.9.128:26381

查询缓存配置(applicationContext-cache.xml)

    <!-- Redis查询缓存 - start -->
    <!-- 开启缓存注解 -->
    <cache:annotation-driven cache-manager="searchCacheManager"/>

    <!-- Redis缓存管理器 -->
    <bean id="searchCacheManager" class="org.springframework.data.redis.cache.RedisCacheManager">
        <constructor-arg name="redisOperations" ref="redisTemplate"/>
    </bean>

    <!-- Redis模板 -->
    <bean id="redisTemplate" class="org.springframework.data.redis.core.RedisTemplate">
        <property name="connectionFactory" ref="jedisConnectionFactory"/>
        <property name="keySerializer" ref="stringSerializer"/>
        <property name="valueSerializer" ref="jackson2JsonSerializer"/>
    </bean>

    <bean name="stringSerializer" class="org.springframework.data.redis.serializer.StringRedisSerializer"/>
    <bean name="jackson2JsonSerializer"
            class="org.springframework.data.redis.serializer.GenericJackson2JsonRedisSerializer"/>

    <!-- Jedis客户端连接工厂 -->
    <bean id="jedisConnectionFactory" class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory"
            p:database="${spring.redis.database}" p:password="${spring.redis.password}">
        <constructor-arg name="sentinelConfig" ref="sentinelConfig"/>
        <constructor-arg name="poolConfig" ref="jedisPoolConfig"/>
    </bean>

    <!-- Redis哨兵 -->
    <bean id="sentinelConfig" class="org.springframework.data.redis.connection.RedisSentinelConfiguration">
        <constructor-arg name="master" value="${spring.redis.sentinel.master}"/>
        <constructor-arg name="sentinelHostAndPorts" value="${spring.redis.sentinel.nodes}"/>
    </bean>

    <!-- Jedis连接池 -->
    <bean id="jedisPoolConfig" class="redis.clients.jedis.JedisPoolConfig">
        <property name="maxTotal" value="${spring.redis.pool.max-total}"/>
        <property name="maxIdle" value="${spring.redis.pool.max-idle}"/>
        <property name="maxWaitMillis" value="${spring.redis.pool.max-wait}"/>
        <property name="testOnBorrow" value="true"/>
    </bean>
    <!-- Redis查询缓存 - end -->

参考资料:

  1. http://blog.mayongfa.cn/258.html
  2. https://www.cnblogs.com/mafly/p/redis_cluster.html
  3. https://tecadmin.net/install-ruby-latest-stable-centos/
  4. https://blog.csdn.net/liuchuanhong1/article/details/54601037
  5. https://www.cnblogs.com/HendSame-JMZ/p/7722104.html
  6. https://blog.csdn.net/u011521890/article/details/78088799
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,324评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,303评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,192评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,555评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,569评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,566评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,927评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,583评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,827评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,590评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,669评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,365评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,941评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,928评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,159评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,880评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,399评论 2 342

推荐阅读更多精彩内容