服务搭建篇(五) Redis单机/redis-cluster集群搭建

news2024/9/21 21:28:54

一. Redis集群简介

redis集群是一个由多个主从节点群组成的分布式服务器群,它具有复制、高可用和分片特性。Redis集群不需要sentinel哨兵·也能完成节点移除和故障转移的功能。需要将每个节点设置成集群模式,这种集群模式没有中心节点,可水平扩展,据官方文档称可以线性扩展到上万个节点(官方推荐不超过1000个节点)。redis集群的性能和高可用性均优于之前版本的哨兵模式,且集群配置非常简单
在这里插入图片描述
Redis Cluster 将所有数据划分为 16384 个 slots(槽位),每个节点负责其中一部分槽位。槽位的信息存储于每个节点中。

当 Redis Cluster 的客户端来连接集群时,它也会得到一份集群的槽位配置信息并将其缓存在客户端本地。这样当客户端要查找某个 key 时,可以直接定位到目标节点。同时因为槽位的信息可能会存在客户端与服务器不一致的情况,还需要纠正机制来实现槽位信息的校验调整。

跳转重定位

当客户端向一个错误的节点发出了指令,该节点会发现指令的 key 所在的槽位并不归自己管理,这时它会向客户端发送一个特殊的跳转指令携带目标操作的节点地址,告诉客户端去连这个节点去获取数据。客户端收到指令后除了跳转到正确的节点上去操作,还会同步更新纠正本地的槽位映射表缓存,后续所有 key 将使用新的槽位映射表。下面第21步操作会有演示

槽位定位算法

redis Cluster 默认会对 key 值使用 crc16 算法进行 hash 得到一个整数值,然后用这个整数值对 16384 进行取模来得到具体槽位。

HASH_SLOT = CRC16(key) mod 16384

二.集群搭建

1.环境准备

redis集群需要至少三个master节点,我们这里搭建三个master节点,并且给每个master再搭建一个slave节点,总共6个redis节点,这里用三台机器部署6个redis实例,每台机器一主一从

192.168.154.146 redis主节点(8001)/从节点(8004)
192.168.154.147 redis主节点(8002)/从节点(8005)
192.168.154.148 redis主节点(8003)/从节点(8006)

(注意: 需要关闭防火墙)

2.下载

https://redis.io/download/

3.安装gcc

yum install gcc

4.放到/usr/local 解压

cd /usr/local
tar zxvf redis-5.0.14.tar.gz 
mv redis-5.0.14/ redis

5.编译安装

cd redis/
make

6.修改配置文件 , 后台启动

daemonize yes # 后台启动

protected‐mode no # 关闭保护模式 , 开启的话只允许本机访问

# bind 127.0.0.1 # 需要注释掉bind,bind绑定的是自己机器网卡的ip,如果有多块网卡可以配多个ip,代表允许客户端通过机器的哪些网卡ip去访问,内网一般可以不配置bind,注释掉即可

7.启动

src/redis-server redis.conf

8.验证

ps -ef | grep redis

9.进入客户端

src/redis-cli

10.退出客户端

quit

11.退出redis服务

pkill redis‐server  
kill 进程号 
src/redis‐cli shutdown 

12.在usr/local创建文件

cd /usr/local
mkdir -p redis-cluster
cd redis-cluster
mkdir 8001 8004 # 其他两台分别为 8002 8005 , 8003 8006

13.复制配置文件

cp /usr/local/redis-5.0.14/redis.conf /usr/local/redis-cluster/8001

14.修改配置

vim redis.conf
daemonize yes
port 8001(分别对每个机器的端口号进行设置)
pidfile /var/run/redis_8001.pid
dir /usr/local/redis-cluster/8001/(指定数据文件存放位置,必须要指定不同的目录位置,不然会丢失数据)
cluster-enabled yes(启动集群模式)
cluster-config-file nodes-8001.conf(集群节点信息文件,这里800x最好和port对应上)
cluster-node-timeout 10000
# bind 127.0.0.1(bind绑定的是自己机器网卡的ip,如果有多块网卡可以配多个ip,代表允许客户端通过机器的哪些网卡ip去访问,内网一般可以不配置bind,注释掉即可)
protected-mode  no   (关闭保护模式)
appendonly yes

如果要设置密码 , 修改如下配置

requirepass liuxs
masterauth liuxs

15.把8001的配置文件复制到8004

cp /usr/local/redis-cluster/8001/redis.conf /usr/local/redis-cluster/8004

16.修改8004的配置文件

vim redis.conf
:%s/8001/8004/g (批量把8001 替换为 8004)

17 其他节点按照以上操作执行一遍

18.启动

