【Redis集群分类】

1.主从复制(master/slave)

2.高可用Sentinel哨兵

3.高可用集群模式

【 主从复制(master/slave)】

[Redis一主多从架构]

通过持久化功能,Redis保证了即使在服务器重启的情况下也不会丢失(或少量丢失)数据,但由于数据是存储在一台服务器上的,如果这台服务器出现故障,比如硬盘坏了,也会导致数据丢失。

为了避免数据单点丢失,我们需要将数据复制多份部署在多台不同的服务器上,即使有一台服务器出现故障其他服务器依然可以继续提供服务。

【如何实现】

要求当主服务器上的数据更新后,自动将更新的数据同步到其他服务器上。

Redis提供了复制(replication)功能来自动实现多台Redis服务器的数据同步。

我们可以通过配置多台Redis,并在配置文件中指定这几台Redis之间的主从关系,主负责写入数据,同时把写入数据实时同步到从机器,这种模式叫做“主从复制”,即master/slave方式,并且Redis默认master用于写,slave用于读,向salve写数据会导致错误。

[ 实现方式1 ]

修改配置文件,启动时,服务器读取配置文件,并自动成为指定服务器的从服务器,从而构成主从复制关系。

下面配置是基于单台服务器,启动多个Redis实例的配置,模拟一下多台redis服务

#master主服务器conf文件配置 新增一个redis_6380配置文件
include /usr/local/redis-3.2.9/redis.conf #导入Redis原始配置文件的内容
daemomize yes
port 6380
pidfile /var/rum/redis_6380.pid
logfile 6380.log
dbfilename dump6380.rdb

#slave从服务器conf文件配置

include /usr/local/redis-3.2.9/redis.conf #同主服务器
daemonize yes
port 6382
pidfile /var/run/redis_6382.log
dbfilename dump6382.rdb
slaveof 127.0.0.1 6380 #这句是关键

相关命令

[ 实现方式2 ]

./redis-server --slaveof <master-ip> <master-port>,在启动redis时指定当前服务器成为某个主Redis服务的从slave。

[容灾处理(手动处理)]

当master服务出现故障,需手动将slave中的一个提升为master,剩下的slave挂至新的master上(冷处理),步骤如下(假如三台机器分别是:master、slave1、slave2)

1.连接slave1,先将slave1服务器提升为master:slaveof no one

2.连接salve2,再将slave2挂至新的master上:slaveof 127.0.0.1 6381

[主从模式总结]

【高可用Sentinel哨兵】

Sentine哨兵是Redis官方提供的高可用方案,可以用它来监视多个Redis实例的运行情况。

[监控]

[配置(使用的是单台服务器启动三个实例的方式)]

[启动sentinel]

[sentinel总结]

【高可用集群模式】

Redis集群是一个由多个节点群组成的分布式服务器群,它具有复制、高可用、分片的特性,Redis不需要Sentinel哨兵也能完成节点移除和故障转移的功能,需要将每个节点设置为集群模式,这种集群模式没有中心节点,可以水平扩展,官方文档称可以线性扩展到1000节点,Redis集群的性能和高可用均优于之前版本的Sentinel哨兵模式,且集群配置较为简单。

