Redis系列之(二):Redis主从同步,读写分离
1. Redis主从同步
Redis支持主从同步。数据可以从主服务器向任意数量的从服务器上同步,同步使用的是发布/订阅机制。
2. 配置主从同步
Mater Slave的模式,从Slave向Master发起SYNC命令。
可以是1 Master 多Slave,可以分层,Slave下可以再接Slave,可扩展成树状结构。
2.1 配置Mater,Slave
配置非常简单,只需在slave的设定文件中指定master的ip和port
Master: test166
修改设定文件,服务绑定到ip上
1
2
|
# vi /etc/redis.conf bind 10.86.255.166 |
重启Redis
# systemctl restart redis
1
|
# less /etc/redis.conf |
Slave: test167
修改设定文件,指定Master
1
2
3
|
slaveof <masterip> <masterport> 指定master的ip和port masterauth <master-password> master有验证的情况下 slave- read -only yes 设置slave为只读模式 |
也可以用命令行设定:
1
2
|
redis 127.0.0.1:9999> slaveof localhost 6379 OK |
2.2 同期情况确认
Master:
1
2
3
4
5
6
|
127.0.0.1:6379> INFO replication # Replication role:master connected_slaves:1 slave0:ip=10.86.255.167,port=6379,state=online,offset=309,lag=1 …… |
Slave:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
127.0.0.1:6379> INFO replication # Replication role:slave master_host:10.86.255.166 master_port:6379 master_link_status:up master_last_io_seconds_ago:7 master_sync_in_progress:0 slave_repl_offset:365 slave_priority:100 slave_read_only:1 connected_slaves:0 master_repl_offset:0 repl_backlog_active:0 repl_backlog_size:1048576 repl_backlog_first_byte_offset:0 repl_backlog_histlen:0 |
同期正常时:
master_link_status:up
master_repl_offset和slave_repl_offset相等,
master_last_io_seconds_ago在10秒内。
2.3 Slave升级为Master
Master不可用的情况下,停止Master,将Slave的设定无效化后,Slave升级为Master
1
2
3
4
5
6
7
|
redis 127.0.0.1:9999> SLAVEOF NO ONE OK redis 127.0.0.1:9999> info ...... role:master ...... |
2.4 Health Check
Slave按照repl-ping-slave-period的间隔(默认10秒),向Master发送ping。
如果主从间的链接中断后,再次连接的时候,2.8以前按照full sync再同期。2.8以后,因为有backlog的设定,backlog存在master的内存里,重新连接之前,如果redis没有重启,并且offset在backlog保存的范围内,可以实现从断开地方同期,不符合这个条件,还是full sync
用monitor命令,可以看到slave在发送ping
1
2
3
|
127.0.0.1:6379> monitor OK 1448515184.249169 [0 10.86.255.166:6379] "PING" |
2.5 设置Master的写行为
2.8以后,可以在设定文件中设置,Master只有当有N个Slave处于连接状态时,接受写操作
1
2
|
min-slaves-to-write 3 min-slaves-max-lag 10 |
3. Redis HA管理工具
redis-sentinel 能监视同期的状态,发现Master down的时候,会进行failover,将Slave升级为Master,启动后会自动更新sentinel设定文件,发生failover时,会自动修改sentinel和redis的设定文件
环境:
Master: 10.86.255.167 :6379 sentinel:26379
Slave1: 10.86.255.166 :6379 sentinel:26379
Slave2: 10.86.255.167 :7379 sentinel:36379
Sentinel的设定文件在/etc/redis-sentinel.conf,对failover的动作等可以进行一些定义,本次主要验证Sentinel的动作,设定文件可以根据具体情况自行调整
3.1 设定Master,Slave
参照上文设定Master,Slave,并确认Mater和2个Slave的同期状态正常
3.2 Master上设定Sentinel
1
2
3
|
# vi /etc/redis-sentinel.conf daemonize yes sentinel monitor mymaster <master ip> 6379 2 |
启动sentinel
1
2
3
|
# redis-sentinel /etc/redis-sentinel.conf 或 # redis-server /etc/redis-sentinel.conf --sentinel |
确认
1
2
|
# redis-cli -p 26379 127.0.0.1:26379> INFO sentinel |
确认Master信息
1
|
127.0.0.1:26379> sentinel masters |
确认Slave信息
1
|
127.0.0.1:26379> sentinel slaves mymaster |
3.3 Slave上设定Sentinel
在slave1上设定sentinel
1
2
3
|
# vi /etc/redis-sentinel.conf daemonize yes sentinel monitor mymaster <master ip> 6379 2 |
启动slave1
1
|
# redis-sentinel /etc/redis-sentinel.conf |
在slave2上设定sentinel
1
2
3
4
|
# less /etc/redis-sentinel_36379.conf daemonize yes port 36379 sentinel monitor mymaster <master ip> 6379 2 |
启动slave2
1
|
# redis-sentinel /etc/redis-sentinel_36379.conf |
3.4 动作确认
停止Master
1
|
127.0.0.1:6379> SHUTDOWN |
确认日志发生fail over
1
|
# tail /var/log/redis/sentinel.log |
确认Slave2变成Master,Slave1是Slave
1
|
test167:7379> info replication |
1
|
test166:6379> info replication |
启动刚才停掉的Master,确认变为Slave
1
|
10.86.255.167:6379> info replication |
3.5 Sentinel命令
1
2
3
4
5
6
|
127.0.0.1:26379> sentinel masters 127.0.0.1:26379> sentinel slaves mymaster 127.0.0.1:26379> SENTINEL get-master-addr-by-name mymaster 127.0.0.1:26379> SENTINEL reset mymaster 127.0.0.1:26379> SENTINEL failover mymaster 127.0.0.1:26379> SENTINEL flushconfig mymaster |
4. 后记
本文介绍了Redis主从同步,读写分离,及HA,后续会继续研究Redis。
Redis系列之(二):Redis主从同步,读写分离的更多相关文章
- mysql 主从同步-读写分离
主从同步与读写分离测试 一. 实验环境(主从同步) Master centos 7.3 192.168.138.13 Slave ...
- 聊聊Mysql主从同步读写分离配置实现
Hi,各位热爱技术的小伙伴您们好,好久没有写点东西了,今天写点关于mysql主从同步配置的操作日志同大家一起分享.最近自己在全新搭建一个mysql主从同步读写分离数据库简单集群,我讲实际操作步骤整理分 ...
- mysql数据库主从同步读写分离(一)主从同步
1.mysql数据库主从同步读写分离 1.1.主要解决的生产问题 1.2.原理 a.为什么需要读写分离? 一台服务器满足不了访问需要.数据的访问基本都是2-8原则. b.怎么做? 不往从服务器去写了 ...
- 使用docker 实现MySQL主从同步/读写分离
1. 利用 docker 实现 mysql 主从同步 / 读写分离 为了保证数据的完整和安全,mysql 设计了主从同步,一个挂掉还可以用另个.最近重构论坛,想来改成主从吧.担心失误,就先拿 dock ...
- mysql主从同步--读写分离。
1.mysql 安装参考 https://www.cnblogs.com/ttzzyy/p/9063737.html 2. 主mysql,从mysql 指定配置文件启动 mysqld --defaul ...
- 关系型数据库MySQL主从同步-读写分离
1.环境准备 我的数据库版本是MySQL 5.6 MySQL主机至少两个实例,可以是多实例,可以是多台主机 关闭selinux,关闭防火墙等基础优化 2.安装 yum -y install make ...
- MariaDB主从复制,redis发布订阅,持久化,以及主从同步
一. MariaDB主从复制 mysql基本操作 1 连接数据库 mysql -u root -p -h 127.0.0.1 mysql -u root -p -h 192.168.12.60 2 ...
- Redis多实例配置以及主从同步
一.多实例配置 1.准备俩配置文件,开两个就准备两个 redis-6380.conf redis-6381.conf 2.分别写入配置信息(这里简化了配置) # 运行在6380端口 bind 172. ...
- Redis系列(四):Redis的复制机制(主从复制)
本篇博客是Redis系列的第4篇,主要讲解下Redis的主从复制机制. 本系列的前3篇可以点击以下链接查看: Redis系列(一):Redis简介及环境安装 Redis系列(二):Redis的5种数据 ...
- Redis系列(五):Redis的过期键删除策略
本篇博客是Redis系列的第5篇,主要讲解下Redis的过期键删除策略. 本系列的前4篇可以点击以下链接查看: Redis系列(一):Redis简介及环境安装 Redis系列(二):Redis的5种数 ...
随机推荐
- 导出数据到Excel --使用ExcelReport有感
先看图,这是几个月前用NPOI写的导出数据到Excel,用了上百行代码,而且难控制,导出来也比较难看 excel打开的效果 下面是我用ExcelReport类库导出到Excel的操作 1.首先引用Ex ...
- 【MVVM DEV】DataColumn中的TextBox与ComboBox的并存
一.前言 在WPF编程中,有时候我们使用DataGrid会需要在一个DataColumn中既有TextBox,也要有ComboBox或者TextBlock等其他数据显示样式. 这个时候我们 ...
- 基于CkEditor实现.net在线开发之路(7)列表页面开发动作介绍
一个列表页面不止是查询,它也包含了很多业务上功能的实现,这些业务功能的实现的逻辑我称之为动作.如触发单击按钮删除数据,更改业务表数据,调用webService,调用WCF接口,弹出新窗体新增.修改.查 ...
- Servlet3.0的可插拔功能
如果说 3.0 版本新增的注解支持是为了简化 Servlet/ 过滤器 / 监听器的声明,从而使得 web.xml 变为可选配置, 那么新增的可插性 (pluggability) 支持则将 Servl ...
- JavaMail发送邮件第一版
首先,我们先来了解一个基本的知识点,用什么工具来发邮件? 简单的说一下,目前用的比较多的客户端:OutLook,Foxmail等 顺便了解一下POP3.SMTP协议的区别: POP3,全名为" ...
- kafka主题offset各种需求修改方法
简要:开发中,常常因为需要我们要认为修改消费者实例对kafka某个主题消费的偏移量.具体如何修改?为什么可行?其实很容易,有时候只要我们换一种方式思考,如果我自己实现kafka消费者,我该如何让我们的 ...
- 浏览器渲染引擎,提高css渲染速度。
一.渲染引擎渲染引擎的职责是……渲染,也就是把请求的内容显示到浏览器屏幕上.默认情况下渲染引擎可以显示HTML,XML文档以及图片. 通过插件(浏览器扩展)它可以显示其它类型文档. 二.各种渲染引擎我 ...
- 非域客户端的office使用RMS加密服务出现‘介绍“信息权限管理服务”’服务的提示
环境:office2007,需要使用windows RMS服务,客户机处于工作组模式,如图: 出现这个说明客户机没有发现RMS服务,可以通过导入注册表解决,如下: Windows Registry E ...
- Centos7更改默认启动模式(转载)
今天心血来潮安装一个centos7的图形界面,但发现用之前的方式无法修改默认启动为命令行模式. 之前的方法:修改/etc/inittab文件中的 id:3:initdefault ...
- NSDateFormatter 时间格式转换
NSString *strDate = @“Wed Apr ::”; NSDateFormatter *dateFomatter =[[NSDateFormatter alloc] init]; [d ...