Redis主从复制

1.Master可以拥有多个slave
2.多个slave可以连接同一个Master外,还可以连接到其他的slave
3.主从复制不会阻塞Master在主从复制时,Master可以处理client请求。
4.提供系统的伸缩性。

主从复制的过程

1.slave与Master建立连接,发送sync同步命令。
也就是说当用户在Master写入一条命令后,他们之间会通过一些算法把数据同步到每一个slave上。
2.Msater会开启一个后台进程,将数据库快照保存到文件中。同时Master主进程会开始收集新的写命令并缓存。
3.后台完成保存后,就将文件发送给slave
4.slave将此文件保存在硬盘上。

主从复制的配置

我们创建三台linux服务器,一台作为主服务器Master,ip为192.168.1.10另外两台作为slave,ip分别为192.168.1.11和192.168.1.12.
三台服务器分别安装redis,当然这里我们要确保三台服务器之间是能进行互相通信的,即互相可以ping通。然后Master服务器不需要做什么配置,将11和12两台服务器的redis.conf配置文件进行修改之后,redis就会自动的为我们实现主从复制。
 
修改两台slave的redis.conf这个配置文件。
如果主服务器没有设置密码,那么我们只要找到slaveof <masterip> <masterport>,这里我们的主服务器ip是192.168.1.10,redis端口是6379,那么我们只需要在redis.conf配置文件中加入slaveof 192.168.1.10 6379,然后保存即可。
如果主服务器设置了密码,我们还需要修改masterauth <master-password>(主服务器的密码)这个配置项。
 
然后同时启动三台服务器 进入到redis-cli客户端用info命令进行查看状态(此处我的Master的ip是192.168.1.231,slave的ip分别为229和230)
我们看到上面的role显示此台机器是master,有两个slave,还可以看到对应的ip和端口。
 
此时我们在slave只能进行读操作,只能通过master进行写操作。并且我们每次的写操作会发现在每一台服务器上面都是同步的。
 
简单的说Redis主从复制,假设我们有三台Redis服务器,一台主服务器Master,两台从服务器slave,slave中只能做读操作。Master可做读写操作,每次对Master进行写操作之后,首先Master会将数据存储在硬盘中,然后通过sync同步命令将每一个slave的数据进行更新,然后每一个slave都将更新的数据写在自己的硬盘中,这样就保证了数据的一致性。

Redis哨兵模式

如果我们在使用主从复制的情况下,Master服务器进行了down机的情况,我们的系统就不能再进行写的操作,所以此时redis在2.6版本引入了哨兵模式,但是并不稳定,2.8版本之后哨兵模式才稳定了起来。
顾名思义Redis的哨兵模式就是对redis系统进行实时的监控,其主要功能有下面两点
1.监测主数据库和从数据库是否正常运行。
2.当我们的主数据库出现故障的时候,可以自动将从数据库转换为主数据库,实现自动的切换。

实现步骤

这里我们还是使用上面的redis服务器的ip,Master的ip为192.168.1.229,slave1为:192.168.1.230,slave2为:192.168.1.231
在其中一台服务器配置sentinel.conf(比如192.168.1.230)
1.进入解压的redis文件夹中使用cp命令将sentinel.conf文件copy到你的redis中的etc文件夹。
2.修改sentinel.conf这个配置文件
打开这个文件 我们注意到哨兵使用的端口号是26379.
 
dir "/usr/local/redis/etc"这个dir相当于哨兵的一些日志,我们修改他的路径,让他存放在我们想要保存的目录中。
 
sentinel monitor mymaster 192.168.1.229 6379 1 对应的分别是 名称,ip,端口,投票选举的次数(那么我们哨兵监听的肯定是master的ip然后端口是6379,1说明当master主服务器down机之后,剩下的服务器要进行一个投票选举出一个主服务器)
 
sentinel down-after-milliseconds mymaster 5000 这个配置代表哨兵0.5ms进行一次检查这个集群。
 
sentinel parallel-syncs mymaster 2这个配置代表你的几个从节点将支持转换为主服务器的这个事情。
 
需要修改的几乎就这几个配置。
然后 我们分别启动三台redis服务器
输入bin/redis-server etc/sentinel.conf --sentinel &这个命令启动哨兵
/usr/local/redis/bin/redis-cli -h 192.168.1.230 -p 26379 info sentinel这个命令是查看哨兵的状态
我们看到我的主服务器现在是229现在有两个slave
 
这样我们的哨兵模式就已经开启了,此时我们可以试图关闭229的redis,然后看哨兵会不会去从两个从服务器中选举一台充当主服务器。
 

