1. 节点(服务器)数量说明

按照redis官方建议:salve和master的数量按照2n+1台服务器(1台master节点,2n台slave节点)
有兴趣的可以了解下redis的master选举机制
但是本文是1台master节点,1台slave节点做测试,测试结果也没问题
如果你要添加第2台salve节点的话,两台slave节点的配置几乎是一样的,我会在下文中提及不一样的地方

2. 本文测试redis主从要达到的目的

1. master节点上的redis服务down掉之后,slave节点升级为master节点
2. 当老的master节点上的redis服务起来后,视新master节点为master,自己降为slave节点
3. 如果你想让老的master还当master,你可以循环以上1、2两步,测过才知道

3. 主机列表

角色 IP
master 192.168.1.9
slave 192.168.1.10

4. 配置前提

假设你已经在master主机上配置好了redis服务(即单机版)

假设你已经在slave主机上配置好了redis服务(即单机版)

如果你还没有配置好单机版的redis服务,请点击这里,先把2个单机版的搞起来

再回来搞这个主从

5. 主从配置过程

配置主从时,把2台机器的redis服务先停掉

5.1 redis主配置文件需要改动的地方如下,其余保持默认即可

[root@master ~]# vim /etc/redis.conf
bind 192.168.1.9
daemonize yes
logfile "/var/log/redis.log"
masterauth "123456" # 其它redis视我为master时的验证密码
requirepass "123456" # 本机redis的登录密码
maxmemory 100mb

5.2 redis主的哨兵配置文件需要改动的地方如下,其余保持默认即可

[root@master ~]# cp /usr/local/redis-4.0.6/sentinel.conf /etc/sentinel.conf
[root@master ~]# vim /etc/sentinel.conf
bind 192.168.1.9
sentinel monitor mymaster 192.168.1.9 6379 2
sentinel auth-pass mymaster 123456
logfile "/var/log/sentinel.log"
daemonize yes

如果你在windows server上搭建主从,你需要手动创建sentinel.conf,除了添加一些内容,完整的配置内容如下:

bind 192.168.1.9
port 26379
dir "/tmp"
sentinel myid 6a23c773b7e139e2ebdd64e5c5fb6de3df3f7b77
sentinel monitor mymaster 192.168.1.9 6379 2
sentinel auth-pass mymaster 123456
sentinel config-epoch mymaster 5
sentinel leader-epoch mymaster 5
logfile "/var/log/sentinel.log"
daemonize yes

5.3 redis从配置文件需要改动的地方如下,其余保持默认即可

[root@slave ~]# vim /etc/redis.conf
bind 192.168.1.10
daemonize yes
logfile "/var/log/redis.log"
masterauth "123456" # 其它redis视我为master时的验证密码
requirepass "123456" # 本机redis的登录密码
maxmemory 100mb
slaveof 192.168.1.9 6379 # master的ip和redis端口

5.4 redis从的哨兵配置文件需要改动的地方如下,其余保持默认即可

[root@slave ~]# cp /usr/local/redis-4.0.6/sentinel.conf /etc/sentinel.conf
[root@slave ~]# vim /etc/sentinel.conf
bind 192.168.1.10
sentinel monitor mymaster 192.168.1.9 6379 2 # master的ip和redis端口
sentinel auth-pass mymaster 123456
logfile "/var/log/sentinel.log"
daemonize yes

如果你在windows server上搭建主从,你需要手动创建sentinel.conf,除了添加一些内容,完整的配置内容如下:

bind 192.168.1.10
port 26379
dir "/tmp"
sentinel myid 7f24d4d935d7e97c8267910535e0c1f0f26b8d6d
sentinel monitor mymaster 192.168.1.9 6379 2
sentinel auth-pass mymaster 123456
sentinel config-epoch mymaster 5
sentinel leader-epoch mymaster 5
logfile "/var/log/sentinel.log"
daemonize yes

6. 哨兵是什么?

1. 哨兵是redis用于主从或集群的不可缺少的故障切换机制。
2. 单台redis的话,程序连接的是redis服务的6379端口;主从或集群的话,程序不再直接连接redis服务了,
而要连接的是多个哨兵,哨兵会告诉程序端找哪个redis服务。

7. 在2台机器上都允许端口通过防火墙

在2台机器上允许对方访问对方的redis端口(6379)和哨兵端口(26379)

iptables -A INPUT -s 192.168.1.0/24 -p tcp --dport 6379 -j ACCEPT
iptables -A INPUT -s 192.168.1.0/24 -p tcp --dport 26379 -j ACCEPT
service iptables save

8. 在2台机器上起redis服务,并测试主从是否同步

