当前位置: 首页 > news >正文

Redis---集群环境准备

一、redis集群环境准备

1、部署Redis集群的目的:

多台服务器一起提供数据存储服务;
实现数据的分布式存储;
可以实现服务的高可用;
可用实现数据自动备份;

2、服务器IP地址及端口:

主机名          IP地址          	  端口
redisA       192.168.4.61         6379     
redisB       192.168.4.62         6379     
redisC       192.168.4.63         6379     
redisD       192.168.4.64         6379
redisE       192.168.4.65         6379
redisF       192.168.4.66         6379
mgm68      192.168.4.68           无redisA、B、C、D、E、F安装redis服务即可

3、redisA修改监控地址和启用redis集群相关功能

[root@redisA ~]# /etc/init.d/redis_6379 stop

4、启用redis集群相关功能

[root@redisA ~]# vim /etc/redis/6379.conf
70 bind 192.168.4.61						#修改监控地址
815  cluster-enabled yes					#取消注释,启用集群功能
823  cluster-config-file nodes-6379.conf		#取消注释,存储集群信息相关文件
829  cluster-node-timeout 5000				#设置集群通信的超时时间(5000秒)
[root@redisA ~]# /etc/init.d/redis_6379 start
[root@redisA ~]# ss -ntulp | grep redis

5、连接redis服务,查看集群信息

[root@redisA ~]# redis-cli -h 192.168.4.61 -p 6379

6、做redis集群时,要保证所有的节点的数据为空,flushall(清空所有数据)

192.168.4.61:6379> keys *
192.168.4.61:6379> cluster info		#查看集群的相关信息
cluster_state:fail          			#集群状态,失败

7、redisB、C、D、E、F相同操作,只是监听的地址换成各自本机的地址

二、创建redis集群

配置管理主机
部署 ruby 脚本运行环境
创建管理集群脚本 redis-trib.rb

1、部署ruby 脚本运行环境,在mgm68上操作

# gem命令,用于安装ruby脚本连接redis服务的软件
[root@mgm68 ~]# yum -y install ruby rubygems
[root@mgm68 ~]# which gem		#查看gem命令是否存在
[root@mgm68 ~]# gem install redis-3.2.1.gem 	此软件,用于ruby脚本连接redis服务
[root@mgm68 ~]# ls redis-4.0.8/src/*.rb	#在redis源码包目录下,找到管理redis集群脚本
redis-4.0.8/src/redis-trib.rb

2、便于管理,将脚本拷贝到linux命令的默认查找路径下

[root@mgm68 ~]# echo $PATH		#查看linux命令的默认查找路径
/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin

3、创建目录,将管理脚本拷贝到该目录下,授予执行权限

[root@mgm68 ~]# mkdir  /root/bin
[root@mgm68 ~]# cp /root/redis-4.0.8/src/redis-trib.rb  /root/bin/
[root@mgm68 ~]# chmod +x  /root/bin/redis-trib.rb

4、Tab键,可以直接以脚本的名称直接运行,help 查看使用方法

[root@mgm68 ~]# redis-trib.rb  help

5、创建集群

#create 创建集群;
#redis集群在创建时,默认会将集群列表中的前3台服务器配置成主服务器,剩下的服务器才会被配置成从服务器;
#–replicas 1 指给每一台主服务器分配1台从服务器,需要6台服务器;
#–replicas 2 指给每一台主服务器分配2台从服务器,需要9台服务器;
#–replicas 3 指给每一台主服务器分配3台从服务器,需要12台服务器;
#最后用IP地址和端口号,指定redis集群的列表,前三台默认为主服务器

