1.前提准备

防火墙,selinux,主机名解析,所有主机安装gcc

[root@localhost ~]# vim /etc/hosts

192.168.122.135  redis_master

192.168.122.136  redis_slave01

192.168.122.137  redis_slave02

192.168.122.138  sentinel01

192.168.122.139  sentinel02

192.168.122.140  sentinel03

[root@localhost ~]# for i in 135 136 137 138 139 140

> do

> rsync /etc/hosts 192.168.122.$i:/etc/hosts

> done

以192.168.122.135位例

[root@redis_master soft]# tar zxf redis-4.0.11.tar.gz

[root@redis_master soft]# cd redis-4.0.11/

[root@redis_master redis-4.0.11]# make MALLOC=libc

[root@redis_master redis-4.0.11]# make PREFIX=/soft/redis install

[root@redis_master redis-4.0.11]# mkdir -p /soft/redis/conf/

[root@redis_master redis-4.0.11]# cp redis.conf /soft/redis/conf/

<三台哨兵[root@redis_master redis-4.0.11]# cp sentinel.conf /soft/redis/conf/

>

2.主从配置

192.168.122.135(master)

[root@redis_master redis]# mkdir data

[root@redis_master redis]# mkdir logs

[root@redis_master conf]# vim redis.conf

bind 192.168.122.135

#支持内网/本地访问,比如 bind 172.31.175.142 127.0.0.1

protected-mode no

是否开启保护模式,默认开启。要是配置里没有指定bind和密码。开启该参数后,redis只会本地进行访问,拒绝外部访问。要是开启了密码和bind,可以开启。否则最好关闭,设置为no。

port 6379

#端口号

daemonize yes

#是否在后台执行,yes:后台运行;no:不是后台运行

pidfile /var/run/redis_6379.pid

#redis的进程文件

logfile /soft/redis/logs

#指定了记录日志的文件。

dir /soft/redis/data

#数据目录,数据库的写入会在这个目录。

slave-read-only yes

#作为从服务器,默认情况下是只读的(yes),可以修改成NO,用于写

slave-priority 100

#当master不可用,Sentinel会根据slave的优先级选举一个master。最低的优先级的slave,当选master。而配置成0,永远不会被选举。

appendonly yes

#redisrdbredissaveAppend Only FileRedis appendonly.aof RedisRDBappendfilename "appendonly.aof"

#aof文件名

appendfsync everysec

#aof持久化策略的配置

#no表示不执行fsync,由操作系统保证数据同步到磁盘,速度最快。

#always表示每次写入都执行fsync,以保证数据同步到磁盘。

#everysec表示每秒执行一次fsync,可能会导致丢失这1s数据

192.168.122.136(slave01)

[root@redis_slave01 redis]# mkdir data

[root@redis_slave01 redis]# mkdir logs

[root@redis_slave01 conf]# vim redis.conf

bind 192.168.122.136

protected-mode no

port 6379

daemonize yes

pidfile /var/run/redis_6379.pid

logfile /soft/redis/logs

dir /soft/redis/data

slave-read-only yes

slaveof 192.168.122.135 6379

#复制选项,slave复制对应的master。

slave-priority 90

appendonly yes

appendfilename "appendonly.aof"

appendfsync everysec

192.168.122.137(slave02)

[root@redis_slave02 redis]# mkdir data

[root@redis_slave02 redis]# mkdir logs

[root@redis_slave02 conf]# vim redis.conf

bind 0.0.0.0

protected-mode no

port 6379

daemonize yes

pidfile /var/run/redis_6379.pid

logfile /soft/redis/logs

dir /soft/redis/data

slave-read-only yes

slaveof 192.168.122.135 6379

slave-priority 80

appendonly yes

appendfilename "appendonly.aof"

appendfsync everysec

3.哨兵配置

192.138.122.138(sentinel01)

[root@sentinel01 redis]# mkdir temp

[root@sentinel01 redis]# mkdir logs

[root@sentinel01 conf]# vim sentinel.conf

protected-mode no

port 26379

dir /soft/redis/temp

daemonize yes

logfile "/soft/redis/logs/sentinel_log.log"

sentinel monitor redis1 192.168.122.135 6379 2

sentinelmaster,192.168.122.135:63792sentinelmaster redissentinelsentinelmaster22sentinelmastermastersentinel parallel-syncs redis1 1

failoverslavemasterfailoverslavereplication 1 slavesentinel down-after-milliseconds redis1 10000

