IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> Redis集群 -> 正文阅读

[大数据]Redis集群

前言

我们之前已经讲过了哨兵模式,现在我们来学习一下redis的集群配置。请大家耐心仔细的看,因为学会了知识就是你的了,但是学不会,那还是我的,哈哈~

编写配置文件

我们先将之前创建的主从复制用到的配置文件移动到某个文件夹中,或者新建个文件夹,放到里面也可以

#创建文件夹
mkdir conf
#j移动配置文件
mv redis-6*.conf conf/

目录大致上是这样的,如下:

创建集群至少要6个服务,6个服务分别为:6379、6380、6381、6389、6390、6391,我们以6379这个文件内容举例,6379配置文件的内容如下:

include /myredis/redis.conf
pidfile "/myredis/pid/redis_6379.pid"
port 6379
dbfilename "dump6379.rdb"
#密码(如果你设置了requirepass)
masterauth 123456
# 集群配置
cluster-enabled yes
cluster-config-file nodes-6379.conf
cluster-node-timeout 15000

我们将新建好的6379配置文件复制5份,命令如下:

cp redis6379.conf


我们按照端口号顺序,对6380、6381、6389、6390、6391配置文件的内容进行替换,输入以下命令,然后回车,记得保存!!!如下:
在这里插入图片描述

rdb持久化文件删除,因为我们要用集群模式重新创建,命令如下:

rm -rf dump*.rdb


我们启动这6个服务,命令如下:

redis-server redis6379.conf


我们进入到我们刚开始将redis下载下来的目录中,然后进入到解压后的目录中,如下:

cd /data/redis-6.2.6/src

我们使用命令,创建集群,命令如下:

# IP地址和端口号是我本机,大家要写自己的IP,别写错
# 我的redis设置密码了,-a后面是密码
redis-cli -a 123456 --cluster create --cluster-replicas 1 192.168.133.128:6379 192.168.133.128:6380 192.168.133.128:6381 192.168.133.128:6389 192.168.133.128:6390 192.168.133.128:6391

在这里插入图片描述
注意:16384这个数字,集群中有16384个插槽。

因为redis集群是无中心化配置我们使用客户端进行连接,所以我们连接哪个端口的服务都可以,命令如下:

# -c 的意思就是连接集群
redis-cli -c  -p 6379 -a 123456

登录以后,我们查看节点信息,命令如下:

cluster nodes


集群服务分配原则:
尽量保证每台主库redis、从库redis都在不同服务器上(一台G掉,其他还可以继续使用)

什么是slots?


一个redis集群包含16384个插槽,数据库中的每个键都属于这16384个插槽中的其中一个。
集群使用公示CRC16(key)%16384来计算键 key 属于哪个槽,其中CRC16(key) 语句用于计算key的CRC16校验和。
图中的三个节点分别处理以下范围的插槽:
A服务负责 0号至5460号插槽
B服务负责5461号至10922号插槽
C服务负责10923号至16383号插槽

加入数据,计算插槽值,该值保存在6381的服务中,自动重定向到了6381服务,如下:
在这里插入图片描述
查询a键在集群中的插槽值,命令如下:

cluster keyslot 键

在这里插入图片描述
查询插槽值的个数,命令如下:

cluster countkeysinslot 插槽值

在这里插入图片描述
查询插槽值对应的key,命令如下:

cluster getkeysinslot 插槽值 个数

在这里插入图片描述

故障恢复

我们刚才配置的集群节点超时内容为:

cluster-node-timeout 15000

我们将某台master服务停掉,然后等15秒,再次查看节点信息,如下:
在这里插入图片描述

在这里插入图片描述
等待15秒以后,再次查看集群节点信息,如下:
在这里插入图片描述

6379已经G掉了,新的master就是6391,我们将6379启动,然后再查看节点信息,如下:
在这里插入图片描述
在这里插入图片描述
如果两次启动后的ID一模一样,那么就不需要那么麻烦了,再次查看节点信息时,只是由master变成了slave而已,如下:
在这里插入图片描述

如果我们发现两个ID不一样了,所以我们要在现有的集群中根据ID删掉它,然后把重新启动后的6379添加进去,如下:

# 在集群中去掉该原6379的ID
cluster forget 30e0dab7f599eed53db06250556482c3cbc6174f

图中标记的slave,意思就是该服务是哪个服务的从服务。
在这里插入图片描述
首先我们将6379服务的dump和nodes配置文件删除,如下:

rm -rf /myredis/dump6379.rdb
rm -rf /myredis/nodes-6379.conf

启动6379服务,命令如下:

redis-server /myredis/redis6379.conf 

我们将刚启动的6379设置为6391的从服务,命令如下:

# ID为集群中某个master节点的ID
redis-cli -a 123456 --cluster add-node --cluster-slave --cluster-master-id 2b0819484c0a25af1d0626f2a7df933c36f4c3ed 192.168.133.128:6379 192.168.133.128:6391


感谢小伙伴们观看!

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2022-03-04 15:39:43  更:2022-03-04 15:43:29 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 9:48:13-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码