11_Redis集群的更多相关文章

  1. 启动了VSAN服务的主机不在vCenter集群中

    背景: 这个问题的来源是,某用户将该ESXi主机直接夺取到另一个vCenterA的管辖中,而这个vCenterA中集群A开启了VSAN功能,导致再次反向夺取到vCenterB中的时候带有了来自于集群A ...

  2. Apache Ignite之集群应用测试

    集群发现机制 在Ignite中的集群号称是无中心的,而且支持命令行启动和嵌入应用启动,所以按理说很简单.而且集群有自动发现机制感觉对于懒人开发来说太好了,抱着试一试的心态测试一下吧. 在Apache ...

  3. 从0开始搭建SQL Server AlwaysOn 第二篇(配置故障转移集群)

    从0开始搭建SQL Server AlwaysOn 第二篇(配置故障转移集群) 第一篇http://www.cnblogs.com/lyhabc/p/4678330.html第二篇http://www ...

  4. Ubuntu 14.04中Elasticsearch集群配置

    Ubuntu 14.04中Elasticsearch集群配置 前言:本文可用于elasticsearch集群搭建参考.细分为elasticsearch.yml配置和系统配置 达到的目的:各台机器配置成 ...

  5. windows+nginx+iis+redis+Task.MainForm构建分布式架构 之 (nginx+iis构建服务集群)

    本次要分享的是利用windows+nginx+iis+redis+Task.MainForm组建分布式架构,由标题就能看出此内容不是一篇分享文章能说完的,所以我打算分几篇分享文章来讲解,一步一步实现分 ...

  6. 在开启DRS的集群中修复VMware虚拟主机启动问题

    通过iSCSI方式连接到ESXi主机上的外挂存储意外失联了一段时间,导致部分虚拟主机在集群中呈现出孤立的状态,单独登陆到每台ESXi上可以看到这些虚拟主机都变成了unknow状态.因为有过上一次(VM ...

  7. 通过VMware的PowerCLI配置集群内指定主机的vMotion功能

    PowerCLI是VMware开发的基于微软(MSFT)的PowerShell的命令行管理vSphere的实现,因此在批量化操作方面CLI会减轻很多GUI环境下的繁琐重复劳作. 现有场景中有大量的物理 ...

  8. 【Oracle 集群】ORACLE DATABASE 11G RAC 知识图文详细教程之集群概念介绍(一)

    集群概念介绍(一)) 白宁超 2015年7月16日 概述:写下本文档的初衷和动力,来源于上篇的<oracle基本操作手册>.oracle基本操作手册是作者研一假期对oracle基础知识学习 ...

  9. 【Big Data】HADOOP集群的配置(一)

    Hadoop集群的配置(一) 摘要: hadoop集群配置系列文档,是笔者在实验室真机环境实验后整理而得.以便随后工作所需,做以知识整理,另则与博客园朋友分享实验成果,因为笔者在学习初期,也遇到不少问 ...

随机推荐

  1. 2019 CCPC-Wannafly Winter Camp Day1 (Div2, onsite)

    solve:4/11 补题:6/11 A 机器人 补题:zz 这是一道分类讨论的题目,有一个规律就是如果必须要从第一个区到第二个区,那么最多转区两次(1到2一次,2到1一次),然后分类讨论即可,只要细 ...

  2. 项目版本不同导致Eclipse报错问题——关于在JDK1.7环境中,运行JDK1.8环境下编写的项目

    本人电脑环境配置的是JDK1.7,朋友的是JDK1.8 ,我把她编的java文件导入到我电脑里的Eclipse(LUNA版本)的时候,项目出现一个红色叹号,当然运行是肯定出错了.SO我就开始了解决之旅 ...

  3. git设置core.autocrlf

    背景: 使用虚拟机共享windows文件夹,文件夹中用git clone 一个仓库.在linux下编辑文件,用git status发现几乎所有的文件都为修改状态.   原因: windows下和lin ...

  4. Mathematica多元隐函数作图

    例: ContourPlot3D[ 1/x + 1/y + 1/z == 1/10, {x, 最小值, 最大值}, {y, 最小值, 最大值}, {z, 最小值, 最大值}]

  5. MySQL初始化与用户配置

    数据库初始化 默认情况下,数据已经初始化好,数据可参见默认配置文件/etc/my.cnf 在其他位置重新初始化MySQL数据库: basedir是mysql的安装根目录,ldata是数据初始化的目录 ...

  6. Oracle 通过子查询批量添加、修改表数据

    1.通过查询快速创建表 create table test1(id,job,mgr,sal) as () ) ---这是一个分页查询 ok,表创建成功 2.通过查询快速创建视图 create or r ...

  7. 【Javascript】Javascript原型与继承

    一切都是对象! 以下的四种(undefined, number, string, boolean)属于简单的值类型,不是对象.剩下的几种情况——函数.数组.对象.null.new Number(10) ...

  8. train,dev,test数据集作用

      train为训练语料,用于模型训练:   dev为开发集,用于模型参数调优:   test用于测试

  9. [PY3]——内置数据结构(8)——解构与封装

    ### 解构的理解与用法 ### 解构是python很有特色的一个功能,被很多语言借鉴(例如ES6) # 元素按照顺序赋值给变量 In [31]: lst=list(range(5)) In [32] ...

  10. python web 框架的基本逻辑练习题

    # -*- coding:utf-8 -*- # date : 2017/12/22 from wsgiref.simple_server import make_server # 首先是导入wsgi ...