redis学习三,Redis主从复制和哨兵模式的更多相关文章

  1. redis学习三 redis持久化

      1,快照持久化 1简介      redis可以通过创建快照来获得某个时间点上的内存内容的数据副本,有了副本之后,就可以将副本发送到其他redis服务器上从而创建相同数据的从服务器,同时快照留在原 ...

  2. redis的主从复制和哨兵模式

    Redis主从复制是什么? 行话:也就是我们所说的主从复制,主机数据更新后根据配置和策略, 自动同步到备机的master/slaver机制,Master以写为主,Slave以读为主 Redis主从复制 ...

  3. Linux基于Docker的Redis主从复制、哨兵模式搭建

    本教程基于CentOS7,开始本教程前,请确保您的Linux系统已安装Docker. 1.使用docker下载redis镜像 docker pull redis 安装完成后,使用docker imag ...

  4. Redis——(主从复制、哨兵模式、集群)的部署及搭建

    Redis--(主从复制.哨兵模式.集群)的部署及搭建 重点: 主从复制:主从复制是高可用redis的基础,主从复制主要实现了数据的多机备份,以及对于读操作的负载均衡和简单的故障恢复. 哨兵和集群都是 ...

  5. Redis学习笔记八:集群模式

    作者:Grey 原文地址:Redis学习笔记八:集群模式 前面提到的Redis学习笔记七:主从复制和哨兵只能解决Redis的单点压力大和单点故障问题,接下来要讲的Redis Cluster模式,主要是 ...

  6. (六) Docker 部署 Redis 高可用集群 (sentinel 哨兵模式)

    参考并感谢 官方文档 https://hub.docker.com/_/redis GitHub https://github.com/antirez/redis happyJared https:/ ...

  7. Redis三种模式——主从复制,哨兵模式,集群

    一.Redis主从复制作用 数据冗余:主从复制实现了数据的热备份,是持久化之外的一种数据冗余方式. 故障恢复:当主节点出现问题时,可以由从节点提供服务,实现快速的故障恢复:实际上是一种服务的冗余. 负 ...

  8. Redis学习三:Redis高可用之哨兵模式

    申明 本文章首发自本人公众号:壹枝花算不算浪漫,如若转载请标明来源! 感兴趣的小伙伴可关注个人公众号:壹枝花算不算浪漫 22.jpg 前言 Redis 的 Sentinel 系统用于管理多个 Redi ...

  9. redis: 主从复制和哨兵模式(十三)

    redis 主从复制 最低要求是一主二从(一个主机和两个从机) 主机才能写 从机只能读 只要从机连接到主机 数据就会全量复制到从机 环境配置(同一台机器) 1:配置文件 redis.conf配置如下: ...

随机推荐

  1. .NET平台下Redis使用(三)【ServiceStack.Redis学习】

    MVC4项目下对redis进行增删该查 Models文件下实体类: public class Book { public string BookName {get;set;} public strin ...

  2. Head First 设计模式 —— 单例模式(Singleton)

    单例模式简要定义:单例模式确保一个类只有一个实例,并提供一个全局访问点. 1. 如何保证一个类只有一个实例,且这个实例易于被访问? lazy evaluation:在用到的时候才创建对象. 全局变量: ...

  3. JSP-Runoob:JSP 文件上传

    ylbtech-JSP-Runoob:JSP 文件上传 1.返回顶部 1. JSP 文件上传 JSP 可以与 HTML form 标签一起使用,来允许用户上传文件到服务器.上传的文件可以是文本文件或图 ...

  4. bzoj2216

    决策单调性+整体二分 这里就是j<k且kj劣于j,j不会再选,所以我们整体二分 pos是因为从L->R中这个是最优点,所以对于mid+1->r选pos之前肯定不优,l->mid ...

  5. java replaceAll 忽略大小写

    public static void main(String[] args) { String temp=" CLASS_path : /aaabb/"; System.out.p ...

  6. 入门activiti-------1简单运行

    1.下载原料 2.放置位置 3.运行 4.成功页面和测试数据

  7. sql简单学习---备忘

    2:Hibernate public boolean deleteFlowerById(int id) { Session session = sessionFactory.openSession() ...

  8. 基于行为树的AI 与 Behavior Designer插件

    优点:    0.行为逻辑和状态数据分离,任何节点都可以反复利用.    1.高度模块化状态,去掉状态中的跳转逻辑,使得状态变成一个"行为".    2."行为" ...

  9. 336 Palindrome Pairs 回文对

    给定一组独特的单词, 找出在给定列表中不同 的索引对(i, j),使得关联的两个单词,例如:words[i] + words[j]形成回文.示例 1:给定 words = ["bat&quo ...

  10. python框架之Flask基础篇(二)-------- 数据库的操作

    1.flask连接数据库的四步: 倒入第三方数据库扩展包:from flask_sqlalchemy import SQLAlchemy 配置config属性,连接数据库: app.config[&q ...