redis高可用集群

2024-09-02 13:48
文章标签 集群 redis 可用

本文主要是介绍redis高可用集群,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

高可用集群

在这里插入图片描述在这里插入图片描述
主从结构的故障转移:主节点故障宕机,从节点顶替
主从的数据备份:主从关系一旦搭建,从节点时刻备份主节点的数据。高可用的基础

redis的主从数据复制

在这里插入图片描述
在这里插入图片描述

>info replication //查看当前节点的角色
>slaveof ip 端口

在这里插入图片描述
注意
此时的挂载方式为临时性的,服务重启后,仍需要重新挂载,永久性需改配置文件265行注释

哨兵

哨兵进程是一个单独的,特殊的redis进程,和redis-server相互独立运行,可以实现对主从结构的监听和管理,实现故障转移的控制

原理:

  • 监听原理:初始化时访问主节点,调用info 命令从主节点获取所有从节点的信息,维护在内存中进行监控管理,所有节点的状态都会通过哨兵进行维护
  • 心跳机制:每秒钟通过rpc(远程通信协议)心跳检测,访问集群的所有节点,一旦发现心跳响应是空的,达到一定时间判断节点故障宕机。
  • 投票机制:主节点宕机,选举一个从节点为新的主节点,通过管理的权限,将这个节点的角色转化为master,将其他集群节点挂接到这个新的主节点,必须通过投票决定(哨兵也是集群),必须投票过半,投票的结果才能执行,否则将会进入到重新判断循环。
    在这里插入图片描述

哨兵(sentinel)集群

三个哨兵节点,监控一个一主二从的主从结构
哨兵的配置文件 redis根目录下sentinel.conf
在这里插入图片描述在这里插入图片描述

[root@VM_0_10_centos redis-3.2.11]# cp sentinel.conf  sentinel01.conf 
[root@VM_0_10_centos redis-3.2.11]# cp sentinel.conf  sentinel02.conf 
[root@VM_0_10_centos redis-3.2.11]# cp sentinel.conf  sentinel03.conf 

在这里插入图片描述

省略

在这里插入图片描述

redis-sentinel sentinel01.conf

在这里插入图片描述

jedis可以连接哨兵连接集群

在这里插入图片描述

哨兵集群的分布式结构

jedis无法实现 jedis无法实现哨兵的分布式
hash一致性计算固定(基于它的结构修改hash一致性算法)
在这里插入图片描述
在这里插入图片描述

总结

redis能干什么?
nosql key-value 非关系型数据库,可持久化 支持分布式 完成缓存等功能
单节点redis问题?
数据容量上限有限
宕机无法使用
什么是数据分片?
对一批数据进行分布式处理时,数据如何划分,划分后的每一部分数据-数据分片
分布式结构的引入:容量上限,解决读写的速度
分片算法
hash取余:实现key与node节点的一致性
hash一致性:

  1. 基础:hash环 散列计算
  2. 对应关系原则:节点整数,key值映射整数,顺时针按key值寻找最近的节点
  3. 平衡性和权重:虚拟节点,一个真实节点对应多个虚拟节点,根据对虚拟节点的个数设置完成权重值的比例配置。

整合分片连接池到springboot
配置类:@Configuration
读取属性:@ConfigurationProperties
构建初始化Bean对象:@Bean(初始化的属性)
高可用
当节点故障时,可以执行故障替换转移,使得集群依然可以对外提供正常的功能
顶替的节点需要能力(数据的复制,高可用的基础)
顶替机制
哨兵:监听主节点,获取集群信息,rpc心跳检测,投票过半
哨兵集群
jedis实现分布式比较复杂,集群所有分片之间没有通信逻辑

这篇关于redis高可用集群的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1130127

相关文章

服务器集群同步时间手记

1.时间服务器配置(必须root用户) (1)检查ntp是否安装 [root@node1 桌面]# rpm -qa|grep ntpntp-4.2.6p5-10.el6.centos.x86_64fontpackages-filesystem-1.41-1.1.el6.noarchntpdate-4.2.6p5-10.el6.centos.x86_64 (2)修改ntp配置文件 [r

