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

已经恢复到原始环境。

centos7搭建redis主从复制,并模拟故障切换。的更多相关文章

  1. 搭建Redis主从复制的集群

    在主从复制模式的集群里,主节点一般是一个,从节点一般是两个或多个,写入主节点的数据会被复制到从节点上,这样一旦主节点出现故障,应用系统能切换到从节点去读写数据,这样能提升系统的可用性.而且如果再采用主 ...

  2. CentOS7下搭建Redis主从复制

    (1).实验环境 youxi1 192.168.1.6 Master服务器 youxi2 192.168.1.7 Slave服务器 (2).实验 1)两台服务器上yum安装Redis,启动并设置开机自 ...

  3. redis(一)Windows下安装redis服务、搭建redis主从复制

    接下来会写一个redis实战系列,在此记录,有什么问题大家请随时批评. 好了,进入正题,这篇会将redis以windows服务形式提供服务(搭建一个简单的主从复制 M:6379:s:6380.6381 ...

  4. Centos7搭建redis集群及安装sentinel

    准备三个节点,系统版本为CentOS7.3 11.0.8.15 master 11.0.8.16 slave01 11.0.8.17 slave02 1.安装redis # yum install - ...

  5. CentOS7 搭建 Redis 集群

    一.手动搭建 1. 准备节点 节点数量至少为 6 个才能保证组成完整高可用的集群 (1) 目录结构 cluster ├── 9001 │   ├── data │   │   ├── appendon ...

  6. CentOS7配置redis主从复制

    规划 ip port role 192.168.1.31 6379 master 192.168.1.32 6379 slave 192.168.1.33 6379 slave 0.关闭防火墙 sys ...

  7. Centos7搭建redis,同一服务器启动两个端口的redis

    1.安装redis [1]下载安装包 #准备安装文件夹 mkdir /usr/local/soft/redis #进入文件夹 cd /usr/local/soft/redis #下载安装包 wget ...

  8. [ 搭建Redis本地服务器实践系列一 ] :图解CentOS7安装Redis

    上一章 [ 搭建Redis本地服务器实践系列 ] :序言 作为开场白介绍了下为什么要写这个系列,从这个章节我们就开始真正的进入正题,开始搭建我们本地的Redis服务器.那么关于Redis的基本概念,什 ...

  9. Linux基于Docker的Redis主从复制、哨兵模式搭建

    本教程基于CentOS7,开始本教程前,请确保您的Linux系统已安装Docker. 1.使用docker下载redis镜像 docker pull redis 安装完成后,使用docker imag ...

随机推荐

  1. OpenGL研究3.0 多边形区域填充

    OpenGL研究3.0 多边形区域填充 DionysosLai(906391500@qq.com)2014-06-22 所谓多边形区域填充.就是将多边形内部区域,所有已相同色块填充.注意:这里讨论的多 ...

  2. hdu1316

    链接:pid=1316" target="_blank">点击打开链接 题意:问区间[a,b]中有多少斐波那契数 代码: #include <iostream ...

  3. 一文了解ConfigurationConditon接口

    ConfigurationCondition 接口说明 @Conditional 和 Condition ​ 在了解ConfigurationCondition 接口之前,先通过一个示例来了解一下@C ...

  4. 【C/C++】高亮C++中函数的重写——函数名相同?参数列表相同?返回值相同?

    C++的重载给人留下了非常深刻的影响,原因是重载的条件很值得注意:函数名相同,参数列表不相同的两个函数构成重载函数,而无关乎二者的返回值. 但是C++中的函数重写又是另一码事.标准规定:只要函数名相同 ...

  5. Uboot的串口下载文件命令:loads / loadb / loady

    1. loads loads [ off ] 通过串口,下载S-Rec文件到off位置 loads命令可以通过串口线下载S-Record格式文件. 2. loadb loadb [ off ] [ b ...

  6. JavaWeb学习总结第四篇--Servlet开发

    Servlet开发 用户在浏览器中输入一个网址并回车,浏览器会向服务器发送一个HTTP请求.服务器端程序接受这个请求,并对请求进行处理,然后发送一个回应.浏览器收到回应,再把回应的内容显示出来.这种请 ...

  7. Unity3D 动态地创建识别图

    前面介绍了EasyAR的单图识别,它是提前在Unity设置好图片路径的,那么如果我们的图片是存储在服务器上的,那么我们肯定不能直接把服务的图片地址填上去了.这个时候我们可以动态地创建识别图.步骤如下: ...

  8. 仿易讯clientloading效果

    以下来实现一个loading效果.详细效果例如以下: 首先对这个效果进行拆分,它由以下部分组成: 1 一个"闪电"样式的图案. 2 "闪电"图案背后是一个圆角矩 ...

  9. 【BZOJ3956】Count 主席树+单调栈

    [BZOJ3956]Count Description Input Output Sample Input 3 2 0 2 1 2 1 1 1 3 Sample Output 0 3 HINT M,N ...

  10. ZOJ 3502 Contest <状态压缩 概率 DP>

    链接:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=3502 #include <iostream> #incl ...