zoukankan      html  css  js  c++  java
  • centos7搭建redis主从复制,并模拟故障切换。

     Cntos7搭建redis主从复制,并模拟故障主从切换

    主从复制搭建

    主机:192.168.161.179

    从机:192.168.161.180

    1、        安装主redis

    自己本地环境,关闭防火墙。

     #sed -i 's/SELINUX=enforcing/SELINUX=disabled/g' /etc/selinux/config

    #setenforce 0

        #systemctl stop firewalld   

    #systemctl disable firewalld

               安装相关依赖

               yum install –y gcc gcc-c++ make

    下载redis4.0.2包

    http://download.redis.io/releases/redis-4.0.2.tar.gz

    下载好后上传至服务器,进行解压(我上传至opt目录)

    解压后编译安装

    cd redis-4.0.2/

    make PREFIX=/usr/local/redis install

    将redis-4.0.2目录的redis.conf sentinel.conf配置文件复制到安装目录/usr/local/redis

    将redis-4.0.2/src目录的redis-cli redis-sentinel redis-server复制到安装目录 /usr/local/redis/

    修改配置

    Cd /usr/local/redis

    Vim redis.conf

    修改内容如下:

      将bind 127.0.0.1这一行注释掉

      将protected-mode yes改为protected-mode no

      将daemonize no改为daemonize yes

     将logfile ""改为logfile"/usr/local/redis/log/redis.log"

    添加密码

    Vim sentinel.conf

    将sentinel monitor mymaster 127.0.0.1 6379 2改为sentinel monitor mymaster 192.168.161.179 6379 2

    添加一下几行

    daemonize yes

    protected-mode no

    logfile "/usr/local/redis/log/sentinel.log"

    2、配置redis从

    安装的方法及路径与redis1主一样

    复制redis配置文件

    cp redis.conf sentinel.conf /usr/local/redis/

    cp redis-cli redis-sentinel redis-server /usr/local/redis/

    cd /usr/local/redis/

    vim redis.conf

    修改内容如下:

    将bind 127.0.0.1注释掉

    将protected-mode yes改为protected-mode no

    将daemonize no改为daemonize yes

    将logfile ""改为logfile " /usr/local/redis/log/redis.log "

    添加一行slaveof   192.168.161.179        6379   (主服务器ip)

    配置密码

    修改sentinel.conf

    修改内容如下:

    192.168.161,179是主服务器ip,这里是写主服务器的ip。

    sentinel monitor mymaster 192.168.161.179 6379 2

    daemonize yes

    protected-mode no

    logfile "/usr/local/redis/log/sentinel.log"

    3、启动主机

    启动主redis

    ./redis-cli -p 6379 -a 123456

    启动从redis    

    ./redis-cli -p 6379 -a 1234567

    4、测试是否可以主从复制

    主机上设置一个键值对

    #set a 1

    在从主机测试是否同步

    #get a

    从主机测试

    #set b 2  (报错因为从机是只读,OK主从已经搭建ok)

    日常的启动关闭主从的命令如下。

    主从复制搭建成功。

    模拟故障切换,将slave切换为主

    5、测试主从切换,当主(master)出现故障时将从(slave)切换成主。

    模拟主挂了,关闭主

    Ps –ef | grep redis

    ./redis-cli -p 6379 -a 123456 shutdown

    在从设备上关闭复制功能,并将从服务器变为主服务器,原来所得的数据集不会被丢弃。

    ./redis-cli -p 6379 -a 1234567 slaveof NO ONE

     

    登陆:./redis-cli -p 6379 -a 1234567

    查看是否变为主:info

    从已经变回master,也可以写入数据

    出现故障时将slave(从)切换为主ok。

    6、测试原来的主redis恢复正常了,恢复回去。

    先将现在的主redis数据进行保存

    在将现在主redis根目录下的dump.rdb,文件拷贝到原来主redis的根目录,进行数据覆盖。

    (我是远程拷贝过去的)

    scp -P 22 dump.rdb root@192.168.161.179:/usr/local/redis/

    启动原来的主。

    在现在这个主在执行最后一步操作,就是将原来的主恢复,将现在这个主还是切换为从。

    ./redis-cli -p 6379 -a 1234567 slaveof 192.168. 161.179 6379

    指定主服务器。

     

    我们可以看看是否恢复原来的主,登陆原来的主查看。

    登陆redis成功输入:info

    已经恢复到原始环境。

  • 相关阅读:
    ArcObject获取ArcMap默认地理数据库的路径
    标准IO
    进程关系
    进程环境
    C语言基础知识位运算
    Bash 快捷键
    信号
    UNIX系统文件
    进程
    unix 文件属性
  • 原文地址:https://www.cnblogs.com/sxshaolong/p/10689342.html
Copyright © 2011-2022 走看看