8.1 起redis服务

[root@master ~]# redis-server /etc/redis.conf >> /var/log/redis-init.log 2>&1

8.2 测试主从是否可以同步数据

在master服务器终端上登录redis服务

[root@master ~]# redis-cli -h 192.168.1.9 -p 6379 -a 123456
192.168.1.9:6379> info replication # 查看主从状态
# Replication
role:master
connected_slaves:1
slave0:ip=192.168.1.10,port=6379,state=online,offset=30290,lag=1
master_replid:426acab1b0c50873b516b7f0bf265c98c927a4f2
master_replid2:0000000000000000000000000000000000000000
master_repl_offset:30290
second_repl_offset:-1
repl_backlog_active:1
repl_backlog_size:1048576
repl_backlog_first_byte_offset:1
repl_backlog_histlen:30290
192.168.1.9:6379>
192.168.1.9:6379> quit
not connected>
[root@master ~]#

在slave服务器终端上登录redis服务

[root@slave ~]# redis-cli -h 192.168.1.10 -p 6379 -a 123456
192.168.1.10:6379> info replication # 查看主从状态
# Replication
role:slave
master_host:192.168.1.9
master_port:6379
master_link_status:up
master_last_io_seconds_ago:9
master_sync_in_progress:0
slave_repl_offset:350
slave_priority:100
slave_read_only:1
connected_slaves:0
master_replid:37472d667df3859cd37371453be2d0197ffbb07b
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
192.168.1.10:6379>
192.168.1.10:6379>
192.168.1.10:6379>

在master服务器终端上登录redis服务,创建数据

192.168.1.9:6379> set name zhangsan
OK
192.168.1.9:6379> set age 20
OK
192.168.1.9:6379> get name
"zhangsan"
192.168.1.9:6379> get age
"20"

在slave服务器终端上登录redis服务,如果可以查询到数据,说明数据同步到从了

192.168.1.10:6379> get name
"zhangsan"
192.168.1.10:6379> get age
"20"

8.3 在2台机器上起哨兵服务,测试故障转移功能

[root@master ~]# redis-sentinel /etc/sentinel.conf
[root@slave ~]# redis-sentinel /etc/sentinel.conf

把master的redis服务停掉

192.168.1.9:6379> shutdown
not connected> quit
[root@master ~]#

等待5秒后,查看从上的redis服务是否升级为了master

192.168.1.10:6379> info replication
# Replication
role:master
connected_slaves:0
master_replid:33b4f309f906ecf6105b9822661236ad7689af27
master_replid2:426acab1b0c50873b516b7f0bf265c98c927a4f2
master_repl_offset:59193
second_repl_offset:53354
repl_backlog_active:1
repl_backlog_size:1048576
repl_backlog_first_byte_offset:1
repl_backlog_histlen:59193
192.168.1.10:6379> get name
"zhangsan"
192.168.1.10:6379> get age
"20"
192.168.1.10:6379> quit
[root@slave ~]#

把192.168.1.9上的redis服务起来,命令参照上文8.1

再查看192.168.1.10上的redis主从状态,5秒后,应该会有slave信息

192.168.1.10:6379> info replication
# Replication
role:master
connected_slaves:1
slave0:ip=192.168.1.9,port=6379,state=online,offset=112,lag=1
master_replid:431fb03e1644a50620dd150c2527ca5acaa5648b
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
192.168.1.10:6379>

注意1: master角色是非抢占模式

即:一旦集群中存在master,则其余节点视其为master,除非master挂掉

注意2: 从库是只读的

9. 查看redis日志和哨兵日志

在/etc/redis.conf和/etc/sentinel.conf里查找日志文件记录在哪个位置了,去看吧

10. 你可以再增加1台slave主机,来测试一下2n+1台的主从

