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;入队操作 出队操作 队满状态 在正常配置下元素的个数(rear>front) 当rear<front 综上所述用一个表达式表示:(rear-frontmaxSize)%maxSize 二、非正常配置下的情况1 队空状态 入队操作…...
【SOAP-WebService系列】SOAP学习笔记
目录 1、SOAP是什么? 2、SOAP特性 3、SOAP消息组成 4、SOAP调用 5、SOAP和HTTP 1、SOAP是什么? SOAP(Simple Object Access Protocol,即简单对象访问协议) ,是一个轻量级协议,用于在分散的分布式环境中使用XML在对…...
材料科学|名词解释终版!!!
晶体:组成物质的原子,分子或离子按照一定的周期性规则排列形成的固体。 非晶体:原子在三维空间的不规则排列,长程无序,各向同性。 晶体结构:原子,离子,原子团按照空间点阵而进行的…...
永久免费内网穿透不限制速度
市面上的免费内网穿透大都有格式各样的限制,什么限制流量啊,每个月要签到打卡啊,还有更改域名地址等,只有神卓互联内网穿透是永久免费没有限制的,白嫖也可以。 这篇文章分享了3个方案,按照性能和综合指标排…...
JAVA开发运维(云基础设备监控)
在大型的商用系统中,经常需要监控云设备的健康状态,性能情况,流量数据等。及时发现系统问题,及时修复,以确保系统的高可用。检查云资源的工作内容主要包括基础监控、主动拨测、用户体验、APM监控、指标体系、业务分析、…...
现在备考2023年5月软考网络工程师时间够吗?
距离2023年5月软考还有1个多月的时间,备考网络工程师的时间是够的,以下是一些备考方法: 1.了解考试内容 在你开始学习考试之前,了解考试的形式和内容是很重要的。这将帮助你把注意力集中在最有可能被测试的领域。你应该复习考试…...
webp怎么转换成png,4个方法教你快速处理
webp怎么转换成png?目前在一些比较大的图片素材网站下载的图片都是webp格式的。我们都知道webp格式图片,它在正常的图片浏览器中是无法打开的。 所以说我们要把webp图片转变成png格式,正常来说我们常用的图片处理软件也能进行格式转换&#x…...
程序员能干多久?程序员能干到多大年龄?
程序员可以工作多少年?大多数程序员认为程序员是吃青春饭的工作。编程只能干到30岁,最长可达35岁。我经常听到这样的话,都让人倍感压力。今天,我们来谈谈这个老话题...... 程序员能干多久? 根据国外的经验来说,干到…...
采购系统是如何管理供应商的?
随着数字化的推进,企业面临着越来越多的供应商管理问题。企业采购数字化转型已经成为大势所趋,对于采购数字化转型而言,供应商管理是重要一环。 供应商准入管理 在供应商准入阶段,企业需要从供应商资质、财务能力、信誉能力、管理…...
Linux学习笔记(2)--一些内核接口
1)dump_stack dump_stack()是Linux内核中的一个函数,用于在内核中输出当前的函数调用栈。该函数会输出当前线程(或进程)的函数调用栈信息,以及相应的调用地址和虚拟内存地址等信息,一般用于诊断程序运行时…...
学习风`宇博客用户权限菜单模块
文章目录 用户-角色-菜单-资源 各表关系图菜单 和 路由菜单表及分析分析 /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(各节点都做) wget https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-7.7.0-linux-x86_64.tar.gz 32.3.2. 解压至安装目录(各节点都做) tar -xvf elasticsearch-7.7.0-li…...
leetcode142. 环形链表 II
给定一个链表的头节点 head ,返回链表开始入环的第一个节点。 如果链表无环,则返回 null。 如果链表中有某个节点,可以通过连续跟踪 next 指针再次到达,则链表中存在环。 为了表示给定链表中的环,评测系统内部使用整数…...
Linux: network: dummy 类型网络接口
文章目录 参考创建一个重要的用途是在container平台的应用dpdk相关的一个用途另一个用途ChatGPT的回复参考 https://tldp.org/LDP/nag/node72.html 这里举了一个例子,说为什么需要dummy类型的接口:就是一个类local loopback的一个接口,当应用需要给另一个本地的应用发送包的…...
java记录-lambda表达式、接口应用、方法引用
基本形式 (str)->{System.out.println(str) };调用作为参数的接口实例的方法 1、用一个类实现接口,然后使用该类实例调用方法 2、匿名内部类 3、在 接口(不能是抽象类) 有且只有一个抽象方法时,可以使用lamda表达式来重写这个…...
AI写作机器人-ai文章生成器在线
使用AI续写生成器,让内容创作事半功倍! 随着人工智能技术的不断进步和应用,AI续写生成器的出现为内容创作带来了全新的革命。这种技术可以让你的写作事半功倍,让你轻松生成高质量的文章和内容。在这篇文章中,我们将介绍…...
HarmonyOS原子化服务卡片整改、下架、升级失败部分原因及处理办法
随着HarmonyOS应用体系相关规则、团队的不断发展和完善,早期上架运营的HarmonyOS原子化服务卡片,很多都收到了整改、下架的通知,主要集中在用户协议、隐私声明、服务卡片的设计规范性等细节方面的问题;需要进行优化调整升级才行。…...
博客系统测试报告【可上线】
目录 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账户,账户名前缀由用户从键盘输入,账户初始密码由用户输入,例如: test1、test2、test3、.....、 test10 1.创建脚本for1.sh [rootserver ~]# vim for1.sh 2.编写脚本for1.sh 3.执行脚本for1.sh [roo…...
Cilium动手实验室: 精通之旅---20.Isovalent Enterprise for Cilium: Zero Trust Visibility
Cilium动手实验室: 精通之旅---20.Isovalent Enterprise for Cilium: Zero Trust Visibility 1. 实验室环境1.1 实验室环境1.2 小测试 2. The Endor System2.1 部署应用2.2 检查现有策略 3. Cilium 策略实体3.1 创建 allow-all 网络策略3.2 在 Hubble CLI 中验证网络策略源3.3 …...
【论文笔记】若干矿井粉尘检测算法概述
总的来说,传统机器学习、传统机器学习与深度学习的结合、LSTM等算法所需要的数据集来源于矿井传感器测量的粉尘浓度,通过建立回归模型来预测未来矿井的粉尘浓度。传统机器学习算法性能易受数据中极端值的影响。YOLO等计算机视觉算法所需要的数据集来源于…...
ardupilot 开发环境eclipse 中import 缺少C++
目录 文章目录 目录摘要1.修复过程摘要 本节主要解决ardupilot 开发环境eclipse 中import 缺少C++,无法导入ardupilot代码,会引起查看不方便的问题。如下图所示 1.修复过程 0.安装ubuntu 软件中自带的eclipse 1.打开eclipse—Help—install new software 2.在 Work with中…...
MySQL中【正则表达式】用法
MySQL 中正则表达式通过 REGEXP 或 RLIKE 操作符实现(两者等价),用于在 WHERE 子句中进行复杂的字符串模式匹配。以下是核心用法和示例: 一、基础语法 SELECT column_name FROM table_name WHERE column_name REGEXP pattern; …...
【7色560页】职场可视化逻辑图高级数据分析PPT模版
7种色调职场工作汇报PPT,橙蓝、黑红、红蓝、蓝橙灰、浅蓝、浅绿、深蓝七种色调模版 【7色560页】职场可视化逻辑图高级数据分析PPT模版:职场可视化逻辑图分析PPT模版https://pan.quark.cn/s/78aeabbd92d1...
力扣热题100 k个一组反转链表题解
题目: 代码: func reverseKGroup(head *ListNode, k int) *ListNode {cur : headfor i : 0; i < k; i {if cur nil {return head}cur cur.Next}newHead : reverse(head, cur)head.Next reverseKGroup(cur, k)return newHead }func reverse(start, end *ListNode) *ListN…...
Caliper 配置文件解析:fisco-bcos.json
config.yaml 文件 config.yaml 是 Caliper 的主配置文件,通常包含以下内容: test:name: fisco-bcos-test # 测试名称description: Performance test of FISCO-BCOS # 测试描述workers:type: local # 工作进程类型number: 5 # 工作进程数量monitor:type: - docker- pro…...
探索Selenium:自动化测试的神奇钥匙
目录 一、Selenium 是什么1.1 定义与概念1.2 发展历程1.3 功能概述 二、Selenium 工作原理剖析2.1 架构组成2.2 工作流程2.3 通信机制 三、Selenium 的优势3.1 跨浏览器与平台支持3.2 丰富的语言支持3.3 强大的社区支持 四、Selenium 的应用场景4.1 Web 应用自动化测试4.2 数据…...
热烈祝贺埃文科技正式加入可信数据空间发展联盟
2025年4月29日,在福州举办的第八届数字中国建设峰会“可信数据空间分论坛”上,可信数据空间发展联盟正式宣告成立。国家数据局党组书记、局长刘烈宏出席并致辞,强调该联盟是推进全国一体化数据市场建设的关键抓手。 郑州埃文科技有限公司&am…...
论文阅读:Matting by Generation
今天介绍一篇关于 matting 抠图的文章,抠图也算是计算机视觉里面非常经典的一个任务了。从早期的经典算法到如今的深度学习算法,已经有很多的工作和这个任务相关。这两年 diffusion 模型很火,大家又开始用 diffusion 模型做各种 CV 任务了&am…...
