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

已经恢复到原始环境。
centos7搭建redis主从复制,并模拟故障切换。的更多相关文章
- 搭建Redis主从复制的集群
在主从复制模式的集群里,主节点一般是一个,从节点一般是两个或多个,写入主节点的数据会被复制到从节点上,这样一旦主节点出现故障,应用系统能切换到从节点去读写数据,这样能提升系统的可用性.而且如果再采用主 ...
- CentOS7下搭建Redis主从复制
(1).实验环境 youxi1 192.168.1.6 Master服务器 youxi2 192.168.1.7 Slave服务器 (2).实验 1)两台服务器上yum安装Redis,启动并设置开机自 ...
- redis(一)Windows下安装redis服务、搭建redis主从复制
接下来会写一个redis实战系列,在此记录,有什么问题大家请随时批评. 好了,进入正题,这篇会将redis以windows服务形式提供服务(搭建一个简单的主从复制 M:6379:s:6380.6381 ...
- Centos7搭建redis集群及安装sentinel
准备三个节点,系统版本为CentOS7.3 11.0.8.15 master 11.0.8.16 slave01 11.0.8.17 slave02 1.安装redis # yum install - ...
- CentOS7 搭建 Redis 集群
一.手动搭建 1. 准备节点 节点数量至少为 6 个才能保证组成完整高可用的集群 (1) 目录结构 cluster ├── 9001 │ ├── data │ │ ├── appendon ...
- 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 ...
- Centos7搭建redis,同一服务器启动两个端口的redis
1.安装redis [1]下载安装包 #准备安装文件夹 mkdir /usr/local/soft/redis #进入文件夹 cd /usr/local/soft/redis #下载安装包 wget ...
- [ 搭建Redis本地服务器实践系列一 ] :图解CentOS7安装Redis
上一章 [ 搭建Redis本地服务器实践系列 ] :序言 作为开场白介绍了下为什么要写这个系列,从这个章节我们就开始真正的进入正题,开始搭建我们本地的Redis服务器.那么关于Redis的基本概念,什 ...
- Linux基于Docker的Redis主从复制、哨兵模式搭建
本教程基于CentOS7,开始本教程前,请确保您的Linux系统已安装Docker. 1.使用docker下载redis镜像 docker pull redis 安装完成后,使用docker imag ...
随机推荐
- vscode 右键文件或者文件夹显示菜单
1.这个是可以在安装时直接选择显示的,如果跟我一样没有选也不愿意重新安装的,可以复制下面代码保存为vsCodeOpenFolder.reg,红色部分是vscode安装路径,换成自己本地路径即可. 双击 ...
- 根据URL发起HTTP请求,我的HTTPHelper。
完整的demo using System; using System.Collections.Generic; using System.Linq; using System.Text; using ...
- 华为AI应用创新大赛即将开启!公开课已备好!
为鼓励开发者创新,挖掘前沿创新能力的应用及服务,帮开发者打造爆款应用的同时丰富终端消费者的用户体验,由设立10亿激励基金耀星计划扶持的华为创新竞赛平台即将开启. 竞赛平台将滚动推出AI.HAG.AR. ...
- 前端要给力之:语句在JavaScript中的值
文件夹 文件夹 问题是语句有值吗 那么说你骗我咯 有啥米用呢 研究这个是不是闲得那个啥疼 ES5ES6有什么差异呢 结论是ES6是改了规则但更合理 最后不不过if语句 这两天在写语言精髓那本书的第三版 ...
- MongoDB学习笔记<六>
继续mongoDB的学习 --索引具体解释 --索引管理 --空间索引 1.创建简单索引 (1)先准备20万条数据 for(var i = 0;i< 200000;i++){ db.books. ...
- springcloud与docker微服务架构实战--笔记
看了<微服务那些事>之后,Spring boot和Spring Cloud的关系理清楚了,Spring cloud各个模块的作用也了解了. 但是,Spring cloud 与Docker的 ...
- python知识点导图(搜集)
第一章 基本环境 第二章 内置类型 第三章 表达式 第四章 函数 第五章 迭代器 第六章 模块 第七章 类 第八章 异常 第九章 装饰器 第十章 描述符 第十一章 元类 第十二章 标准库 Re模块 附 ...
- 使用IntelliJ IDEA 15和Maven创建Java Web项目(转)
1. Maven简介 相对于传统的项目,Maven 下管理和构建的项目真的非常好用和简单,所以这里也强调下,尽量使用此类工具进行项目构建, 它可以管理项目的整个生命周期. 可以通过其命令做所有相关的工 ...
- 九度OJ 1069:查找学生信息 (排序、查找)
时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:11240 解决:3024 题目描述: 输入N个学生的信息,然后进行查询. 输入: 输入的第一行为N,即学生的个数(N<=1000) 接 ...
- c++中的重载、覆盖和隐藏
1 重载发生在同一个类内部. 同一个类内部,具有相同的函数名,但是参数列表不同,那么就是重载.因为c++编译器编译时,将函数名和函数列表一起对函数进行了重命名. 2 覆盖和隐藏发生在子类和父类之间. ...