redis-集群 原生部署和工具自动部署

  • 什么redis集群?

    • redis集群是一个提供在多个redis节点之间共享数据的程序集。它并不像redis主从复制模式那样仅提供一个master节点来提供写服务,而是会提供多个master节点来提供写服务,每个master节点中存储的数据都不一样,这些数据通过数据分片的方式被自动分割到不同的master节点上
  • redis集群介绍:

    • Redis Cluster 是redis的分布式解决方案,当遇到单机、内存、流量等瓶颈时,可以采用cluster架构方式达到负载均衡的目的
  • 数据分布:

    • 分布式数据库首先要解决吧整个数据库集按照分区规则映射到多个节点的问题,即把数据集划分到多个节点上,每个节点负责整体数据的一个子集,需要关注的是数据分片规则,Rredis Cluster采用哈希分片规则。
  • 集群节点之间的通讯方式:

    • 节点之间通过建立TCP连接,使用gossip协议来传播集群的信息。端口为:服务端口+10000
  • Redis Cluster部署的两种方式:

    • 原生安装与官方工具安装

    • 原生安装的步骤:

      • 1.手动配置节点发现
      • 2.meet操作(通知新节点加入)
      • 3.指派槽位
      • 4.分主从
    • 官方工具安装:

      • 如果redis版本为3打头需要手动安装redis-trib.rb工具,新版本无需安装
  • 本章实验环境如下:

    • 环境介绍:

      • 为了使整个集群变得高可用性,我们给每台服务器上开了两个实例 一个为master一个为slave,当master节点故障,则会自动使用slave升级为master节点。
      • 如何知道集群中某个节点故障了呢?
        • 他们之间的通讯方式:每个节点都使用tcp协议相互通讯交流,当某个master出现故障时,所有节点都会知道这个出现故障的master,这时集群会自动把故障下面的salve升级为master
    • 实验操作:

      • 原生安装:

      • 1.三台服务器上部署redis服务:
        • redis1:创建数据目录和安装目录:
          • mkdir -p /opt/redis_cluster/redis_{6380,6381}/{conf,logs,pid}
          • mkdir -p /data/redis_cluster/redis_{6380,6381}
        • 解压安装包到/opt/redis_cluster目录下:
          • tar xf redis-5.0.7.tar.gz -C /opt/redis_cluster/
          • cd /opt/redis_cluster/
          • ln -s redis-5.0.7 redis
          • cd redis
          • make && make install
        • 编辑配置文件:
          • 配置文件解释:

          • cat >/opt/redis_cluster/redis_6380/conf/redis_6380.conf<<EOF
            bind 192.168.8.5
            port 6380
            daemonize yes
            pidfile "/opt/redis_cluster/redis_6380/pid/redis_6380.pid"
            logfile "/opt/redis_cluster/redis_6380/logs/redis_6380.log"
            dbfilename "redis_6380.rdb"
            dir "/data/redis_cluster/redis_6380/"
            cluster-enabled yes
            cluster-config-file nodes_6380.conf
            cluster-node-timeout 15000
            EOF
            cd /opt/redis_cluster/
            cp redis_6380/conf/redis_6380.conf redis_6381/conf/redis_6381.conf
            sed -i 's#6380#6381#g' redis_6381/conf/redis_6381.conf 
            redis-server /opt/redis_cluster/redis_6380/conf/redis_6380.conf
            redis-server /opt/redis_cluster/redis_6381/conf/redis_6381.conf
            

        • 将redis1服务器的安装目录和数据目录,远程复制到redis2、redis3服务器上:
          • scp -rp /opt/* root@192.168.8.6:/opt
          • scp -rp /opt/* root@192.168.8.7:/opt
        • redis2 操作:
          • cd /opt/redis_cluster/redis
            make install 
            find /opt/redis_cluster/redis_638* -type f -name "*.conf"|xargs sed -i "s#5#6#g"
            mkdir -p /data/redis_cluster/redis_{6380,6381}
            redis-server /opt/redis_cluster/redis_6380/conf/redis_6380.conf
            redis-server /opt/redis_cluster/redis_6381/conf/redis_6381.conf
            

        • redis3 操作:
          • cd /opt/redis_cluster/redis
            make install
            find /opt/redis_cluster/redis_638* -type f -name "*.conf"|xargs sed -i "s#5#7#g"
            mkdir -p /data/redis_cluster/redis_{6380,6381}
            redis-server /opt/redis_cluster/redis_6380/conf/redis_6380.conf
            redis-server /opt/redis_cluster/redis_6381/conf/redis_6381.conf
            

        • 查看8.6-7服务器上是否有6380和6381端口:
          • netstat -anpt | grep 638
        • 至此每台服务器上出现此端口,代表三台redis部署启动成功。
      • 开始创建群集:

        • 1.手动配置节点发现:
          • 登录任意一台服务器的redis节点:
            • redis-cli -h 192.168.8.5 -p 6380
            • 登录8.5的6380redis实例后,开始发现其他五个节点:
              • 使用节点发现命令,发现其他五个节点(登录数据库后执行):
                • CLUSTER MEET 192.168.8.5 6381
                  CLUSTER MEET 192.168.8.6 6380
                  CLUSTER MEET 192.168.8.7 6380
                  CLUSTER MEET 192.168.8.6 6381
                  CLUSTER MEET 192.168.8.7 6381
                  

            • 查看集群信息:
              • CLUSTER NODES
            • Redis Cluster 通讯流程:
              • 1)集群中的每一个节点都会单独开辟一个 Tcp 通道,用于节点之间彼此通信,防火墙放行(端口号+10000).
              • 2)每个节点在固定周期内通过特定规则选择结构节点发送 ping 消息
              • 3)接收到 ping 消息的节点用 pong 消息作为响应。集群中每个节点通过一定规则挑选要通信的节点,每个节点可能知道全部节点,也可能仅知道部分节点,
              • 只要这些节点彼此可以正常通信,最终他们会打成一致的状态,当节点出现故障,新节点加入,主从角色变化等,它能够给不断的ping/pong消息,从而达到同步目的。
            • Redis Cluster手动分配槽位:
              • 现在节点之间已经互相发现了,但是此时集群还是不可用的状态,因为并没有给节点分配槽位,而且必须是所有的槽位都分配完毕后整个集群才是可用的状态。
              • 我们虽然是有6个节点,但是真正写入数据的只有三个节点,其他三个节点只是作为主节点的从节点,只需要分配这其中三个主节点的槽位就可以了
              • 分别登录到每个主节点的客户端来执行命令:
                • 在数据库外执行:
                  • redis-cli -h 192.168.8.5 -p 6380 cluster addslots {0..5460}
                    redis-cli -h 192.168.8.6 -p 6380 cluster addslots {5461..10922}
                    redis-cli -h 192.168.8.7 -p 6380 cluster addslots {10923..16383}
                    

              • 再次查看集群信息:
                • 可以看到后面有了刚才分配的槽位,群集状态也是ok的。

            • 手动配置集群高可用:
              • 虽然这时候集群是可以用得了,但是整个集群只要有一台机器坏掉了,那么整个集群都是不可用的。
              • 这时候就需要将另外三个没有槽位的三个节点分别作为现在三个有槽位的主节点的从节点,这样就可以应对集群主节点故障时可以进行自动切换,以保证整个集群的高可用性。
              • 在任意一台redis服务器上远程操作集群其他节点
                • 注意:需要执行命令的是每个服务器的从节点
                  • 注意主从的ID不要搞混了
                  • 主从节点不要在一台服务器上,要交叉分主从
                • redis-cli -h 192.168.8.5 -p 6381 CLUSTER REPLICATE 49cbd0227229494070be11e3bc2a4a383f8d535e  (第二台主机6380的id)id号查看自己的id号
                  redis-cli -h 192.168.8.6 -p 6381 CLUSTER REPLICATE c9f13f78e29245ca993ea635ab27a3e260c6a210(第三台主机6380的id)
                  redis-cli -h 192.168.8.7 -p 6381 CLUSTER REPLICATE 6bb3f91ff8da948fc07d25445992e2161ed741f4	(第一台主机6380的id)
                  

              • 再次查看群集信息:
                • 发现每台主机的6381端口节点,都变成了slave状态(从服务器)

                • 此时手动搭建群集以部署完毕,测试是否可以正常存储数据!!
              • Redis Cluster测试集群:
                • 此时我们使用常规插入redis数据的方式往集群里写数据看看会发生什么
                • redis-cli -h 192.168.8.5 -p 6380 set k1 v1
                • 并没有插入数据到数据库中,这是因为集群后由于数据被分片了,所以并不是说在那台机器上写入数据就会在那台机器的节点上写入。
                • 集群的数据写入和读取就要涉及到另外一个概念,ASK路由。
                • Redis Cluster ASK路由介绍:
                  • 在集群模式下,redis接受任何键相关命令是首选会计算键对应的槽(slot),再根据槽找出所对应的节点,如果节点是自身,则处理键命令;
                  • 否则恢复MOVED重定向错误,通知客户端请求正确的节点,这个过程称为MOVER重定向。
                  • redis-cli客户端提供了-c参数实现自动重定向。
                • 插入数据:redis-cli -c -h 192.168.8.5 -p 6380 set k1 v1
                • 写入后同样需要使用-c选项来读取键值:
                • 读取数据:redis-cli -c -h 192.168.8.5 -p 6380 get k1
              • Redis Cluster模拟故障转移
                • 模拟redis2故障:
                  • redis-cli -h 192.168.8.6 -p 6380 shutdown
                  • redis-cli -h 192.168.8.6 -p 6381 shutdown
                • 查看群集节点状态:
                  • redis-cli -h 192.168.8.5 -p 6380
                    • cluster nodes
                  • 关闭8.6的6380主节点后,8.5的6381从节点自动又主节点切换回了主节点

                • 再次将8.6服务器上的两个节点启动起来:
                  • redis-server /opt/redis_cluster/redis_6380/conf/redis_6380.conf
                  • redis-server /opt/redis_cluster/redis_6381/conf/redis_6381.conf
                • 查看群集节点状态:
                  • 8.5的6381切换回了slave。
      • 使用工具自动搭建部署Redis Cluster集群

        • 实验环境还是6个节点与原生安装一样:
          • 部署redis节点过程略与上方一样
        • 开始部署群集:
          • 无需安装redis-trib.rb工具(新版本无需安装),节点部署好后直接创建集群
          • 创建群集:
          • redis-cli --cluster create --cluster-replicas 1 192.168.8.5:6380 192.168.8.6:6380 192.168.8.7:6380 192.168.8.5:6381 192.168.8.6:6381 192.168.8.7:6381
            • (前面三个自动被分配为master,后三个自动被分配为slave)
            • 直接yes即可
          • 检查完整性:redis-cli --cluster check 192.168.8.5:6380
            • 槽位也被自动分配了

          • 当我们节点不够用时,使用redis集群扩容:
            • 1)准备新节点
            • 2)加入集群
            • 3)迁移槽和数据
          • 为了省资源,我们在redis1服务器上再创建两个新节点
            • mkdir -p /opt/redis_cluster/redis_{6390,6391}/{conf,logs,pid}
            • mkdir -p /data/redis_cluster/redis_{6390,6391}
            • cd /opt/redis_cluster/
            • cp redis_6380/conf/redis_6380.conf redis_6390/conf/redis_6390.conf
            • cp redis_6380/conf/redis_6380.conf redis_6391/conf/redis_6391.conf
            • sed -i 's#6380#6390#g' redis_6390/conf/redis_6390.conf
            • sed -i 's#6380#6391#g' redis_6391/conf/redis_6391.conf
            • 启动节点
              • redis-server /opt/redis_cluster/redis_6390/conf/redis_6390.conf
              • redis-server /opt/redis_cluster/redis_6391/conf/redis_6391.conf
            • 发现节点:(将新建的两台节点)
              • redis-cli -c -h 192.168.8.5 -p 6380 cluster meet 192.168.8.5 6390
              • redis-cli -c -h 192.168.8.5 -p 6380 cluster meet 192.168.8.5 6391
            • 从之前的三台master节点服务器上向新的6390节点分配slots槽位
              • redis-cli --cluster reshard 192.168.8.5:6390
            • 将6391顺从于6390:
              • redis-cli -h 192.168.8.5 -p 6391 cluster replicate 6390id
            • 再次检查集群,发现6390有了槽位,6391 没有槽位也是slave
            • 扩展完之后,再将它们收缩:
              • 移除下线节点的槽位:
              • redis-cli --cluster reshard 192.168.8.5:6390
                • 这样重复三次,即可将槽位还回去
                  • 1365 给redis1的6380
                  • 1366 给redis2的6380
                  • 1365 给redis3的6380
              • 移除下线的节点:
                • redis-cli -c -h 192.168.8.5 -p 6380 cluster forget 6f2a812b88aa230e13fadabc1096304ddcbddc17(6390id)
                • redis-cli -c -h 192.168.8.5 -p 6380 cluster forget 547176fc5e7b7a3fb144ea1cb49dd48018d3ff3c(6391id)
          • 至此整章redis集群的原生部署和自动部署环境分别介绍完毕,感谢观看!!
  •  

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

buildadmim生成代码时让菜单有层级

当我们使用buildadmin生成代码的时候&#xff0c;在菜单的部分&#xff0c; 有时希望它生的是一个带有层级的菜单&#xff0c;有时候则想生成一个没有层级的菜单 like this 经过本人测试 如果我们要生成没有层级的菜单 我们可以在高级设置中的 相对位置处更改&#xff0c;同时…

O2O:Adaptive policy learning for offline-to-online reinforcement learning

AAAI2023 paper Introduction 传统Online RL需要智能体与环境进行海量交互&#xff0c;而Offline RL容易受限于数据集质量。因此本文提出一种O2O的自适应策略学习框架APL。APL在离线阶段悲观更新策略而在现阶段乐观更新。进一步&#xff0c;基于框架分别提出value-based 以及…

蓝牙APP开发实现汽车遥控钥匙解锁汽车智能时代

在现代社会&#xff0c;随着科技的不断发展&#xff0c;汽车已经不再是简单的交通工具&#xff0c;而是与智能科技紧密相连的载体。其中&#xff0c;通过开发APP蓝牙程序实现汽车遥控钥匙成为了一种趋势&#xff0c;为车主带来了便捷与安全的体验。虎克技术公司作为行业领先者&…

Redis6 搭建主从集群架构

文章目录 搭建Redis主从集群架构1.集群结构2.准备实例和配置3.启动4.开启主从关系5.测试 搭建Redis主从集群架构 安装部署单机版Redis6可参考&#xff1a; 安装部署单机版Redis6 1.集群结构 我们搭建的主从集群结构如图&#xff1a; 我们计划是在一台虚拟机里去部署三个R…

区块链媒体套餐:精益求精链游媒体宣发推广7个关键细节分享-华媒舍

在如今竞争激烈的游戏行业&#xff0c;一款优秀的游戏缺乏有效的宣发推广&#xff0c;很难脱颖而出。而随着区块链技术的兴起&#xff0c;链游媒体的宣发推广成为游戏开发者和运营商的重要选择之一。本文将为大家介绍精益求精的链游媒体宣发推广的七个关键细节。 1. 定位目标受…

初学C++

注释 变量 作用&#xff1a;给一段指定的内存空间起名&#xff0c;方便操作这段内容 数据类型 变量名 变量初始值; 常量 用于记录程序中不可更改的数据 宏常量&#xff1a; #define 宏常量 常量值 const修饰的变量&#xff1a; const 数据类型 常量名 常量值; 关键字 …

从0到1入门C++编程——10 stack容器、queue容器、list容器、set容器、map容器

文章目录 一、stack容器二、queue容器三、list容器1、构造函数2、赋值和交换3、大小及判空4、插入和删除5、数据存取6、反转和排序7、排序案例 四、set/multiset容器1、构造和赋值2、大小和交换3、插入和删除4、查找和统计5、set和multiset的区别6、pair对组的创建7、排序及规则…

文献速递:深度学习疾病预后--临床级计算病理学使用基于整张切片图像的弱监督深度学习

Title 题目 Clinical-grade computational pathology using weakly supervised deep learning on whole slide images 临床级计算病理学使用基于整张切片图像的弱监督深度学习 01 文献速递介绍 The development of decision support systems for pathology and their deplo…

下载无水印抖音视频

在抖音看到某些视频想下载&#xff0c;却出现无法保存在本地【显示"作品暂时无法保存,链接已复制"】。或者下载的视频有水印。 而某些微信小程序下载可能需要付费或者有水印。其实我们可以直接使用电脑浏览器直接下载。 举个例子: 这是来自王道官方账号的一条视频链…

融合软硬件串流多媒体技术的远程控制方案

远程技术已经发展得有相当水平了&#xff0c;在远程办公&#xff0c;云游戏&#xff0c;云渲染等领域有相当多的应用场景&#xff0c;以向日葵&#xff0c;todesk rustdesk等优秀产品攻城略地&#xff0c;估值越来越高。占据了通用应用的方方面面。 但是细分市场&#xff0c;还…

【Simulink系列】——控制系统仿真基础

声明&#xff1a;本系列博客参考有关专业书籍&#xff0c;截图均为自己实操&#xff0c;仅供交流学习&#xff01; 一、控制系统基本概念 这里就不再介绍类似于开环系统、闭环系统等基本概念了&#xff01; 1、数学模型 控制系统的数学模型是指动态数学模型&#xff0c;大致…

开源文生图大模型Playground v2.5发布:超越SD、DALL·E 3和 Midjourney

前言 在AI技术迅速发展的今天&#xff0c;文生图模型成为了艺术创作、设计创新等领域的重要工具。Playground v2.5的发布&#xff0c;不仅在技术上取得了突破&#xff0c;更在开源文化的推广与实践上迈出了重要一步。 Huggingface模型下载&#xff1a;https://huggingface.co/…

【记录处理Vue项目中Video.js播放不了MP4视频Bug】

记录处理Vue项目中Video.js播放不了MP4视频Bug 一、项目场景&#xff1a;二、问题描述三、原因分析&#xff1a;四、解决方案&#xff1a; 一、项目场景&#xff1a; 在Vue项目中使用Video.js播放MP4视频。 二、问题描述 在项目中使用Video.js播放MP4视频。视频采集上来存在数…

使用java批量写入环境变量

环境需求 jdk版本&#xff1a;1.8 jna依赖&#xff1a; <dependency><groupId>net.java.dev.jna</groupId><artifactId>jna</artifactId><version>5.10.0</version></dependency><dependency><groupId>net.java.…

Java - Spring MVC 实现跨域资源 CORS 请求

据我所知道的是有三种方式&#xff1a;Tomcat 配置、拦截器设置响应头和使用 Spring MVC 4.2。 设置 Tomcat 这种方式就是引用别人封装好的两个 jar 包&#xff0c;配置一下web.xml就行了。我也并不推荐&#xff0c;这里放两个我在网上找到的配置相关文章&#xff0c;感兴趣可…

更快更强,Claude 3全面超越GPT4,能归纳15万单词

ChatGPT4和Gemini Ultra被Claude 3 AI模型超越了&#xff1f; 3月4日周一&#xff0c;人工智能公司Anthropic推出了Claude 3系列AI模型和新型聊天机器人&#xff0c;其中包括Opus、Sonnet和Haiku三种模型&#xff0c;该公司声称&#xff0c;这是迄今为止它们开发的最快速、最强…

【论文阅读】DeepLab:语义图像分割与深度卷积网络,自然卷积,和完全连接的crf

【论文阅读】DeepLab:语义图像分割与深度卷积网络&#xff0c;自然卷积&#xff0c;和完全连接的crf 文章目录 【论文阅读】DeepLab:语义图像分割与深度卷积网络&#xff0c;自然卷积&#xff0c;和完全连接的crf一、介绍二、联系工作三、方法3.1 整体结构3.2 使用空间金字塔池…

Stable Diffusion 提示词语法(Prompt)

本文收录于《AI绘画从入门到精通》专栏&#xff0c;专栏总目录&#xff1a;点这里。 大家好&#xff0c;我是水滴~~ 本篇文章主要讲述 Stable Diffusion 提示词语法&#xff0c;主要包括&#xff1a;提示词的概念、提示词的长度、权重、分步绘制、交替绘制、组合绘制等&#x…

ORA/GSA -- 学习记录

brief over-representation analysis(ORA),过表“达”分析&#xff0c;就是我们做多分组的RNAseq数据解析后会得到一些差异表达的gene&#xff0c;有些时候是单独拿出一个差异gene去解释表型&#xff0c;缺点是欠缺证据力度。有些人就把一些相关的差异gene放在一块儿解释&…

leetcode 热题 100_最大子数组和

题解一&#xff1a; 动态规划&#xff1a;这是一道经典的动态规划题。维护一个dp数组&#xff0c;dp[i]表示0~i组成的数组的最大子数组和。当数组长度为1时&#xff0c;最大和连续子数组是它本身&#xff0c;也就是dp[i]nums[i]。当数组长度每增加1时&#xff0c;最大和连续子数…