Redis的集群 高可用

文章目录

  • Redis基本概念
    • 主从复制
    • 哨兵模式
    • 故障切换
    • 集群

Redis基本概念

Redis集群三种模式

主从复制:奇数台 3: 一主两从

哨兵模式:3: 1主两从

cluster:6

主从复制:和mysql的主从复制类似,主可以写,写入主的数据通过RDB方式把数据同步到从服务器,从不能更新到主,也是哨兵模式的基础

缺点:没有办法实现故障自动化恢复,只有主能够写。

哨兵:故障自动化恢复,主从复制完成之后,从服务器会变成只读模式

故障切换时,主故障,变成从服务器,主变成从之后,也会进入只读模式

缺点:从节点一旦故障,读会受到影响

集群:把每两台服务器作为主从模式,形成一个大的主从的集群

解决了写操作的负载均衡。较为完善的高可用方案

缺点:保证高可用,对数据的完整性要求不高。

主从复制

主节点和从节点

数据的复制是单向的,由主复制到从

主从复制的流程

在这里插入图片描述

部署主从复制

20.0.0.50 主

20.0.0.51 从

20.0.0.25 从

yum -y install ntpdatentpdate ntp.aliyun.com

做时间同步

在这里插入图片描述

在这里插入图片描述

修改主的配置文件

vim /etc/redis/6379.conf 

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

两台从服务器

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

重启服务

在这里插入图片描述

查看端口

在这里插入图片描述

查看日志

在这里插入图片描述

哨兵模式

在这里插入图片描述

主从配置方法

在这里插入图片描述

修改这个配置文件 主从一起

在这里插入图片描述

在这里插入图片描述

日志文件所在位置

在这里插入图片描述

在这里插入图片描述

初始化监听。都是监听主。监听主服务器的状态 2 对应的就是从服务器的数量以及投票的参与者,参与者要和从服务器的数量是一致的

2台服务器投票通过 主才能进行故障转移

在这里插入图片描述

判断服务器宕机的时间周期 30秒 每30秒检测一次

在这里插入图片描述

判断故障节点180000毫秒(即3分钟)后开始执行故障转移操作,选择一个新的主节点。

在这里插入图片描述

先启动主 在启动从

redis-sentinel sentinel.conf &

在这里插入图片描述

查看状态

redis-cli -p 26379 info sentinel

在这里插入图片描述

故障切换

将主关掉 然后查看日志

 /etc/init.d/redis_6379 restart/etc/init.d/redis_6379 start
Starting Redis server...
[root@redis1 redis-5.0.7]# /etc/init.d/redis_6379 stop 
Stopping ...
Waiting for Redis to shutdown ...
Redis stopped
 tail -f /var/log/sentinel.log 

在这里插入图片描述

集群

Redis3.0之后的分布式存储方案

集群由多个节点组成,Redis数据保存在这些节点

集群中的节点分为主和从

主负责读写以及维护集群的信息

从节点进行主节点数据的复制(也可以查)

Redis集群的数据分片

在集群概念中,引用的是哈水槽的概念

创建了集群就有16384个哈希槽

0-16383

主1:0-5460

主2:5461-10922

主3:10923-16383

如果节点当中,如果主和从全部失败,整个集群都将不可用

部署集群

20.0.0.50 20.0.0.53

20.0.0.51 20.0.0.54

20.0.0.52 20.0.0.55

在这里插入图片描述

部署时间同步

六个节点全都做时间同步

 yum -y install ntpdate​ntpdate ntp.aliyun.comvim /etc/redis/6379.conf 

六个节点 做一样配置

注释掉

在这里插入图片描述

在这里插入图片描述

集群的文件

在这里插入图片描述

在这里插入图片描述

超时时时间

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

然后重启服务

/etc/init.d/redis_6379 restartredis-cli -h 20.0.0.50 --cluster create 20.0.0.50:6379 20.0.0.51:6379 20.0.0.52:6379 20.0.0.53:6379 20.0.0.54:6379 20.0.0.55:6379 --cluster-replicas 1
redis-cli -h 20.0.0.50  集群的主连接节点 配置节点--cluster create 20.0.0.50:6379 20.0.0.51:6379 20.0.0.52:6379 20.0.0.53:6379 20.0.0.54:6379 20.0.0.55:6379
前面是是主后面是从--cluster-replicas 1 
表示每个主只有一个节点

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

