CentOS7下搭建Redis主从复制

(1).实验环境
youxi1 192.168.1.6 Master服务器
youxi2 192.168.1.7 Slave服务器
(2).实验
1)两台服务器上yum安装Redis,启动并设置开机自启
详细查看:CentOS7下yum安装Redis
2)修改Master服务器上的配置
[root@youxi1 ~]# vim /etc/redis.conf
bind 0.0.0.0 //第69行,设置监听地址。0.0.0.0表示监听所有地址
requirepass 123456 //第507行,设置认证密码
[root@youxi1 ~]# systemctl restart redis
如果防火墙是开启状态,记得添加端口号
[root@youxi1 ~]# firewall-cmd --permanent --zone=public --add-port=6379/tcp && firewall-cmd --reload
success
success
3)修改Slave服务器上的配置
[root@youxi2 ~]# vim /etc/redis.conf
replicaof 192.168.1.6 6379 //第286行,设置master的IP地址和端口号
masterauth 123456 //第293行,设置master的认证密码
[root@youxi2 ~]# systemctl restart redis
4)查看master和slave的状态信息
查看master的状态信息
[root@youxi1 ~]# redis-cli
127.0.0.1:6379> auth 123456
OK
127.0.0.1:6379> info replication
# Replication
role:master //这是一台master
connected_slaves:1 //连接slave服务器的数量
slave0:ip=192.168.1.7,port=6379,state=online,offset=350,lag=1 //slave服务器的信息
master_replid:e26e1e0953261c81b2ca2de08ce8ebda264eeabf
master_replid2:0000000000000000000000000000000000000000
master_repl_offset:350
second_repl_offset:-1
repl_backlog_active:1
repl_backlog_size:1048576
repl_backlog_first_byte_offset:1
repl_backlog_histlen:350
查看slave的状态信息
[root@youxi2 ~]# redis-cli
127.0.0.1:6379> info replication
# Replication
role:slave //这是一台slave
master_host:192.168.1.6 //master服务器的IP地址
master_port:6379 //master服务器的端口号
master_link_status:up //连接状态
master_last_io_seconds_ago:5
master_sync_in_progress:0
slave_repl_offset:112
slave_priority:100
slave_read_only:1 //成为slave服务器后,只读
connected_slaves:0
master_replid:e26e1e0953261c81b2ca2de08ce8ebda264eeabf
master_replid2:0000000000000000000000000000000000000000
master_repl_offset:112
second_repl_offset:-1
repl_backlog_active:1
repl_backlog_size:1048576
repl_backlog_first_byte_offset:1
repl_backlog_histlen:112
5)测试
在master服务器上创建一个键值,然后到slave上查看
[root@youxi1 ~]# redis-cli
127.0.0.1:6379> auth 123456
OK
127.0.0.1:6379> set user youxi
OK [root@youxi2 ~]# redis-cli
127.0.0.1:6379> get user
"youxi"
这就成功了。
(3).主从复制高级配置参数
CentOS7下yum安装Redis已经记载了,这里复制一下,便于查看。
/*第218到220行,快照存储策略,存到磁盘的持久化策略
*第一个数字是单位时间,单位为秒;第二个数字是键值发生变化的次数
* 例如第一个,900秒内至少发生1次键值变化,则做一次快照(持久化)
* 第二个就是,300秒内至少发生10次键值变化,则做一次快照(持久化)
* 所有条件是并列关系,根据不同的键值变化选择使用规则
*/
save 900 1
save 300 10
save 60 10000
//第235行,在进行快照备份时,一旦发生错误是否停止,默认yes即可
stop-writes-on-bgsave-error yes
//第241行,指定RDB文件是否压缩。yes表示压缩,会消耗CPU资源
rdbcompression yes
/*第250行,是否对RDB文件做校验码检测。
*此项定义在redis启动时加载RDB文件是否对文件检查校验码,在redis生成RDB文件是会生成校验信息,在redis再次启动或装载RDB文件时,是否检测校验信息。
*如果检测的情况下会消耗时间,会导致redis启动时慢,但是能够判断RDB文件是否产生错误。
*/
rdbchecksum yes
//第253行,RDB文件名称
dbfilename dump.rdb
//第263行,RDB文件存放的路径
dir /var/lib/redis //第286行,定义Master服务器的IP和端口,主从复制的配置信息
# replicaof <masterip> <masterport>
//第293行,定义Master服务器的密码,主从复制的配置信息
# masterauth <master-password>
//第308行,当从端在主从复制过程中与主端断开连接,yes表示继续提供服务,即使数据可能不是最新的;no表示对请求返回错误信息
replica-serve-stale-data yes
//第324行,从端只读
replica-read-only yes
//第355行,默认不使用diskless(无磁盘)同步方式
repl-diskless-sync no
//第367行,diskless(无磁盘)方式进行数据传递之前会有一个时间的延迟,以便从端能够进行到待传送的目标队列中,默认5秒
repl-diskless-sync-delay 5
//第373行,从端向主端发送ping的时间间隔,默认10秒
# repl-ping-replica-period 10
//第385行,设置超时时间
# repl-timeout 60
/*第400行,是否启用TCP_NODELAY。
* 如果启用则会使用少量的TCP包和带宽去进行数据传输到从端,速度较慢;
* 如果不启用则使用较多的带宽进行数据传输,速度较快。
*/
repl-disable-tcp-nodelay no
/*第413行,设置backlog的大小。backlog是一个缓冲区,在从端失联时存放要同步到从端的数据。
* 因此当从端重连时,一般是不需要完全同步的。backlog越大,从端可以失联的时间就越长(相对来说)
*/
# repl-backlog-size 1mb
//第426行,一段时间后,从端还没有连上master,那么backlog(缓冲区)的内存将被释放。0表示永不释放,默认3600秒
# repl-backlog-ttl 3600
//第441行,从端的优先级设置,数字越小优先级越高。主端故障会根据优先级高的从端来进行恢复。如果设置的是0,那么该从端永远不会被选中
replica-priority 100
//第457到458行,当主端的可用从端小于3个或网路延迟岛屿10秒时,主端拒绝接收用户的写请求。
# min-replicas-to-write 3
# min-replicas-max-lag 10
CentOS7下搭建Redis主从复制的更多相关文章
- linux系统centOS7下搭建redis集群中ruby版本过低问题的解决方法
问题描述: 在Centos7中,通过yum安装ruby的版本是2.0.0,但是如果有些应用需要高版本的ruby环境,比如2.2,2.3,2.4... 那就有点麻烦了,譬如:我准备使用redis官方给的 ...
- Linux系统:Centos7下搭建PostgreSQL关系型数据库
本文源码:GitHub·点这里 || GitEE·点这里 一.PostgreSQL简介 1.数据库简介 PostgreSQL是一个功能强大的开源数据库系统,具有可靠性.稳定性.数据一致性等特点,且可以 ...
- centos7搭建redis主从复制,并模拟故障切换。
Cntos7搭建redis主从复制,并模拟故障主从切换 主从复制搭建 主机:192.168.161.179 从机:192.168.161.180 1. 安装主redis 自己本地环境,关 ...
- 第四百零五节,centos7下搭建sentry错误日志服务器,接收python以及Django错误,
第四百零五节,centos7下搭建sentry错误日志服务器,接收python以及Django错误, 注意:版本,不然会报错 Docker >=1.11Compose >1.6.0 通过d ...
- Linux CentOs7 下安装 redis
Linux CentOs7 下安装 redis 请将以下命令放入linux命令行中运行 如果安装过程前没有安装GCC请先安装 命令如下 $ yum install gcc-c++ $ wget ht ...
- Windows下搭建Redis集群
Redis集群: 如果部署到多台电脑,就跟普通的集群一样:因为Redis是单线程处理的,多核CPU也只能使用一个核, 所以部署在同一台电脑上,通过运行多个Redis实例组成集群,然后能提高CPU的利用 ...
- 在Centos7下搭建Socks5代理服务器
在Centos7下搭建Socks5代理服务器 http://blog.51cto.com/quliren/2052776 采用socks协议的代理服务器就是SOCKS服务器,是一种通用的代理服务器 ...
- Hyperledger超级账本在Centos7下搭建运行环境
超级账本(hyperledger)是Linux基金会于2015年发起的推进区块链数字技术和交易验证的开源项目,加入成员包括:荷兰银行(ABN AMRO).埃森哲(Accenture)等十几个不同利益体 ...
- Redis集群搭建(转自一菲聪天的“Windows下搭建Redis集群”)
配置Redis参考:http://blog.csdn.net/zsg88/article/details/73715947 使用Ruby配置集群参考:https://www.cnblogs.com/t ...
随机推荐
- LightOJ - 1349 - Aladdin and the Optimal Invitation
链接: https://vjudge.net/problem/LightOJ-1349 题意: Finally Aladdin reached home, with the great magical ...
- java如何连接数据库并对其操作(以PostgreSQL为例)
java如何连接数据库并对其操作(以PostgreSQL为例) 相关概念 JDBC(Java Data Base Connectivity)是一种用于执行SQL语句的Java API,可以为多种关系数 ...
- SIGAI机器学习第二十三集 高斯混合模型与EM算法
讲授高斯混合模型的基本概念,训练算法面临的问题,EM算法的核心思想,算法的实现,实际应用. 大纲: 高斯混合模型简介实际例子训练算法面临的困难EM算法应用-视频背景建模总结 高斯混合模型简写GMM,期 ...
- PHP流程控制之do...while循环的区别
do...while与while的语法结构基本一样,也是一个布尔型循环,功能也基本一样.大理石平台价格 基本语法规定如下: do { //代码块 } while (判断); do...while ...
- Linux https认证原理
HTTPS在传输的过程中会涉及到三个密钥:服务器端的公钥和私钥,用来进行非对称加密客户端生成的随机密钥,用来进行对称加密一个HTTPS请求实际上包含了两次HTTP传输,可以细分为8步.1.客户端向服务 ...
- 花样流水灯的verilog实现
LED(Light emitting diode)发光二极管将电能转化为可见光,正向电压导通,反向电压截止.对于该板子,二极管用低电压导通,其实验原理图为: 所谓流水灯,即让LED像水一样的点亮,从左 ...
- 如何在Processing中调用Windows应用程序
Processing调用了exe就意味着失去了跨平台.调用的过程是,先得到当前的runtime,然后调用runtime的exec()方法,在exec()传入的是字符串参数,这个参数很重要,该有空格的地 ...
- AtCoder Grand Contest 004题解
传送门 \(A\) 咕咕 int a,b,c; int main(){ scanf("%d%d%d",&a,&b,&c); if((a&1^1)|( ...
- 洛谷P3178[HAOI]2015 树上操作
题目 树剖裸题,这个题更可以深刻的理解树剖中把树上的节点转换为区间的思想. 要注意在区间上连续的节点,一定是在一棵子树中. #include <bits/stdc++.h> #define ...
- Pytest权威教程09-捕获标准输出及标准错误输出
目录 捕获标准输出及标准错误输出 默认 stdout/stderr/stdin 捕获行为 设置捕获方法或禁用捕获 调试中使用print语句 在测试用例中使用的捕获的输出 返回: Pytest权威教程 ...