会向发送心跳来确认是否存活,如果在一定时间范围内不回应或者是回复了一个错误消息,那么这个会主观地单方面地认为这个已经不可用了也简称为。而这个就是用来指定这个一定时间范围的,单位是毫秒。

sentinel failover-timeout redis1 60000

#failover过期时间,当failover开始后,在此时间内仍然没有触发任何failover操作,当前sentinel  将会认为此次failover失败

192.168.122.139(sentinel02)

[root@sentinel02 redis]# mkdir temp

[root@sentinel02 redis]# mkdir logs

[root@sentinel02 conf]# vim sentinel.conf

protected-mode no

port 26379

dir /soft/redis/temp

daemonize yes

logfile "/soft/redis/logs/sentinel_log.log"

sentinel monitor redis1 192.168.122.135 6379 2

sentinel parallel-syncs redis1 1

sentinel down-after-milliseconds redis1 10000

sentinel failover-timeout redis1 60000

192.168.122.140(sentinel03)

[root@sentinel03 redis]# mkdir logs

[root@sentinel03 redis]# mkdir temp

[root@sentinel03 conf]# vim sentinel.conf

protected-mode no

port 26379

dir /soft/redis/temp

daemonize yes

logfile "/soft/redis/logs/sentinel_log.log"

sentinel monitor redis1 192.168.122.135 6379 2

sentinel parallel-syncs redis1 1

sentinel down-after-milliseconds redis1 10000

sentinel failover-timeout redis1 60000

4.启动redis主从,哨兵

[root@redis_master bin]# ./redis-server ../conf/redis.conf

[root@redis_slave01 bin]# ./redis-server ../conf/redis.conf

[root@redis_slave02 bin]# ./redis-server ../conf/redis.conf

[root@sentinel01 bin]# ./redis-server ../conf/sentinel.conf --sentinel

[root@sentinel02 bin]# ./redis-server ../conf/sentinel.conf --sentinel

[root@sentinel03 bin]# ./redis-server ../conf/sentinel.conf --sentinel

附一:错误

redisError condition on socket for SYNC: No route to host

redis问题解决:Error condition on socket for SYNC: No route to host

第一种方案:

1.telnet ip port 是否通

2.使用netstat -tnlp 查询IP地址是127.0.0.1而不是0.0.0.0或者本机ip(127.0.0.1代表只能本机使用)

3.修改master中redis.conf中bind绑定0.0.0.0或者本机ip

2.重启master服务

如果第一种方案行不通,那就使用第二种方案;

第二种方案:

1.关闭防火墙:service iptables stop

2.如果出现以下异常

Redirecting to /bin/systemctl stop iptables.service

Failed to stop iptables.service: Unit iptables.service not loaded.

(其他异常也可以试下)

3.进入/etc/sysconfig/目录下查询有没有iptables文件

4.如果没有,使用systemctl stop firewalld 关闭防火墙

5.使用yum install iptables-services 安装或者更新服务

6.service iptables stop尝试下关闭服务器

7.关闭成功无异常,重启maste和slave,进入redis-cli 输入info就能看到maste和slave信息了

5.验证redis:master-slave(info replication)

[root@redis_master bin]# ./redis-cli -h 192.168.122.135

192.168.122.135:6379> SET age 23

OK

192.168.122.135:6379> get age

"23"

192.168.122.136:6379> get age

"23"

192.168.122.137:6379> get age

"23"

6.验证哨兵集群(反客为主)

这时我们让master挂掉,查看哨兵日志

tail -50f sentinel_log.log 按照我们配置的 “slave-priority”的值,值小的192.168.122.137(slave02)将成为新的master.192.168.122.136成为192.168.122.137的slave. 在将192.168.122.135这台机器的redis服务起来后发现变成了新master的slave

