6.redis-集群

news2025/1/19 11:20:55

01-集群cluster

  • 存在的问题

    • redis提供的服务OPS(operation per second)可以达到10万/秒,当前业务OPS如果超过10万/秒,怎么办?
  • redis集群

    • [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-gITgqXr9-1681709270830)(null)]

    • 使用网络将若干redis主从机器机联通起来,并提供统一的管理方式,使其对外呈现单机的服务效果

  • 好处

    • 分散单台服务器的访问压力,实现负载均衡
    • 分散单台服务器的存储压力,实现可扩展性
    • 降低单台服务器宕机带来的业务灾难

02-cluster集群搭建

  • 需求

    • 搭建三个 1主1从 结构,并启动cluster集群
  • 配置说明

    # 是否启用cluster,加入cluster节点
    cluster-enabled yes|no
    
    # cluster配置文件名,该文件属于自动生成,仅用于快速查找文件并查询文件内容
    cluster-config-file filename
    
    # 节点服务响应超时时间,用于判定该节点是否下线或切换为从节点
    cluster-node-timeout milliseconds
    
  • 语法

    #主机ip1:主机port1
    #从机ip1:从机port1
    #n: 1台主机对应n台从机
    
    redis-cli --cluster create 主机ip1:主机port1 [主机ip2:主机port2 ...] 从机ip1:从机port1 [从机ip2:从机port2 ...] --cluster-replicas n
    
  • 开发步骤

    • ①配置主从结构
    • ②启动主从服务
    • ③启用集群服务
    • ④查看集群信息
  • ①配置主从结构

    #主机配置
    port 6379
    daemonize no
    # logfile "log-6379.log"
    maxclients 100000
    timeout 0
    loglevel debug
    
    # RDB设置
    # 1.设置rdb文件名
    dbfilename "dump-6379.rdb"
    
    # 2.设置rdb文件存储路径
    dir "/usr/local/redis-6379/data"
    
    # 3.设置存储rdb时是否压缩数据
    rdbcompression no
    
    # 4.设置读写文件过程是否进行RDB格式校验
    rdbchecksum no
    
    # 5.后台存储过程中如果出现错误现象,是否停止保存操作
    stop-writes-on-bgsave-error yes
    
    # 6.每隔10秒检测一次,有2个数据变化就执行bgsave指令
    save 10 2
    
    # AOF设置
    # 1.开启aof持久化功能
    appendonly yes
    # 2.设置aof文件名
    appendfilename "appendonly-6379.aof"
    # 4.设置aof策略
    appendfsync everysec
    
    # 5.当前aof文件大小达到64mb,自动触发AOF重写
    auto-aof-rewrite-min-size 64mb
    # 5.当前aof文件大小比之前aof文件大小增加了100%,自动触发AOF重写
    auto-aof-rewrite-percentage 100
    
    protected-mode no
    
    # 是否启用cluster,加入cluster节点
    cluster-enabled yes
    
    # cluster配置文件名,该文件属于自动生成,仅用于快速查找文件并查询文件内容
    cluster-config-file "cluster-6379.conf"
    
    # 节点服务响应超时时间,用于判定该节点是否下线或切换为从节点
    cluster-node-timeout 5000
    
    #从机配置
    # slave-26379
    
    port 26379
    daemonize no
    dir "/usr/local/redis-26379/data"
    
    # 设置RDB文件
    dbfilename "dump-26379.rdb"
    
    # 开启aof
    appendonly yes
    appendfilename "appendonly-26379.aof"
    appendfsync everysec
    
    # 设置无密码访问
    protected-mode no
    
    # 开启集群
    cluster-enabled yes
    # cluster配置文件名
    cluster-config-file "cluster-26379.conf"
    # 节点服务响应超时时间为5秒
    cluster-node-timeout 5000
    
  • ②启动主从服务

    # 集群至少3个主节点,至少6个节点
    
    redis-server /usr/local/redis-6379/redis-6379.conf
    redis-server /usr/local/redis-6380/redis-6380.conf
    redis-server /usr/local/redis-6381/redis-6381.conf
    
    redis-server /usr/local/redis-26379/redis-26379.conf
    redis-server /usr/local/redis-26380/redis-26380.conf
    redis-server /usr/local/redis-26381/redis-26381.conf
    
  • ③启用集群服务

    redis-cli --cluster create 192.168.199.110:6379 192.168.199.110:6380 192.168.199.110:6381 192.168.199.110:26379 192.168.199.110:26380  192.168.199.110:26381 --cluster-replicas 1
    
    • ga3vqwetg3qw4a5rfvwq
  • ④查看集群信息

    cluster nodes
    
    • 3tgy4q2r5w627y35q6
  • 注意事项

    • 在cluster集群中, 确认主从关系不需要配置slaveof ip port
    • redis集群有16384个槽, 默认是等分.