[root@mgm68 ~]# redis-trib.rb create --replicas 1  192.168.4.61:6379  192.168.4.62:6379  192.168.4.63:6379  192.168.4.64:6379  192.168.4.65:6379   192.168.4.66:6379Creating cluster
Performing hash slots allocation on 6 nodes...
Using 3 masters:
192.168.4.61:6379    #主服务器
192.168.4.62:6379    #主服务器
192.168.4.63:6379    #主服务器#### 192.168.4.65 为 192.168.4.61的从服务器
Adding replica 192.168.4.65:6379 to 192.168.4.61:6379#### 192.168.4.66 为 192.168.4.62的从服务器
Adding replica 192.168.4.66:6379 to 192.168.4.62:6379#### 192.168.4.64 为 192.168.4.63的从服务器
Adding replica 192.168.4.64:6379 to 192.168.4.63:6379#### M 指的是主服务器(占用hash槽); 
#### S 指的是从服务器(不占用hash槽,从主服务器同步数据)
M: c1198049c748cd11daff4a2477bd9dcdb3358fba 192.168.4.61:6379slots:0-5460 (5461 slots) master
M: 1417e06b26368b5e465fad155ad8a5520a937402 192.168.4.62:6379slots:5461-10922 (5462 slots) master
M: 4515ec026b1fba677cc13f0d8f72d18afde8b6b8 192.168.4.63:6379slots:10923-16383 (5461 slots) master
S: eb6558d188e64bb36016390030657f0eaa34f2cb 192.168.4.64:6379replicates 4515ec026b1fba677cc13f0d8f72d18afde8b6b8
S: 8a527e4080f47e5172715ef8cba58321534a125c 192.168.4.65:6379replicates c1198049c748cd11daff4a2477bd9dcdb3358fba
S: bbe8589f4a41adfd24ccfaae3a4fe27d5b5c4b53 192.168.4.66:6379replicates 1417e06b26368b5e465fad155ad8a5520a937402###########输入 yes,确认配置
Can I set the above configuration? (type 'yes' to accept): yes>>> Nodes configuration updated
>>> Assign a different config epoch to each node
>>> Sending CLUSTER MEET messages to join the cluster
Waiting for the cluster to join.....
>>> Performing Cluster Check (using node 192.168.4.61:6379)
M: c1198049c748cd11daff4a2477bd9dcdb3358fba 192.168.4.61:6379slots:0-5460 (5461 slots) master1 additional replica(s)
S: bbe8589f4a41adfd24ccfaae3a4fe27d5b5c4b53 192.168.4.66:6379slots: (0 slots) slavereplicates 1417e06b26368b5e465fad155ad8a5520a937402
S: eb6558d188e64bb36016390030657f0eaa34f2cb 192.168.4.64:6379slots: (0 slots) slavereplicates 4515ec026b1fba677cc13f0d8f72d18afde8b6b8
S: 8a527e4080f47e5172715ef8cba58321534a125c 192.168.4.65:6379slots: (0 slots) slavereplicates c1198049c748cd11daff4a2477bd9dcdb3358fba
M: 4515ec026b1fba677cc13f0d8f72d18afde8b6b8 192.168.4.63:6379slots:10923-16383 (5461 slots) master1 additional replica(s)
M: 1417e06b26368b5e465fad155ad8a5520a937402 192.168.4.62:6379slots:5461-10922 (5462 slots) master1 additional replica(s)
[OK] All nodes agree about slots configuration.
>>> Check for open slots...
>>> Check slots coverage...[OK] All 16384 slots covered.				#所有的slots(槽)分配完成

6、查看集群信息,选择查看任何节点均可,结果相同

[root@mgm68 ~]# redis-trib.rb info 192.168.4.65:6379
192.168.4.61:6379 (c1198049...) -> 0 keys | 5461 slots | 1 slaves.
192.168.4.63:6379 (4515ec02...) -> 0 keys | 5461 slots | 1 slaves.
192.168.4.62:6379 (1417e06b...) -> 0 keys | 5462 slots | 1 slaves.
主服务器地址和端口(ID值) ——> 存储变量的个数 | 占用槽的个数 | 从服务器个数

7、check 查看集群的详细信息,M 指的是主服务器(占用hash槽); S 指的是从服务器(不占用hash槽,从主服务器同步数据),最后指定主服务器的ID值

[root@mgm68 ~]# redis-trib.rb check 192.168.4.65:6379redis服务器本机上,查看集群信息,在redisA上操作
[root@redisA ~]# cat  /var/lib/redis/6379/nodes-6379.conf
[root@redisA ~]# redis-cli -h 192.168.4.61 -p 6379
192.168.4.61:6379> cluster info		#查看集群的状态信息
cluster_state:ok            #集群状态,OK
cluster_slots_assigned:16384
...
cluster_known_nodes:6        #集群中有6台服务器
cluster_size:3               #集群中有3台主服务器
...
192.168.4.61:6379> cluster nodes		#查看所有节点的信息
#节点在集群中的ID值(唯一的)    ID对应节点的IP地址,端口号及集群端口号   myself为当前访问的节点,master为主服务器,slave指从服务器  .......

8、vpc50客户端,访问集群存取数据

