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. ...
随机推荐
- 移动端地区选择控件mobile-select-area
由于之前的[js开源组件开发]js手机联动选择地区仿ios 开源git 很受欢迎,于是我又对其进行了一些优化,包括可选的范围变大了,添加了默认空首地址的功能,也添加了更多api参数,首先我们先来看下这 ...
- 解决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 ...
- 洛谷P2178 [NOI2015]品酒大会(后缀自动机 线段树)
题意 题目链接 Sol 说一个后缀自动机+线段树的无脑做法 首先建出SAM,然后对parent树进行dp,维护最大次大值,最小次小值 显然一个串能更新答案的区间是\([len_{fa_{x}} + 1 ...
- json&pickle数据序列化模块
用于序列化的模块 json,通用的序列化方式,序列化成为str类型,支持所有语言识别,序列化的数据具有局限性. pickle,python的所有数据类型都可以被序列化,序列化为bites格式,只适用于 ...
- SEIG Modbus 3.4 CVE-2013-0662 漏洞分析与利用
前言 Schneider Electric Modbus Serial Driver 会监听 27700 端口,程序在处理客户端发送的数据时会导致栈溢出. 测试环境: windows xp sp3 相 ...
- ADB命令行控制界面开关
以下命令需要root权限: svc命令 这个脚本在/system/bin目录下,这个命令可以用来控制电源管理,wifi开关,数据开关(就是上网流量) svc power stayon [t ...
- flask中的url_for的使用
有多个路由的程序需要连接不同的网页链接,例如导航条 模板中构建正确的动态url较为困难,如果重定义路由,模板中的链接失效 url_for()函数: 使用url映射中保存的信息生成url 用法: 用视图 ...
- Python数据清洗基本流程
# -*- coding: utf-8 -*-"""Created on Wed Jul 4 18:40:55 2018 @author: zhen"" ...
- mysql常用赋权命令
GRANT 所需权限 ON 库名.表名 TO '账号'@'允许访问的IP地址'; 把中文按需替换掉 所需权限:select.insert.delete.update按需要来. 上面那个允许访问IP ' ...
- HTTP请求行、请求头、请求体详解(转)
转自 https://blog.csdn.net/u010256388/article/details/68491509/ HTTP请求报文解剖 HTTP请求报文由3部分组成(请求行+请求头+ ...