进入库内查看

20.0.0.50:6379> CLUSTER SLOTS

在这里插入图片描述

20.0.0.50:6379> CLUSTER NODES

在这里插入图片描述

测试同步

在主库创建 从库查看

在这里插入图片描述

在这里插入图片描述

然后 主库挂点测试从库是否可以转为主库

在这里插入图片描述

在这里插入图片描述

集群

moved不是报错,是系统提示客户端去指定位置的哈希槽进行读或者写,系统提示啥,就去那操作即可,这个节点是该节点的主

集群的功能只是满足了高可用和负载均衡,不能保证数据的完整性

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/388693.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C++ string类

目录 为什么要有string类? auto和范围for 1. auto 2. 范围for 一. 标准库中string类的简单使用 二. string类的常用接口说明 1. string类对象的常见构造 2. string类对象的容量操作 3. string类对象的访问及遍历操作 4. string类对象的修改与查找操作 插入…

【Web 前端开发】vue3开发环境部署

1、安装 Node.js 和 npm 访问 Node.js 官网 下载并安装最新的 LTS 版本。 安装完成后,打开命令行工具, 输入 node -v 和 npm -v 检查安装是否成功。 node -vnpm -v 如下图: 2、安装 Vue CLI 在命令行工具中输入以下命令安装 Vue CLI&…

微信小程序开发:宿主环境—组件

✨✨ 欢迎大家来访Srlua的博文(づ ̄3 ̄)づ╭❤~✨✨ 🌟🌟 欢迎各位亲爱的读者,感谢你们抽出宝贵的时间来阅读我的文章。 我是Srlua小谢,在这里我会分享我的知识和经验。&am…

详解DDR3原理以及使用Xilinx MIG IP核(app 接口)实现DDR3读写测试

系列文章目录 (1)详解SDRAM基本原理以及FPGA实现读写控制 文章目录 系列文章目录一、DDR简介1.1 什么是 SDRAM、DDR、DDR2、DDR31.2 SDRAM、DDR、DDR2、DDR3核心频率、工作频率以及等效频率的计算1.3 DDR3带宽以及容量的计算 二、MIG IP核的介绍三、MIG…

机器学习 第8章-集成学习

机器学习 第8章-集成学习 8.1 个体与集成 集成学习(ensemble learning)通过构建并结合多个学习器来完成学习任务,有时也被称为多分类器系统(multi-classifersystem)、基于委员会的学习(committee-based learning)等。 图8.1显示出集成学习的一般结构:先产生一组“…

【附安装包】CentOS7(Linux)详细安装教程(手把手图文详解版)

目前流行的虚拟机软件有VMware、Virtual Box和Virtual PC等等,其中最常用的就是VMware。 而centos是Linux使用最广泛的版本之一。 教程开始教程有许多不完备之处,大佬请忽略。。。 1.安装VMware 首先需要准备VMware的安装包以及Ubuntu的ISO镜像&#…

鸿蒙系统开发【设备安全服务-应用设备状态检测】安全

设备安全服务-应用设备状态检测 介绍 本示例向您介绍如何在应用中获取DeviceToken用于对应用的设备状态进行检测。 需要使用设备安全服务接口 kit.DeviceSecurityKit。 效果预览 Sample工程的配置与使用 在DevEco中配置Sample工程的步骤如下 [创建项目]及[应用]。打开Sam…

数据结构与算法 - 递归