客户端通过-c 访问redis集群,访问任何一个节点都可以
[root@vpc50 ~]#  redis-cli -c -h 192.168.4.63 -p 6379##redis集群中存入数据,给数据分配槽编号为5798
##根据槽编号所在的位置,将数据存入到4.62主机上,切换到4.62主机中
192.168.4.63:6379> set name plj
-> Redirected to slot [5798] located at 192.168.4.62:6379
192.168.4.62:6379> keys *
1) "name"查看4.62主机的从服务器信息,到从服务器4.66本机上,验证数据是否同步
192.168.4.62:6379> info replication
# Replication
role:master               #4.62为主服务器
connected_slaves:1        #4.62的从服务器为4.66
slave0:ip=192.168.4.66,port=6379,state=online,offset=2813,lag=1##redis集群中继续存入数据,给数据分配槽编号为741
##根据槽编号所在的位置,将数据存入到4.61主机上,切换到4.61主机中
192.168.4.62:6379> set age 19
-> Redirected to slot [741] located at 192.168.4.61:6379##查看4.61主机的从服务器信息,到从服务器4.65本机上,验证数据是否同步
192.168.4.61:6379> info replication
# Replication
role:master             #4.61为主服务器
connected_slaves:1      #4.61的从服务器为4.65   
slave0:ip=192.168.4.65,port=6379,state=online,offset=3777,lag=0
.....
##查看当前库下的所有变量,可以看到数据
192.168.4.61:6379> keys *##redis集群中继续存入数据,给数据分配槽编号为8455
##根据槽编号所在的位置,将数据存入到4.62主机上,切换到4.62主机中
192.168.4.61:6379> set school tarena
-> Redirected to slot [8455] located at 192.168.4.62:6379
edis集群中继续存入数据,继续存储在4.62主机上
192.168.4.62:6379> set class nsd2020#查看4.62主机上的所有变量
192.168.4.62:6379> keys *
1) "school"
2) "class"
3) "name"

9、redis集群数据存储

#1》redis集群在部署完成后,每个 master主机 都被分配了一批不同编号的槽;
#2》存储数据时,会根据算法,为数据分配不同编号的槽;
#3》根据槽编号所在的位置,将数据存储在相应的master主机上;
#4》master主机对应的从服务器也会同步主服务器中的数据;

10、-c 客户端从集群中读取数据,在vpc50上

[root@redis ~]# redis-cli -c -h 192.168.4.63 -p 6379
192.168.4.62:6379> keys *
192.168.4.62:6379> get name		#从本机中获取name变量的值
192.168.4.62:6379> get age		#根据槽的编号741从4.61的主机上获取age变量的值
-> Redirected to slot [741] located at 192.168.4.61:6379
"19"

相关文章:

Redis---集群环境准备

一、redis集群环境准备 1、部署Redis集群的目的: 多台服务器一起提供数据存储服务; 实现数据的分布式存储; 可以实现服务的高可用; 可用实现数据自动备份; 2、服务器IP地址及端口: 主机名 IP地…...

数据结构考研版——队列的配置问题

一、正常配置下的情况 队空状态 frontrear;入队操作 出队操作 队满状态 在正常配置下元素的个数&#xff08;rear>front&#xff09; 当rear<front 综上所述用一个表达式表示&#xff1a;(rear-frontmaxSize)%maxSize 二、非正常配置下的情况1 队空状态 入队操作…...

【SOAP-WebService系列】SOAP学习笔记

目录 1、SOAP是什么&#xff1f; 2、SOAP特性 3、SOAP消息组成 4、SOAP调用 5、SOAP和HTTP 1、SOAP是什么&#xff1f; SOAP(Simple Object Access Protocol&#xff0c;即简单对象访问协议) &#xff0c;是一个轻量级协议&#xff0c;用于在分散的分布式环境中使用XML在对…...

材料科学|名词解释终版!!!

晶体&#xff1a;组成物质的原子&#xff0c;分子或离子按照一定的周期性规则排列形成的固体。 非晶体&#xff1a;原子在三维空间的不规则排列&#xff0c;长程无序&#xff0c;各向同性。 晶体结构&#xff1a;原子&#xff0c;离子&#xff0c;原子团按照空间点阵而进行的…...

永久免费内网穿透不限制速度

市面上的免费内网穿透大都有格式各样的限制&#xff0c;什么限制流量啊&#xff0c;每个月要签到打卡啊&#xff0c;还有更改域名地址等&#xff0c;只有神卓互联内网穿透是永久免费没有限制的&#xff0c;白嫖也可以。 这篇文章分享了3个方案&#xff0c;按照性能和综合指标排…...

JAVA开发运维(云基础设备监控)

在大型的商用系统中&#xff0c;经常需要监控云设备的健康状态&#xff0c;性能情况&#xff0c;流量数据等。及时发现系统问题&#xff0c;及时修复&#xff0c;以确保系统的高可用。检查云资源的工作内容主要包括基础监控、主动拨测、用户体验、APM监控、指标体系、业务分析、…...

现在备考2023年5月软考网络工程师时间够吗?

