Redis主从复制、哨兵模式

1.部署主从

环境:主IP:10.0.0.15,端口6379;从IP:10.0.0.16,端口6379.

原理:基于RDB持久化的功能来实现主从复制的功能.

a.linux-redis1(10.0.0.15)

cd /usr/local/redis/
grep "^[a-Z]" redis.conf  # 列出几个修改过的配置
bind 10.0.0.15
protected-mode no
port 6379
daemonize yes
loglevel notice
logfile /usr/local/redis/logs/redis.log
databases 16
save 900 1
save 300 10
save 60 10000
dir /data/redis

b.linux-redis2(10.0.0.16)

cd /usr/local/redis/
grep "^[a-Z]" redis.conf  # 其余与上面的配置保持一致
bind 10.0.0.16
slaveof  10.0.0.15 6379

# 启动脚本
cat /usr/lib/systemd/system/redis.service

IP=`ifconfig eth0 | awk -F"[ ]+" ‘NR==2{print $3}‘`
[Unit]
Description=The redis-server Process Manager
After=network.target

[Service]
ExecStart=/usr/local/redis/src/redis-server /usr/local/redis/redis.conf --daemonize no
ExecStop=/usr/local/redis/src/redis-cli -h $IP shutdown

[Install]
WantedBy=multi-user.target

systemctl daemon-reload
systemctl enable redis
systemctl start redis

c.测试

主redis上输入数据

从redis上获取数据

此时的从redis只能读取数据,不能写入,主redis宕机之后,也不能写入,手动切换:

主redis上输入shutdown,从redis上输入slaveof no one,就可以写入数据了;

此时如果有其他的从redis,则输入slaveof 10.0.0.16 6379即可更换主redis;

此时如果刚才宕掉的redis又恢复了,则还是输入slaveof 10.0.0.16 6379,由主变成从.

2.利用哨兵模式实现主从自动切换

cat sentinel.conf  # 当启动模式之后,这个配置文件中会自动增加从redis的信息
port 26379
dir "/tmp"
sentinel myid b84f8aea247ad5f7ea48c6a4921d0cca5ffc915f
sentinel monitor mymaster 10.0.0.15 6379 1
sentinel down-after-milliseconds mymaster 10000
sentinel failover-timeout mymaster 18000

./src/redis-sentinel sentinel.conf
# Sentinel ID is b84f8aea247ad5f7ea48c6a4921d0cca5ffc915f
# +monitor master mymaster 10.0.0.15 6379 quorum 1
* +slave slave 10.0.0.16:6379 10.0.0.16 6379 @ mymaster 10.0.0.15 6379
* +slave slave 10.0.0.17:6379 10.0.0.17 6379 @ mymaster 10.0.0.15 6379

# 配置文件中自动生成了这些内容
# Generated by CONFIG REWRITE
sentinel config-epoch mymaster 0
sentinel leader-epoch mymaster 0
sentinel known-slave mymaster 10.0.0.16 6379
sentinel known-slave mymaster 10.0.0.17 6379
sentinel current-epoch 0

在10.0.0.15上停掉主redis:redis-cli -h 10.0.0.15 shutdown

主redis宕了,其余redis开始进行选举,在经过选举之后,其中的一个从redis会变为主redis,通过日志或者配置文件都可以看出来,此时谁是master.

cat sentinel.conf
port 26379
dir "/tmp"
sentinel myid b84f8aea247ad5f7ea48c6a4921d0cca5ffc915f
sentinel monitor mymaster 10.0.0.17 6379 1
sentinel down-after-milliseconds mymaster 10000
sentinel failover-timeout mymaster 18000
# Generated by CONFIG REWRITE
sentinel config-epoch mymaster 1
sentinel leader-epoch mymaster 1
sentinel known-slave mymaster 10.0.0.15 6379
sentinel known-slave mymaster 10.0.0.16 6379
sentinel current-epoch 1

# 此时启动10.0.0.15上的redis,它也只能"俯首称臣"
convert-to-slave slave 10.0.0.15:6379 10.0.0.15 6379 @ mymaster 10.0.0.17 6379

# 在配置文件sentinel.conf中加上这三行比较合适
daemonize yes
protected-mode no
logfile "/var/log/sentinel.log"

Redis主从利用Keepalived自动切换:http://blog.51cto.com/tryingstuff/2093119

原文地址:https://www.cnblogs.com/fawaikuangtu123/p/10388238.html

时间: 2024-08-24 09:16:31

Redis主从复制、哨兵模式的相关文章

Redis主从复制结构模式,哨兵模式