一、递归 1. 概述 定义:在计算机科学中,递归是一种解决计算问题的方法,其中解决方案取决于同一类问题的更小子集。 比如单链表递归遍历的例子: void f(Node node) {if(node null) {return;}println("before:" node…

Animate软件基础:在时间轴中添加或插入帧

FlashASer:AdobeAnimate2021软件零基础入门教程https://zhuanlan.zhihu.com/p/633230084 FlashASer:实用的各种Adobe Animate软件教程https://zhuanlan.zhihu.com/p/675680471 FlashASer:Animate教程及作品源文件https://zhuanlan.zhihu.co…

软件测试--python基础

一、python基础 (1)第一个python (2)python解释器 (3)基础语法 ①字面量 什么是字面量 常用的值类型 字符串 ②注释 ③变量 什么是变量 变量的特征 变量的目的是存储运行过程的数据 存储的目的是为了:重复使用 ④数据类型 type()语句 变量有类型吗?…

在欧拉系统中安装数据库

在欧拉系统中的安装 (禁止超级用户root登录) yum install mariadb-server -y #下载命令 systemctl enable --now mariadb #设置为开机自启,并立即启动该服务 mysql_secure_installation #安全设置,初始化 修…

C语言数据在内存中的存储超详解

文章目录 1. 整数在内存中的存储2. 大小端字节序和字节序判断2. 1 什么是大小端?2. 2 为什么会有大小端?2. 3 练习 3. 浮点数在内存中的存储3. 1 一个代码3. 2 浮点数的存储3. 2. 1 浮点数存的过程3. 2. 2 浮点数取的过程3. 3 题目解析 1. 整数在内存中的…

ctfshow-web入门-sql注入(web171-web175)

目录 1、web171 2、web172 3、web173 4、web174 5、web175 1、web171 单引号测一下,报错 -- 闭合后回显正常 也可以用 # ,不过需要 URL 编码 成功闭合之后,先判断下字段数: 1 order by 3-- 3 的时候正常 4 的时候报错&am…

C++必修:STL之vector的了解与使用

✨✨ 欢迎大家来到贝蒂大讲堂✨✨ 🎈🎈养成好习惯,先赞后看哦~🎈🎈 所属专栏:C学习 贝蒂的主页:Betty’s blog 1. C/C中的数组 1.1. C语言中的数组 在 C 语言中,数组是一组相同类型…

泰迪智能科技AI大模型某医院合作案例介绍

泰迪智能科技AI大模型支持以ChatGLM2-6B、Baichuan-13B、Qwen14B和文心一言等多种大语言模型为底座,实现基于特定领域数据、面向智能客服、问答系统、自动摘要、智能打标、内容创作、信息抽取等应用场景的模型微调、评估和推理,为业务智能升级和价值挖掘…

【C++从小白到大牛】类和对象

目录 一、面向过程和面向对象初步认识 二、类的引入 三、类的定义 类的成员函数两种定义方式: 1. 声明和定义全部放在类体中 2. 类声明放在.h文件中,成员函数定义放在.cpp文件中 成员变量命名规则的建议: 四、类的访问限定符 【访问限…

本地部署持续集成工具Jenkins并配置公网地址实现远程自动化构建

文章目录 前言1. 安装Jenkins2. 局域网访问Jenkins3. 安装 cpolar内网穿透软件4. 配置Jenkins公网访问地址5. 公网远程访问Jenkins6. 固定公网地址 前言 本文主要介绍如何在Linux CentOS 7中安装Jenkins并结合cpolar内网穿透工具实现远程访问管理本地部署的Jenkins服务. Jenk…

大模型算法面试题(十八)

本系列收纳各种大模型面试题及答案。 1、P-tuning v2 思路、优缺点是什么 P-tuning v2是清华大学自然语言处理实验室(THUDM)等研究机构提出的一种新的预训练模型优化方法,主要关注如何通过动态构建任务相关的提示序列来引导预训练模型进行更…

【数据结构进阶】手撕红黑树

🔥个人主页: Forcible Bug Maker 🔥专栏: C || 数据结构 目录 🌈前言🔥红黑树的概念🔥手撕红黑树红黑树结点的定义红黑树主体需要实现的成员函数红黑树的插入findEmpty和Size拷贝构造析构函数和…

Redis和Mysql如何保持数据一致性

一般情况下,Redis是用来实现应用和数据库之间读操作得缓存层,主要目的是减少数据库IO,还可以提升数据的IO性能。 当应用程序需要去读取某个数据时,会首先尝试去Redis里面加载,如果命中就直接返回,如果没有…