zoukankan      html  css  js  c++  java
  • redis 主从复制+读写分离+哨兵

    1.redis读写分离应用场景

    当数据量变得庞大的时候,读写分离还是很有必要的。同时避免一个redis服务宕机,导致应用宕机的情况,我们启用sentinel(哨兵)服务,实现主从切换的功能。redis提供了一个master,多个slave的服务。

      准备两个redis服务,依次命名文件夹子master,slave.端口号分别为192.168.121.130和192.168.121.131

    2.分别对两台服务器进行redis安装

      如果对Redis不熟悉的童鞋请看博主的redis单机安装的博文. 这里是传送门

    3.修改master配置文件

      这里192.168.121.131作为master

          vim redis.conf
    requirepass 123

      

    4.修改slave配置文件

        vim redis.conf
    port 6379
    slaveof 192.168.121.131 6379
    masterauth 123
    requirepass 123

    5.查看命令

    运行在redis客户端下 ./redis.cli -p 6379 

    查看主从信息:INFO replication

    6.测试

      

    主从复制,读写分离成功

    7.哨兵

    应用场景,主redis挂了会影响从机,所以redis提供了一个sentinel(哨兵),以此来实现主从切换的功能

    Redis哨兵(sentinel)实现主从切换:

    通过配置两个sentinel进程:/bin目录下(两个sentinel.conf内容相同)

    vim sentinel.conf 

    port 26379
    # 6379后的1为投票选数量满足1后就切换,可自行设置 sentinel monitor mymaster 192.168.121.131 6379 1
    daemonize yes
    sentinel auth-pass mymaster 123
    
    

    启动:redis-server sentinel.conf --sentinel

     当我们kill master进程后会自动主进行主从切换

    欢迎转载: 

    中文名:惠凡

    博客名:淹死的鱼o0

    转载时请说明出处:http://www.cnblogs.com/huifan/

     

  • 相关阅读:
    PHP命名空间
    php各个版本的区别
    MySQL的读写分离---主从复制、主主复制
    redis的安装和php的redis扩展
    php的设计模式
    git命令详情
    memcache和redis的对比
    mysql性能优化
    MySQL的分区、分表、集群
    nginx的反向代理和负载均衡
  • 原文地址:https://www.cnblogs.com/huifan/p/9391974.html
Copyright © 2011-2022 走看看