redsi一主两从三哨兵
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
附一:错误
redis:Error 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一主两从三哨兵的更多相关文章
- redis(一主两从三哨兵模式搭建)记录
转自:http://www.cnblogs.com/fly-piglet/p/9836314.html 目的: 让看看这篇文章的的人能够知道:软件架构.软件的安装.配置.基本运维的操作.高可用测试.也 ...
- 【运维技术】redis(一主两从三哨兵模式搭建)记录
redis(一主两从三哨兵模式搭建)记录 目的: 让看看这篇文章的的人能够知道:软件架构.软件的安装.配置.基本运维的操作.高可用测试.也包含我自己,能够节省对应的时间. 软件架构: 生产环境使用三台 ...
- 实践 - 搭建Redis一主两从三哨兵
实践 - 搭建Redis一主两从三哨兵 原因: 最近在复习Redis的时候,学习到了为了提高Redis集群的高可用性,有一个模式为哨兵模式.哨兵模式的作用是为了在主节点出现阻塞或者错误,无法接收数据的 ...
- Docker搭建Redis一主两从三哨兵
作者:oscarwin juejin.im/post/5d26b03de51d454fa33b1960 这次实验准备了三台云主机,系统为Debian,ip分别为:35.236.172.131 ,35. ...
- redis一主二从三哨兵
redis做集群的时候有很多种配置方法,一主二从三哨兵这种模式是官网推荐的.,写配置文件链接的时候,写的是哨兵地址,不是IP,用户名,密码之类的. 一主二从很好理解,一个主的redis,实时备份到两个 ...
- springboot 集成Redis一主二从三哨兵
1.Centos7 Redis一主二从三哨兵配置 Redis一主二从三哨兵环境搭建 2.接入过程 与集成redis单机不同的是jedis相关的配置做了修改,JedisPool换成了JedisSenti ...
- redis环境搭建及一主二从三哨兵模式配置
一.单机redis环境搭建 1.安装: OS:linux redhat6.5 下载redis 官网下载链接:https://redis.io/download 把安装包上传到服务器,进行解压 [roo ...
- docker compose搭建redis7.0.4高可用一主二从三哨兵集群并整合SpringBoot【图文完整版】
一.前言 redis在我们企业级开发中是很常见的,但是单个redis不能保证我们的稳定使用,所以我们要建立一个集群. redis有两种高可用的方案: High availability with Re ...
- redis 一主二从三哨兵
总体部署 一主二从三哨兵 ip地址分配分别为 主 127.0.0.1:6379 从 127.0.0.1:6389 从 127.0.0.1:6399 哨兵 127.0.0.1:26379 哨兵 127. ...
随机推荐
- Owin 自寄宿 asp.net web api
http://owin.org/ Owin 定义了webserver和webapplication之间的标准接口,目标就是为了解耦webapplication对webserver的依赖, 就是说以后可 ...
- T-SQL:开窗函数(十二)
1.基本概念 开窗函数分为两个部分分别是 1.聚合,排名,偏移,分布函数 . 2.开窗分区,排序,框架. 下面举个例子 SELECT empid, ordermonth, val, SUM(val) ...
- Numbers、Strings、Lists 笔记<一>
下一篇:流程控制<二> 阅读链接:官方Python3.7教程 废话:最近开始阅读python3.7文档,希望把容易混淆的知识记下来. 除法总是返回一个浮点数 >>> 8/ ...
- [PHP] 数据结构-循环链表的PHP实现
1.将单链表中终端结点的指针端由空指针改为指向头结点,单循环链表,循环链表和单链表的主要差异就在于循环的判断条件上原来是判断p->next是否为空,现在则是p->next不等于头结点,则循 ...
- 洛谷P3193 [HNOI2008]GT考试(dp 矩阵乘法)
题意 题目链接 Sol 设\(f[i][j]\)表示枚举到位置串的第i位,当前与未知串的第j位匹配,那么我们只要保证在转移的时候永远不会匹配即可 预处理出已知串的每个位置加上某个字符后能转移到的位置, ...
- input上传文件个数控制
HTML: <h3>请上传[2,5]个文件</h3> <form action="" enctype="multipart/form-dat ...
- vue.js 键盘enter事件的使用
在监听键盘事件时,我们经常需要检查常见的键值.Vue 允许为 v-on 在监听键盘事件时添加按键修饰符: <!-- 只有在 `keyCode` 是 13 时调用 `vm.submit()` -- ...
- struts2文件上传大小限制问题小结(引用)
最后解决办法: 页面js控制上传文件的大小,在页面进行控制.如下代码 inputs是所有文本上传input DOM //名称信息 var nameStr=''; //大小信息 var sizeStr= ...
- Leaflet 测试加载高德地图
<!DOCTYPE html> <html> <head> <title>Leaflet Quick Start Guide Example</ ...
- 在Visualforce页面中使用Visual Flow
在本文中,我们将通过一个示例说明如何将"流"(Visual Flow)用于Visualforce页面. 更全面的知识可以参考官方文档. 创建流 我们要创建一个流,它的作用是得到一个 ...