/usr/local/redis/src/redis-server /usr/local/redis-cluster/8001/redis.conf
/usr/local/redis/src/redis-server /usr/local/redis-cluster/8004/redis.conf
/usr/local/redis/src/redis-server /usr/local/redis-cluster/8002/redis.conf
/usr/local/redis/src/redis-server /usr/local/redis-cluster/8005/redis.conf
/usr/local/redis/src/redis-server /usr/local/redis-cluster/8003/redis.conf
/usr/local/redis/src/redis-server /usr/local/redis-cluster/8006/redis.conf

19.验证

ps -ef | grep redis

20.用redis-cli创建整个redis集群(redis5以前的版本集群是依靠ruby脚本redis-trib.rb实现)

/usr/local/redis/src/redis-cli -a liuxs --cluster create --cluster-replicas 1 192.168.154.146:8001 192.168.154.147:8002 192.168.154.148:8003 192.168.154.146:8004 192.168.154.147:8005 192.168.154.148:8006

21.验证

1.连接任意一个节点都可以

/usr/local/redis/src/redis-cli -a liuxs -c -h 192.168.154.147 -p 8002

2.查看集群信息

cluster info

在这里插入图片描述

3.查看集群列表

cluster nodes

在这里插入图片描述

4.数据验证

在147:8002 插入一条key为test 的数据
在这里插入图片描述
从146:8001客户端访问 , 会跳到147:8002 , 这就是redis集群原理之一 : 跳转重定位
在这里插入图片描述

22.关闭集群

/usr/local/redis/src/redis-cli -a liuxs -c -h 192.168.154.146 -p 8001 shutdown
/usr/local/redis/src/redis-cli -a liuxs -c -h 192.168.154.146 -p 8004 shutdown
/usr/local/redis/src/redis-cli -a liuxs -c -h 192.168.154.147 -p 8002 shutdown
/usr/local/redis/src/redis-cli -a liuxs -c -h 192.168.154.147 -p 8005 shutdown
/usr/local/redis/src/redis-cli -a liuxs -c -h 192.168.154.148 -p 8003 shutdown
/usr/local/redis/src/redis-cli -a liuxs -c -h 192.168.154.148 -p 8006 shutdown

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

C语言重点解剖指针和数组要点速记

1.指针指向的是最低字节地址。 2.每一次跑程序,变量的地址都会是随机的,这是一种保护机制。基本上不可以使用地址直接访问变量。 3.以下是一段有意思的代码。 4.在栈上开辟变量,地址由高到低变化,值得注意的是,不是连…

云原生|kubernetes|kube-bench安全检测工具的部署和使用

前言: 安全是一个绕不开的话题,那么,在云原生领域,在kubernetes内更加的需要安全。毕竟没有人愿意自己的项目是千疮百孔,适当的安全可以保证项目或者平台稳定高效的运行。 安全性是一个永远不会消失的问题&#xff0c…

基于springboot+mybatis+mysql+vue软件缺陷管理系统