设置临时生效 1.配置从库 192.168.4.58:6058> info replication // 查看主从配置信息 # Replication role:master connected_slaves:0 master_replid:784d7d32d7f522703ca763c6a1a4bb0f8c1db591 master_replid2:0000000000000000000000000000000000000000 master_repl_offset:0 second_repl

redis主从+哨兵模式

主从模式配置分为手动和配置文件两种方式进行配置,我现在有192.168.238.128(CentOS1).192.168.238.131(CentOS3).192.168.238.132(CentOS4)几台机器,只是配置文件的配置方式是降手动配置的命令放在配置文件中而已,本质是一致的.下面将对配置文件方式进行配置,我所述的案例,是基于我自己的另一篇博文<Redis的安装.服务配置>之上: 1.我将CentOS4作为主数据库,其他 模拟为从数据库 2.将CentOS1目录切换到/etc/red

Redis sentinel 哨兵模式集群方案配置

第一个方案是创建 redis cluster,第二种方案就是用哨兵模式来进行主从替换以及故障恢复.兵模式集群方案配置 一.sentinel介绍 Sentinel作用: 1):Master状态检测 2):如果Master异常,则会进行Master-Slave切换,将其中一个Slave作为Master,将之前的Master作为Slave 3):Master-Slave切换后,master_redis.conf.slave_redis.conf和sentinel.conf的内容都会发生改变,即mast

Redis 之 哨兵模式

一.哨兵模式的概念 哨兵模式是一种特殊的模式,首先Redis提供了哨兵的命令,哨兵是一个独立的进程,作为进程,它会独立运行.其原理是哨兵通过发送命令,等待Redis服务器响应,从而监控运行的多个Redis实例. 二.实验环境 三.安装redis服务 1.指定外部安装源wget -O /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-6.repo2.安装redisyum -y install redis 四.配置maste

学习记录03 --- 重新配置redis的哨兵模式

查阅多方资料后,才发现昨天写的配置哨兵模式开启是错的,尴尬... 今天重新来配置一下,当然为了避免出现问题,先理清下思路,整理好信息 哨兵模式监控的节点最少三个,昨天监控了2个是不够的,所以我又再一次的拷贝了一份redis.conf 服务器类型 是否主服务器 IP地址 端口号 Redis 是 192.168.200.128 6379 Redis 否 192.168.200.128 6380 Redis 否 192.168.200.128 6381 Sentinel - 192.168.200.1

redis的哨兵模式(redis有密码)

环境搭建: 前言: 小编使用的redis的版本号是5.0.5,可能会略有不同,例如redis.conf配置文件中,没有slaveof这一项配置 虚拟机一定要关闭掉防火墙 本次使用7006作为master,7007,7008作为slave 为了方便直接在slave的配置文件中写好master的配置(配从不配主),配置好master的ip,redis的端口和密码 slave的redis.conf里主机配置: 启动主机和从机后一主二从模式就ok了,可以简单测试一下 下面开始配置哨兵 新建了一个sent

Redis之哨兵模式Sentinel配置与启动(五)

一.介绍 上一篇我们已经介绍了Redis的主从复制,传送门:<Redis高可用之主从复制实践(四)>,想必大家对redis已经有一个概念了,那么问题来了,如果redis主从复制的master服务器挂掉了,那么整体redis就崩溃了,因为master无法进行写数据,导致slave中无法更新数据. 那么为了解决这个问题我们就需要有一种方案让redis宕机后可以自动进行故障转移,还好redis给我们提供一种高可用解决方案 Redis-Sentinel.Redis-sentinel本身也是一个独立运行

Redis 主从哨兵模式搭建

安装单机版redis 1.编译redis cd /opt/ tar zxvf redis-3.0.6.tar.gz cd redis-3.0.6 make 2.创建redis目录 cd src/ mkdir /usr/local/redis cp redis-cli /usr/local/redis/ cp redis-server /usr/local/redis/ cd .. cp redis.conf /usr/local/redis/ 3.修改配置文件 cd /usr/local/red

redis sentinel哨兵模式集群搭建教程

1.环境说明 我们将使用192.168.220.128.192.168.220.129.192.168.220.130三台机器搭建sentinel集群 当前我们已在192.168.220.128上按redis安装教程安装了redis,192.168.220.129和192.168.220.130两台上没有安装 2.配置并启动192.168.220.128上的sentinel 2.1修改conf/redis.conf,配置masterauth字段值 2.2修改conf/sentinel.conf,

redis主从复制+哨兵配置

1.redis主从: 主从有好几种复制模式 一主一从:一个主服务器,一个从服务器,适合并发量较小的 一主多从:适合于读多写少的,结构: 3. 树状结构 原文地址:https://www.cnblogs.com/lonecloud/p/9113999.html