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.confbind 10.86.255.166 | 
重启Redis
# systemctl restart redis
| 1 | # less /etc/redis.conf | 
Slave: test167
修改设定文件,指定Master
| 1 2 3 | slaveof <masterip> <masterport>    指定master的ip和portmasterauth <master-password>       master有验证的情况下slave-read-only yes设置slave为只读模式 | 
也可以用命令行设定:
| 1 2 | redis 127.0.0.1:9999> slaveof localhost 6379OK | 
2.2 同期情况确认
Master:
| 1 2 3 4 5 6 | 127.0.0.1:6379> INFO replication# Replicationrole:masterconnected_slaves:1slave0: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# Replicationrole:slavemaster_host:10.86.255.166master_port:6379master_link_status:upmaster_last_io_seconds_ago:7master_sync_in_progress:0slave_repl_offset:365slave_priority:100slave_read_only:1connected_slaves:0master_repl_offset:0repl_backlog_active:0repl_backlog_size:1048576repl_backlog_first_byte_offset:0repl_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 OKredis 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> monitorOK1448515184.249169 [0 10.86.255.166:6379] "PING" | 
2.5 设置Master的写行为
2.8以后,可以在设定文件中设置,Master只有当有N个Slave处于连接状态时,接受写操作
| 1 2 | min-slaves-to-write 3min-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.confdaemonize yessentinel 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 26379127.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.confdaemonize yessentinel 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.confdaemonize yesport 36379sentinel monitor mymaster <master ip> 6379 2 | 
启动slave2
| 1 | # redis-sentinel /etc/redis-sentinel.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,确认Master变为Slave
| 1 | 10.86.255.166:6379> info replication | 

3.5 Sentinel命令
| 1 2 3 4 5 6 | 127.0.0.1:26379> sentinel masters127.0.0.1:26379> sentinel slaves mymaster127.0.0.1:26379> SENTINEL get-master-addr-by-name mymaster127.0.0.1:26379> SENTINEL reset mymaster127.0.0.1:26379> SENTINEL failover mymaster127.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种数 ... 
随机推荐
- java获取指定地址图片高度宽度简单代码
			package com.test; import java.awt.image.BufferedImage; import java.io.IOException; import java.io.In ... 
- POJ 1659 Frogs' Neighborhood
			转载请注明出处:http://blog.csdn.net/a1dark 分析:切图论切的第一道题.也是图论的例题.主要用到一个Havel-Hakimi 定理 有以下两种不合理的情形: (1) 某次对剩 ... 
- POJ 1287 Networking(最小生成树)
			题意 给你n个点 m条边 求最小生成树的权 这是最裸的最小生成树了 #include<cstdio> #include<cstring> #include<algor ... 
- JavaScript语言基础知识10
			JavaScript中间if声明: <span style="font-size:18px;"><HTML> <HEAD> <TITLE& ... 
- Linux 软连接与硬连接
			Linux 软连接与硬连接 对于一个文件来说,有唯一的索引接点与之相应,而对于一个索引接点号,却能够有多个文件名称与之相应.因此,在磁盘上的同一个文件能够通过不同的路径去訪问该文件.注意在Linux下 ... 
- 【原创】leetCodeOj --- Candy 解题报告
			题目地址: https://leetcode.com/problems/candy/ 题目内容: Candy Total Accepted: 43150 Total Submissions: 2038 ... 
- SQLServer 网络协议(一)
			SQLserver现在主要的3种协议:Shared Memory.TCP/IP 和 Named Pipe SharedMemory: Shared Memory最快最简单的协议,使用SharedMem ... 
- Copy-and-swap
			为了在自己定义类里重载一个异常安全(exception safe)的赋值操作符.创造了一个这种习惯用语.也叫:Create-Temporary-and-Swap. 要想写健壮的C++代码.异常安全很重 ... 
- iframe页面控制父页面跳转
			<script> window.onload=function(){ window.location.href="http://www.baidu.com"; ... 
- CentOS 6.3 安装 samba 共享(转)
			PHP环境在linux下,但是开发的时候用的是windows,于是我用了samba将linux的一个目录共享,然后在windows上做映射,这样就可以直接在windows下编辑linux上的文件了 首 ... 