03-cluster集群演示

  • 需求

    • ①使用集群模式操作redis

      redis-cli -c -p 端口
      
    • ②关闭redis-6379, 查看主从切换情况

  • ①使用集群操作redis

    • tgy3qayw5g34aghqa
  • ②关闭redis-6379, 查看主从切换情况

    • 注意: cluster集群内置哨兵模式.

04-cluster集群节点操作之添加master

  • 语法

    #new-master-host:new-master-port: 新主机的ip和port
    #cluster-host:cluster-port: 已经在集群中的设备的ip和port
    redis-cli --cluster add-node new-master-host:new-master-port cluster-host:cluster-port
    
  • 需求

    • 新建6382的节点, 并将其添加到redis集群中
  • 开发步骤

    • ①新建6382节点并启动
    • ②将其添加到redis集群中
  • ①新建6382节点并启动

    • tg3qwayg7w4352ay52gwq37
  • ②将其添加到redis集群中

    redis-cli --cluster add-node 192.168.199.110:6382 192.168.199.110:6379
    
    • tgw3q4yg435wg5w24372yq

05-cluster集群节点操作之添加slave

  • 语法

    #new-slave-host:new-slave-port: 新从机的ip和port
    #master-host:master-port: 主机的ip和port
    #masterid: 主机的id
    
    redis-cli --cluster add-node new-slave-host:new-slave-port master-host:master-port --cluster-slave --cluster master-id masterid
    
  • 需求

    • cluster集群添加slave-26382
  • 开发步骤

    • ①新建26382节点并启动
    • ②将其添加到redis集群中
  • ①新建26382节点并启动

    • t3qgawfyg3w45q2ar
  • ②将其添加到redis集群中

    redis-cli --cluster add-node 192.168.199.110:26382 192.168.199.110:6382 --cluster-slave --cluster-master-id 7815c2d8a6255391d3d38a7cdfd689ec5f7ad927
    
  • 5r215tqeh5u7hbe

  • tg3qawygh2w435

06-cluster集群节点操作之移除节点

  • 语法

    #del-node del-cluster-host:del-cluster-port: 需要删除的节点的ip和port
    #del-cluster-id: 需要删除的节点的id
    redis-cli --cluster del-node del-cluster-host:del-cluster-port del-cluster-id
    
  • 需求

    • cluster集群移除master-6382、slave-26382
  • 代码实现

    redis-cli --cluster del-node 192.168.216.110:6382 c876a9869fdcb8a91decb109d73cf56df6277369
    
    redis-cli --cluster del-node 192.168.216.110:26382 0a84ac5ddb836fe56444f9a85726314d435d226a
    
  • 注意事项

    • 只能删除空节点(①没有slots, ②没有从机)

07-cluster集群分槽

  • 概述

    • redis集群中有16384个槽, 用于存储数据.
  • 语法

    #--cluster reshard target-master-host:target-master-port: 目标主机的ip和port
    #--cluster-from src-master-id1 ... src-master-idn: 源头主机的id
    #--cluster-to target-master-id: 目标主机的id
    #--cluster-slots slots: 槽的数量
    redis-cli 
    --cluster reshard target-master-host:target-master-port 
    --cluster-from src-master-id1 ... src-master-idn 
    --cluster-to target-master-id 
    --cluster-slots slots
    
  • 需求

    • 6379, 6380,6381, 6382四个主机均分16384个slots, 每一个主机分得4096
  • 代码实现

    redis-cli --cluster reshard 192.168.199.110:6382 --cluster-from 4cdc5c3348744f68887c4e12e62965727b9ae373 b4cfa66305c8e8edce500425b667873344aa89a8 b3ca1b27d891d42bf7abda2e66a5f2f441a2f444 --cluster-to 7815c2d8a6255391d3d38a7cdfd689ec5f7ad927 --cluster-slots 4096
    
  • 补充

    • 如果要删除主机, 需要先将槽分配给其他主机, 再删除对应的从机.

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

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