距离2023年5月软考还有1个多月的时间&#xff0c;备考网络工程师的时间是够的&#xff0c;以下是一些备考方法&#xff1a; 1.了解考试内容 在你开始学习考试之前&#xff0c;了解考试的形式和内容是很重要的。这将帮助你把注意力集中在最有可能被测试的领域。你应该复习考试…...

webp怎么转换成png,4个方法教你快速处理

webp怎么转换成png&#xff1f;目前在一些比较大的图片素材网站下载的图片都是webp格式的。我们都知道webp格式图片&#xff0c;它在正常的图片浏览器中是无法打开的。 所以说我们要把webp图片转变成png格式&#xff0c;正常来说我们常用的图片处理软件也能进行格式转换&#x…...

程序员能干多久?程序员能干到多大年龄?

程序员可以工作多少年?大多数程序员认为程序员是吃青春饭的工作。编程只能干到30岁&#xff0c;最长可达35岁。我经常听到这样的话&#xff0c;都让人倍感压力。今天&#xff0c;我们来谈谈这个老话题...... 程序员能干多久&#xff1f; 根据国外的经验来说&#xff0c;干到…...

采购系统是如何管理供应商的?

随着数字化的推进&#xff0c;企业面临着越来越多的供应商管理问题。企业采购数字化转型已经成为大势所趋&#xff0c;对于采购数字化转型而言&#xff0c;供应商管理是重要一环。 供应商准入管理 在供应商准入阶段&#xff0c;企业需要从供应商资质、财务能力、信誉能力、管理…...

Linux学习笔记(2)--一些内核接口

1&#xff09;dump_stack dump_stack()是Linux内核中的一个函数&#xff0c;用于在内核中输出当前的函数调用栈。该函数会输出当前线程&#xff08;或进程&#xff09;的函数调用栈信息&#xff0c;以及相应的调用地址和虚拟内存地址等信息&#xff0c;一般用于诊断程序运行时…...