Centos7上搭建redis主从的更多相关文章

  1. 在cnetos7上搭建mysql主从服务

    本文主要是介绍在centos上搭建mysql的主从服务器.如果没有搭建过的,可以查看我以前的博客,里面有详细的安装centos和在centos上安装mysql的说明. 一.安装从虚拟机: 1.右键—& ...

  2. docker搭建redis主从集群和sentinel哨兵集群,springboot客户端连接

    花了两天搭建redis主从集群和sentinel哨兵集群,讲一下springboot客户端连接测试情况 redis主从集群 从网上查看说是有两种方式:一种是指定配置文件,一种是不指定配置文件 引用地址 ...

  3. 一、全新安装搭建redis主从集群

    前言· 这里分为三篇文章来写我是如何重新搭建redis主从集群和哨兵集群的及原本服务器上有单redis如何通过升级脚本来实现redis集群.(redis结构:主-从(备)-从(备)) 至于为什么要搭建 ...

  4. 在 CentOS7 上部署 MySQL 主从

    在 CentOS7 上部署 MySQL 主从 通过 SecureCRT 连接至 MySQL 主服务器: 找到 my.cnf 文件所在的目录: mysql --help | grep my.cnf 一般 ...

  5. 在windows上搭建redis集群

    一 所需软件 Redis.Ruby语言运行环境.Redis的Ruby驱动redis-xxxx.gem.创建Redis集群的工具redis-trib.rb 二 安装配置redis redis下载地址   ...

  6. centos7上搭建开源系统jforum

    centos7上搭建好tomcat,mysql; 将 jforum-2.6.2.war放到tomcat目录的webapps下: 启动tomcat,./startup.sh ,查看webapp下jfor ...

  7. linux上搭建redis

    环境centos7及redis-4.0.2.tar.gz 第一步首先在/usr/local/mypackage下mkdir redis 通过工具上传redis安装包 解压安装包 tar -zxvf r ...

  8. Linux系统:Centos7环境搭建Redis单台和哨兵集群环境

    本文源码:GitHub·点这里 || GitEE·点这里 一.环境和版本 Linux:centos7 三台 三台Linux服务 192.168.72.129 192.168.72.130 192.16 ...

  9. linux系统centOS7下搭建redis集群中ruby版本过低问题的解决方法

    问题描述: 在Centos7中,通过yum安装ruby的版本是2.0.0,但是如果有些应用需要高版本的ruby环境,比如2.2,2.3,2.4... 那就有点麻烦了,譬如:我准备使用redis官方给的 ...

随机推荐

  1. 002-如何理解Java的平台独立性

    本文首发于公众号:javaadu Java有句非常有名的口号--"一次编写,到处运行",依靠的就是JVM提供的平台独立性,本质上来讲,就是通过虚拟机技术,通过限制一些功能,达到屏蔽 ...

  2. gitbook 入门教程之使用 gitbook-cli 开发电子书

    gitbook 生成电子书主要有三种方式: gitbook-cli 命令行操作,简洁高效,适合从事软件开发的相关人员. gitbook-editor 编辑器操作,可视化编辑,适合无编程经验的文学创作者 ...

  3. Unsupported major.minor version 52.0解决办法

    一.错误现象:当改变了jdk版本时,在编译java时,会遇到Unsupported major.minor version错误.jdk版本和stanford parser对应关系 JDK版本和Java ...

  4. Python用Django写restful api接口

    用Python如何写一个接口呢,首先得要有数据,可以用我们在网站上爬的数据,在上一篇文章中写了如何用Python爬虫,有兴趣的可以看看: https://www.cnblogs.com/sixrain ...

  5. 一份非常完整的MySQL规范

    一.数据库命令规范 所有数据库对象名称必须使用小写字母并用下划线分割 所有数据库对象名称禁止使用mysql保留关键字(如果表名中包含关键字查询时,需要将其用单引号括起来) 数据库对象的命名要能做到见名 ...

  6. 剑指Spring源码(二)

    这是春节后的第一篇博客,我在构思这篇博客的时候,一度想放弃,想想要不要换个东西写,因为毕竟个人水平有限,Spring源码实在博大精深,不是我这个菜的抠脚的菜鸡可以驾驭的,怕误人子弟,还有就是源码分析类 ...

  7. 数据库连接(1)-从JDBC到MyBatis

    摘要 因为有持久层框架,和Spring的存在,越来越多的人对数据库连接这块不甚了解,只知使用方便,不知其原理.所以写一个数据库连接的系列文章,总结下本人在数据库连接方面遇到的问题,和对数据库连接的理解 ...

  8. 日吞吐万亿,腾讯云时序数据库CTSDB解密

    一.背景 随着移动互联网.物联网.大数据等行业的高速发展,数据在持续的以指数级的速度增长,比如我们使用手机访问互网络时的行为数据,各种可穿戴设备上报的状态数据,工厂中设备传感器采集的指标数据,传统互联 ...

  9. TabTopLayout【自定义顶部选项卡区域(固定宽度且居中)】

    版权声明:本文为HaiyuKing原创文章,转载请注明出处! 前言 自定义顶部选项卡并居中显示.结合显示/隐藏view的方式实现切换功能(正常情况下可能是切换fragment). 效果图 代码分析 T ...

  10. [个人网站搭建]·Django增加评论功能(Python3)

    [个人网站搭建]·Django增加评论功能 个人主页--> https://xiaosongshine.github.io/ 个人网站搭建github地址:https://github.com/ ...