相关文章

Nginx学习笔记 - 新

跟着 https://www.bilibili.com/video/BV1yS4y1N76R 视频学的 安装教程 nginx环境搭建 通过不同域名相同端口访问不同页面 首先添加hosts,映射下域名到装nginx的主机IP地址,我这里是虚拟机,且没有买域名就自己本地这样玩 进入nginx安装目…

【C语言学习3——基本的C语言语法知识1】

C语言学习3——基本的C语言语法知识主函数什么是主函数&#xff1f;写一个自己的函数主函数是整个C语言程序的入口要调用函数&#xff0c;必须先知道函数什么是变量&#xff1f;#include <stdio.h> int main() { printf("Hello World\n"); return 0; }相信你已…

科研人的R速成利器,读这两本就够了!

R 是数据科学领域的一门大热的编程语言&#xff0c;可以说它是专门为统计分析而生的。 相比起其他语言&#xff0c;R 简单易学&#xff0c;代码可读性强&#xff0c;并且不需要搭建复杂的编程环境&#xff0c;对初学者非常友好。 今天就和大家分享两本学习R的宝藏图书&#x…

【FPGA实验4】举重比赛机制

举重比赛有三名裁判&#xff0c;当运动员将杠铃举起后&#xff0c;须有两名或两名以上裁判认可&#xff0c;方可判定试举成功&#xff0c;若用A、B、C分别代表三名裁判的意见输入&#xff0c;同意为1&#xff0c;否定为0;F为裁判结果输出&#xff0c;试举成功时F1&#xff0c;试…

02-神经网络基础

一、从机器学习到神经网络 1. 两层神经网络 - 多层感知机 2. 浅层神经网络特点 (1)需要数据量小、训练速度快; (2)对复杂函数的表示能力有限,泛化能力受到制约。 Kurt Hornik 证明了理论上两层神经网络足以拟合任意函数,而且过去没有足够的数据和计算能力,因此之前的…

计算机组成原理实验1---运算器 预习报告

本实验为哈尔滨工业大学计算机组成原理实验&#xff0c;实验内容均为个人完成&#xff0c;目的是分享交流&#xff0c;如有抄袭将追究责任&#xff0c;笔者能力有限&#xff0c;若因此影响读者的分数&#xff0c;本人深表抱歉。 一、 实验目的 了解运算器的组成结构基于数据通…

ChatGPT 究竟在做什么?它为何能做到这些?(2)

机器学习和神经网络的训练 到目前为止&#xff0c;我们一直在讨论那些 “已经知道” 如何完成特定任务的神经网络。但是&#xff0c;神经网络之所以如此有用&#xff08;估计也是在大脑中&#xff09;&#xff0c;是因为它们不仅是可以完成各种任务&#xff0c;而且可以逐步 “…

数据 数据元素 数据项 数据对象

文章目录数据、数据元素、数据项和数据对象数据数据元素数据对象数据元素和数据对象数据结构数据结构包括以下三个方面的内容逻辑结构物理结构&#xff08;存储结构&#xff09;逻辑结构与存储结构的关系逻辑结构的种类集合结构线性结构树型结构图状结构或网状结构四种基本的存…

【人工智能】模糊推理

模糊推理:以下内容都是我自学理解的&#xff0c;不保证对引言&#xff1a;“生活中的模糊关系”模糊集合模糊集合的定义模糊集合的表示法模糊集合表示法示例隶属函数模糊规则模糊计算的流程引言&#xff1a;“生活中的模糊关系” 如果说&#xff0c;我们简单的将 温度<10度 …

如何构建敏捷项目管理团队?

敏捷专家认为&#xff1a;团队合作对于交付出色软件来说非常关键&#xff0c;而在优秀的敏捷团队普遍都是站在集体的角度去思考和工作&#xff0c;而不是以个体的形式。对每个成员来说更有价值的是——优秀的成员都会站在团队的角度将自己宝贵的开发经验分享出来&#xff0c;来…