学习风`宇博客用户权限菜单模块

文章目录 用户-角色-菜单-资源 各表关系图菜单 和 路由菜单表及分析分析 /api/admin/user/menus接口MenuServiceImpl#listUserMenus接口返回示例及分析 前端代码分析menu.jsSideBar.vue 接口权限控制资源表 及 分析分析 WebSecurityConfig权限控制整体流程先说登录UserDetailsS…...

centos7.6部署ELK集群(一)之elasticsearch7.7.0集群部署

32.3. 部署es7.7.0 32.3.1. 下载es&#xff08;各节点都做&#xff09; wget https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-7.7.0-linux-x86_64.tar.gz 32.3.2. 解压至安装目录&#xff08;各节点都做&#xff09; tar -xvf elasticsearch-7.7.0-li…...

leetcode142. 环形链表 II

给定一个链表的头节点 head &#xff0c;返回链表开始入环的第一个节点。 如果链表无环&#xff0c;则返回 null。 如果链表中有某个节点&#xff0c;可以通过连续跟踪 next 指针再次到达&#xff0c;则链表中存在环。 为了表示给定链表中的环&#xff0c;评测系统内部使用整数…...

Linux: network: dummy 类型网络接口

文章目录 参考创建一个重要的用途是在container平台的应用dpdk相关的一个用途另一个用途ChatGPT的回复参考 https://tldp.org/LDP/nag/node72.html 这里举了一个例子,说为什么需要dummy类型的接口:就是一个类local loopback的一个接口,当应用需要给另一个本地的应用发送包的…...

java记录-lambda表达式、接口应用、方法引用

基本形式 (str)->{System.out.println(str) };调用作为参数的接口实例的方法 1、用一个类实现接口&#xff0c;然后使用该类实例调用方法 2、匿名内部类 3、在 接口&#xff08;不能是抽象类&#xff09; 有且只有一个抽象方法时&#xff0c;可以使用lamda表达式来重写这个…...

AI写作机器人-ai文章生成器在线

使用AI续写生成器&#xff0c;让内容创作事半功倍&#xff01; 随着人工智能技术的不断进步和应用&#xff0c;AI续写生成器的出现为内容创作带来了全新的革命。这种技术可以让你的写作事半功倍&#xff0c;让你轻松生成高质量的文章和内容。在这篇文章中&#xff0c;我们将介绍…...

HarmonyOS原子化服务卡片整改、下架、升级失败部分原因及处理办法

随着HarmonyOS应用体系相关规则、团队的不断发展和完善&#xff0c;早期上架运营的HarmonyOS原子化服务卡片&#xff0c;很多都收到了整改、下架的通知&#xff0c;主要集中在用户协议、隐私声明、服务卡片的设计规范性等细节方面的问题&#xff1b;需要进行优化调整升级才行。…...

博客系统测试报告【可上线】

目录 1、测试概述 1.1、项目名称 1.2、测试时间 1.3、编写目的 1.4、测试范围 2、测试计划 2.1、测试用例 2.1.1、注册/登录模块 2.1.2、个人中心模块 2.1.3、找回密码模块 2.1.4、博客主列表模块 2.1.5、个人博客列表模块 2.1.6、个人草稿列表模块 2.1.7、博客详…...

shell中的for循环和if判断

一.编写脚本for1.sh,使用for循环创建20账户&#xff0c;账户名前缀由用户从键盘输入&#xff0c;账户初始密码由用户输入&#xff0c;例如: test1、test2、test3、.....、 test10 1.创建脚本for1.sh [rootserver ~]# vim for1.sh 2.编写脚本for1.sh 3.执行脚本for1.sh [roo…...

MPNet:旋转机械轻量化故障诊断模型详解python代码复现

目录 一、问题背景与挑战 二、MPNet核心架构 2.1 多分支特征融合模块(MBFM) 2.2 残差注意力金字塔模块(RAPM) 2.2.1 空间金字塔注意力(SPA) 2.2.2 金字塔残差块(PRBlock) 2.3 分类器设计 三、关键技术突破 3.1 多尺度特征融合 3.2 轻量化设计策略 3.3 抗噪声…...

Debian系统简介

目录 Debian系统介绍 Debian版本介绍 Debian软件源介绍 软件包管理工具dpkg dpkg核心指令详解 安装软件包 卸载软件包 查询软件包状态 验证软件包完整性 手动处理依赖关系 dpkg vs apt Debian系统介绍 Debian 和 Ubuntu 都是基于 Debian内核 的 Linux 发行版&#xff…...

安宝特方案丨XRSOP人员作业标准化管理平台:AR智慧点检验收套件

在选煤厂、化工厂、钢铁厂等过程生产型企业&#xff0c;其生产设备的运行效率和非计划停机对工业制造效益有较大影响。 随着企业自动化和智能化建设的推进&#xff0c;需提前预防假检、错检、漏检&#xff0c;推动智慧生产运维系统数据的流动和现场赋能应用。同时&#xff0c;…...

Leetcode 3577. Count the Number of Computer Unlocking Permutations

Leetcode 3577. Count the Number of Computer Unlocking Permutations 1. 解题思路2. 代码实现 题目链接&#xff1a;3577. Count the Number of Computer Unlocking Permutations 1. 解题思路 这一题其实就是一个脑筋急转弯&#xff0c;要想要能够将所有的电脑解锁&#x…...

【算法训练营Day07】字符串part1

文章目录 反转字符串反转字符串II替换数字 反转字符串 题目链接&#xff1a;344. 反转字符串 双指针法&#xff0c;两个指针的元素直接调转即可 class Solution {public void reverseString(char[] s) {int head 0;int end s.length - 1;while(head < end) {char temp …...

[10-3]软件I2C读写MPU6050 江协科技学习笔记(16个知识点)

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16...

《基于Apache Flink的流处理》笔记

思维导图 1-3 章 4-7章 8-11 章 参考资料 源码&#xff1a; https://github.com/streaming-with-flink 博客 https://flink.apache.org/bloghttps://www.ververica.com/blog 聚会及会议 https://flink-forward.orghttps://www.meetup.com/topics/apache-flink https://n…...

3-11单元格区域边界定位(End属性)学习笔记

返回一个Range 对象&#xff0c;只读。该对象代表包含源区域的区域上端下端左端右端的最后一个单元格。等同于按键 End 向上键(End(xlUp))、End向下键(End(xlDown))、End向左键(End(xlToLeft)End向右键(End(xlToRight)) 注意&#xff1a;它移动的位置必须是相连的有内容的单元格…...

Unity | AmplifyShaderEditor插件基础(第七集:平面波动shader)

目录 一、&#x1f44b;&#x1f3fb;前言 二、&#x1f608;sinx波动的基本原理 三、&#x1f608;波动起来 1.sinx节点介绍 2.vertexPosition 3.集成Vector3 a.节点Append b.连起来 4.波动起来 a.波动的原理 b.时间节点 c.sinx的处理 四、&#x1f30a;波动优化…...

rnn判断string中第一次出现a的下标

# coding:utf8 import torch import torch.nn as nn import numpy as np import random import json""" 基于pytorch的网络编写 实现一个RNN网络完成多分类任务 判断字符 a 第一次出现在字符串中的位置 """class TorchModel(nn.Module):def __in…...