基于springbootmybatismysqlvue软件缺陷管理系统一、系统介绍二、功能展示1.主页2.个人中心3.缺陷管理4.项目管理5.系统管理6.统计分析三、代码展示四、其它1.其他系统实现2.获取源码一、系统介绍 系统主要功能: 开发人员:主页、个人中心(我…

Java记录2:Java的三种注释类型

Java 注释 文章目录Java 注释一、单行注释 //二、多行注释 /*三、文档注释用于注解说明解释程序的文字就是注释,注释提高了代码的阅读性(可读性)。   注释是一个程序员必须要具有的良好编程习惯。将自己的思想通过注释先整理出来&#xff0…

EasyExcel写数字格式数据默认为科学计数法解决方案

问题背景 我们项目有个场景是excel下载,需要将数字类型的数据由字符格式转化为数字格式,但由于数字较长,利用easyExcel写入文件后,数字类型会默认展示为科学计数法。下面我们来看看demo演示。 demo演示 准备以下代码 public c…

2015-2022机器人方向课程教学评价成绩和任务汇总

←机器人工程或机器人方向毕业设计汇总篇→↓2022↑https://zhangrelay.blog.csdn.net/article/details/124856849ROS机器人程序设计课程反思-2022终篇-https://blog.csdn.net/ZhangRelay/article/details/127295957由于系统更新,分为两个部分2015-20182018-2022学生…

2023首场CSDN直播丨顶象邀您共话验证码顶层能力设计

1.12 15:00 验证码技术解析——业务安全大讲堂直播https://live.csdn.net/room/dingxiangtech/gqzj6MEr “我不是机器人”本应是不言自明的事情。但随着黑灰产的出现,诈骗行为和刷票行为呈指数级增长。 为了遏制这种现象,第一代验证码出现了。由此也开…

你需要知道的无代码数据分析工具

Nov. 2022, Vincy当今市场上有无数种的无代码分析工具,允许开发人员和非开发人员使用拖放的方式构建图表和仪表盘。此列表涵盖了 4 种针对不同的用例和行业的无代码数据分析工具。这些工具可以帮助用户节省时间并根据数据做出明智的决策。Footprint AnalyticsFootpr…

burp抓包mumu模拟器

1、生成android系统证书 step1:burp导出der证书 step2:生成pem格式证书 openssl x509 -inform DER -in mybpcert.der -out PortSwiggerCA.pem 生成hash并显示 openssl x509 -inform PEM -subject_hash_old -in PortSwiggerCA.pem|head -1 mv PortSwiggerCA.pem 9a5ba575.0…

mysql 存储过程批量删除重复数据

mysql 存储过程批量删除重复数据 表结构: LOAD DATA INFILE /usr/local/phone_imsi_12 replace INTO TABLE tbl_imsi2number_new FIELDS TERMINATED BY \t ENCLOSED BY (number,imsi); 先用SQL语句来进行去重操作: delete from tbl_imsi2number_new …

115.(leaflet之家)leaflet空间判断-点与矩形的空间关系

听老人家说:多看美女会长寿 地图之家总目录(订阅之前建议先查看该博客) 文章末尾处提供保证可运行完整代码包,运行如有问题,可“私信”博主。 效果如下所示: 下面献上完整代码,代码重要位置会做相应解释 <!DOCTYPE html> <html>

PCBA方案——红外医用额温枪方案

本方案讲述一款国产8位CMOS单芯片ZHW3548开发的额温枪方案&#xff0c;该CMOS芯片内置8K*16bits一次性可编程OTP ROM&#xff08;只能分为4K和4K两次使用&#xff09;&#xff0c;内置256*8bits数据存储器SRAM&#xff0c;一个带有1路全差分模拟信号输入的24位ADC&#xff0c;低…

【LeetCode每日一题】——258.各位相加

文章目录一【题目类别】二【题目难度】三【题目编号】四【题目描述】五【题目示例】六【解题思路】七【题目提示】八【题目进阶】九【时间频度】十【代码实现】十一【提交结果】一【题目类别】 数学 二【题目难度】 简单 三【题目编号】 258.各位相加 四【题目描述】 给…

React(coderwhy)- 01(介绍及基础)

React的介绍&#xff08;技术角度&#xff09; React是什么&#xff1f;React&#xff1a;用于构建用户界面的 JavaScript 库React的官网文档&#xff1a;https://zh-hans.reactjs.org/React的特点&#xff1a; 声明式编程组件化开发多平台适配Hello React react需要3个依赖&am…

最近蛮多应届生问,刚出来怎么找工作,我实在难以启齿......

前言 不知道什么情况&#xff0c;近几个月&#xff0c;好多兄弟朋友有在问我&#xff0c;关于应届生刚出来找工作的事儿。 可以看到标题&#xff0c; ‘难以启齿’ 这四个字大家应该都很少看到了吧。 因为很多兄弟问这个事情&#xff0c;我决定悄悄地发出来&#xff0c;把 我…

域名批量查询 到期未续费域名查询

域名的批量查询&#xff0c;指用户可以一次性输入多个域名进行查询&#xff0c;这样可以节省很多查询时间&#xff0c;例如你需要查询iis7这个关键词相关的域名在全球的注册情况 你完全可以使用域名批量查询工具。 最近入职了一家SEO公司&#xff0c;接手管理了110多个网站&am…

ARM指令

目录 1.指令格式 2.条件&#xff08;cond字段&#xff09; 3.指令助记符 4.寄存器 1.指令格式 基本格式 <opcode>{<cond>}{S} <Rd>,<Rn>{,<opcode2>} 一共6部分 其中&#xff0c;<>内的项是必须的&#xff0c;{}内的项是可选的&#…

【整型提升问题】

整型提升是什么&#xff1f; 整型提升的规则整型提升的存在 整型提升&#xff1a; 在计算机中&#xff0c;一个数据的类型如果是char 类型&#xff0c;以整型的形式打印该char类型的值时&#xff0c;会自动转换成整型&#xff0c;叫做整型提升。 整型提升的规则&#xff1a…

LeetCode 力扣 2042. 检查句子中的数字是否递增 areNumbersAscending

大家觉得写还可以&#xff0c;可以点赞、收藏、关注一下吧&#xff01; 也可以到我的个人博客参观一下&#xff0c;估计近几年都会一直更新&#xff01;和我做个朋友吧&#xff01;https://motongxue.cn 文章目录2042. 检查句子中的数字是否递增题目描述示例 1&#xff1a;示例…

分享一套微信门户应用管理系统源码 微信公众号平台开发框架源码

微信门户开发框架源码 微信公众号平台开发框架源码 源码分享&#xff0c;需要源码学习可私信我获取。 微信门户应用管理系统&#xff0c;采用基于 MVC Bootstrap Ajax Enterprise Library的技术路线&#xff0c;界面层采用Boostrap Metronic组合的前端框架&#xff0c;数…