mysql(beetlsql框架)适配人大金仓(KingBase)有感

毁灭吧&#xff0c;前几天加班适配kingbase&#xff0c;发现坑是真滴多&#xff0c;小小总结一波。 tips:kingbase的语法可以直接参照pgsql...他们两个是通用的&#xff08;应该&#xff09; 1. 的坑 在Mysql里面的 (不是单引号&#xff01; 和 还是有点区别的) 这是拿来…

机械臂路径规划path planning

一、路径规划&#xff1a;假设机械臂的终端结构要从一个点运动到另一个点&#xff0c;我们要求所有的关节和终端机构在运动的过程中都不能碰到障碍物&#xff0c;这个称为路径规划。 1、路径规划算法主要可分成两种&#xff1a; &#xff08;1&#xff09;一种是基于搜索结果…

第十三天缓存一致性篇

目录 一、缓存的应用场景 二、缓存数据一致性如何保证&#xff1f; 三、缓存的最终一致性解决方案&#xff1a; 一、缓存的应用场景 1、缓存中的数据不应该是实时性一致性要求超高的&#xff0c; 通过缓存加上过期时间保证每天拿到的数据都是最新的即可。 2、如果实时性要求…

tcp通信,客户端服务端

进行过程 //TCP通信的流程 //服务器端&#xff08;被动接受连接的角色&#xff09; 1.创建一个用于监听的套接字 -监听&#xff1a;监听有客户端的连接 -套接字&#xff1a;这个套接字其实就是一个文件描述符 2.将这个监听文件描述符和本地的IP和端口绑定&#xff08;IP和端口…

飞凌嵌入式AM62x核心板,赋能新一代HMI

HMI&#xff08;人机界面&#xff09;是系统和用户之间进行交互和信息交换的媒介&#xff0c;凡是涉及人机信息交流的领域都离不开人机界面&#xff0c;因此在许多行业内都能见到HMI的身影。随着技术的进步HMI也在持续发展和演进&#xff0c;除了数据收集、控制和显示外&#x…

在采购过程中保持供应商诚实的5种方法

不信任潜在供应商的心理在B2B买家中很常见。据报告称&#xff0c;供应商和买家之间存在着信任差距。这不是针对个人&#xff0c;而是健康的怀疑态度。谁不会对他们企业的潜在六七位数技术投资持怀疑态度&#xff1f; 企业和其供应商之间的关系通常是决定成败的关键。为此&…

SQL 条件函数 日期函数 文本函数 窗口函数

玩了几天&#xff0c;劳逸结合&#xff0c;继续复习刷题sql 一、条件函数 1.题目&#xff1a;现在运营想要将用户划分为25岁以下和25岁及以上两个年龄段&#xff0c;分别查看这两个年龄段用户数量&#xff08;age为null 也记为 25岁以下&#xff09; user_profile 期望结果&…

【论文阅读】MAMIL

1、基本信息 misc{Konstantinov_Utkin, title{Multi-Attention Multiple Instance Learning}, author{Konstantinov, AndreiV. and Utkin, LevV.} }2、摘要 本文提出了基于多注意力的MIL问题求解方法&#xff0c;该方法考虑了包中每个被分析实例的相邻实例。在该方法中&…

如何还原min.js文件

最近在看别人给的一个代码包&#xff0c;但是有一些文件是 xx.min.js ,这种文件在vscode中打开后是这样的 这种怎么阅读&#xff0c;太难了&#xff0c;于是全选&#xff0c;右键格式化文档&#xff0c;不管用 通过咨询群友&#xff0c;学到了&#xff1a; 回答一&#xff1…

vscode开发常用的工具栏选项,查看源码技巧以及【vscode常用的快捷键】

一、开发常用的工具栏选项 1、当前打开的文件快速在左侧资源树中定位&#xff1a; 其实打开了当前的文件已经有在左侧资源树木定位了&#xff0c;只是颜色比较浅 2、打开太多文件的时候&#xff0c;可以关闭 3、设置查看当前类或文件的结构 OUTLINE 相当于idea 查看当前类或接…