HDFS—集群扩容及缩容

白名单:表示在白名单的主机IP地址可以,用来存储数据。 配置白名单步骤如下: 1)在NameNode节点的/opt/module/hadoop-3.1.4/etc/hadoop目录下分别创建whitelist 和blacklist文件 (1)创建白名单 [lytfly@hadoop102 hadoop]$ vim whitelist 在whitelist中添加如下主机名称,假如集群正常工作的节

Hadoop集群数据均衡之磁盘间数据均衡

生产环境,由于硬盘空间不足,往往需要增加一块硬盘。刚加载的硬盘没有数据时,可以执行磁盘数据均衡命令。(Hadoop3.x新特性) plan后面带的节点的名字必须是已经存在的,并且是需要均衡的节点。 如果节点不存在,会报如下错误: 如果节点只有一个硬盘的话,不会创建均衡计划: (1)生成均衡计划 hdfs diskbalancer -plan hadoop102 (2)执行均衡计划 hd

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

搭建Kafka+zookeeper集群调度

前言 硬件环境 172.18.0.5        kafkazk1        Kafka+zookeeper                Kafka Broker集群 172.18.0.6        kafkazk2        Kafka+zookeeper                Kafka Broker集群 172.18.0.7        kafkazk3

Sentinel 高可用流量管理框架

Sentinel 是面向分布式服务架构的高可用流量防护组件,主要以流量为切入点,从限流、流量整形、熔断降级、系统负载保护、热点防护等多个维度来帮助开发者保障微服务的稳定性。 Sentinel 具有以下特性: 丰富的应用场景:Sentinel 承接了阿里巴巴近 10 年的双十一大促流量的核心场景,例如秒杀(即突发流量控制在系统容量可以承受的范围)、消息削峰填谷、集群流量控制、实时熔断下游不可用应

JAVA用最简单的方法来构建一个高可用的服务端,提升系统可用性

一、什么是提升系统的高可用性 JAVA服务端,顾名思义就是23体验网为用户提供服务的。停工时间,就是不能向用户提供服务的时间。高可用,就是系统具有高度可用性,尽量减少停工时间。如何用最简单的方法来搭建一个高效率可用的服务端JAVA呢? 停工的原因一般有: 服务器故障。例如服务器宕机,服务器网络出现问题,机房或者机架出现问题等;访问量急剧上升,导致服务器压力过大导致访问量急剧上升的原因;时间和

Redis中使用布隆过滤器解决缓存穿透问题

一、缓存穿透(失效)问题 缓存穿透是指查询一个一定不存在的数据,由于缓存中没有命中,会去数据库中查询,而数据库中也没有该数据,并且每次查询都不会命中缓存,从而每次请求都直接打到了数据库上,这会给数据库带来巨大压力。 二、布隆过滤器原理 布隆过滤器(Bloom Filter)是一种空间效率很高的随机数据结构,它利用多个不同的哈希函数将一个元素映射到一个位数组中的多个位置,并将这些位置的值置

一种改进的red5集群方案的应用、基于Red5服务器集群负载均衡调度算法研究

转自: 一种改进的red5集群方案的应用: http://wenku.baidu.com/link?url=jYQ1wNwHVBqJ-5XCYq0PRligp6Y5q6BYXyISUsF56My8DP8dc9CZ4pZvpPz1abxJn8fojMrL0IyfmMHStpvkotqC1RWlRMGnzVL1X4IPOa_  基于Red5服务器集群负载均衡调度算法研究 http://ww

Lua 脚本在 Redis 中执行时的原子性以及与redis的事务的区别

在 Redis 中,Lua 脚本具有原子性是因为 Redis 保证在执行脚本时,脚本中的所有操作都会被当作一个不可分割的整体。具体来说,Redis 使用单线程的执行模型来处理命令,因此当 Lua 脚本在 Redis 中执行时,不会有其他命令打断脚本的执行过程。脚本中的所有操作都将连续执行,直到脚本执行完成后,Redis 才会继续处理其他客户端的请求。 Lua 脚本在 Redis 中原子性的原因