redsi一主两从三哨兵的更多相关文章

  1. redis(一主两从三哨兵模式搭建)记录

    转自:http://www.cnblogs.com/fly-piglet/p/9836314.html 目的: 让看看这篇文章的的人能够知道:软件架构.软件的安装.配置.基本运维的操作.高可用测试.也 ...

  2. 【运维技术】redis(一主两从三哨兵模式搭建)记录

    redis(一主两从三哨兵模式搭建)记录 目的: 让看看这篇文章的的人能够知道:软件架构.软件的安装.配置.基本运维的操作.高可用测试.也包含我自己,能够节省对应的时间. 软件架构: 生产环境使用三台 ...

  3. 实践 - 搭建Redis一主两从三哨兵

    实践 - 搭建Redis一主两从三哨兵 原因: 最近在复习Redis的时候,学习到了为了提高Redis集群的高可用性,有一个模式为哨兵模式.哨兵模式的作用是为了在主节点出现阻塞或者错误,无法接收数据的 ...

  4. Docker搭建Redis一主两从三哨兵

    作者:oscarwin juejin.im/post/5d26b03de51d454fa33b1960 这次实验准备了三台云主机,系统为Debian,ip分别为:35.236.172.131 ,35. ...

  5. redis一主二从三哨兵

    redis做集群的时候有很多种配置方法,一主二从三哨兵这种模式是官网推荐的.,写配置文件链接的时候,写的是哨兵地址,不是IP,用户名,密码之类的. 一主二从很好理解,一个主的redis,实时备份到两个 ...

  6. springboot 集成Redis一主二从三哨兵

    1.Centos7 Redis一主二从三哨兵配置 Redis一主二从三哨兵环境搭建 2.接入过程 与集成redis单机不同的是jedis相关的配置做了修改,JedisPool换成了JedisSenti ...

  7. redis环境搭建及一主二从三哨兵模式配置

    一.单机redis环境搭建 1.安装: OS:linux redhat6.5 下载redis 官网下载链接:https://redis.io/download 把安装包上传到服务器,进行解压 [roo ...

  8. docker compose搭建redis7.0.4高可用一主二从三哨兵集群并整合SpringBoot【图文完整版】

    一.前言 redis在我们企业级开发中是很常见的,但是单个redis不能保证我们的稳定使用,所以我们要建立一个集群. redis有两种高可用的方案: High availability with Re ...

  9. redis 一主二从三哨兵

    总体部署 一主二从三哨兵 ip地址分配分别为 主 127.0.0.1:6379 从 127.0.0.1:6389 从 127.0.0.1:6399 哨兵 127.0.0.1:26379 哨兵 127. ...

随机推荐

  1. 移动端地区选择控件mobile-select-area

    由于之前的[js开源组件开发]js手机联动选择地区仿ios 开源git 很受欢迎,于是我又对其进行了一些优化,包括可选的范围变大了,添加了默认空首地址的功能,也添加了更多api参数,首先我们先来看下这 ...

  2. 解决VM提示:VMware Workstation cannot connect to the virtual machine. Make sure you have rights to run the program, access all directories the program uses, and access all directories for temporary files.

    问题: 在开启虚拟机的时候报: VMware Workstation cannot connect to the virtual machine. Make sure you have rights ...

  3. 洛谷P2178 [NOI2015]品酒大会(后缀自动机 线段树)

    题意 题目链接 Sol 说一个后缀自动机+线段树的无脑做法 首先建出SAM,然后对parent树进行dp,维护最大次大值,最小次小值 显然一个串能更新答案的区间是\([len_{fa_{x}} + 1 ...

  4. json&pickle数据序列化模块

    用于序列化的模块 json,通用的序列化方式,序列化成为str类型,支持所有语言识别,序列化的数据具有局限性. pickle,python的所有数据类型都可以被序列化,序列化为bites格式,只适用于 ...

  5. SEIG Modbus 3.4 CVE-2013-0662 漏洞分析与利用

    前言 Schneider Electric Modbus Serial Driver 会监听 27700 端口,程序在处理客户端发送的数据时会导致栈溢出. 测试环境: windows xp sp3 相 ...

  6. ADB命令行控制界面开关

    以下命令需要root权限:   svc命令     这个脚本在/system/bin目录下,这个命令可以用来控制电源管理,wifi开关,数据开关(就是上网流量) svc power stayon [t ...

  7. flask中的url_for的使用

    有多个路由的程序需要连接不同的网页链接,例如导航条 模板中构建正确的动态url较为困难,如果重定义路由,模板中的链接失效 url_for()函数: 使用url映射中保存的信息生成url 用法: 用视图 ...

  8. Python数据清洗基本流程

    # -*- coding: utf-8 -*-"""Created on Wed Jul 4 18:40:55 2018 @author: zhen"" ...

  9. mysql常用赋权命令

    GRANT 所需权限 ON 库名.表名 TO '账号'@'允许访问的IP地址'; 把中文按需替换掉 所需权限:select.insert.delete.update按需要来. 上面那个允许访问IP ' ...

  10. HTTP请求行、请求头、请求体详解(转)

    转自 https://blog.csdn.net/u010256388/article/details/68491509/     HTTP请求报文解剖 HTTP请求报文由3部分组成(请求行+请求头+ ...