redis高可用集群搭建

news/2024/11/13 3:31:19/

redis高可用集群搭建

  • redis的安装
  • 配置允许远程访问
  • 重启服务
  • 检查服务是否启动
  • 架构图
  • 开始搭建集群
  • 安装ruby
  • 创建集群
  • 高可用测试
  • redis集群的扩展
  • 将7号机添加为新的master节点
  • 添加从节点
  • 删掉一个slave节点
  • 删除master节点

redis的安装

sudo apt-get install redis-server

配置允许远程访问

sudo gedit /etc/redis/redis.conf

注释掉**#bind 127.0.0.1**行

重启服务

sudo redis-server /etc/redis/redis.conf

检查服务是否启动

ps -ef | grep redis

架构图

在这里插入图片描述

开始搭建集群

要想搭建高可用的redis集群,至少需要三台主库,每个主库需要一台从库。每个主库的数据是不同的,每个从库的数据跟主库同步,redis会将需要存放的数据放到某一个主库中。我们开八台虚拟机,使用前六台搭建一个高可用的redis集群,服务器分配如下:
在这里插入图片描述
分别进入1-6号主机,建立redis的集群目录,要有权限,以服务端口为文件夹名,在下面把redis的配置文件拷贝一份:

mkdir -p /home/wang/redis-cluster/7001
sudo cp /etc/redis/redis.conf /home/wang/redis-cluster/7001/redis-7001.conf
chmod 777 redis-7001.conf

其余5台服务器操作类似,只需要改服务端口。
修改redis-7001.conf的内容,注意以下配置:

port 7001
cluster-enabled yes
cluster-config-file nodes.conf
cluster-node-timeout 5000
appendonly yes

其余五台服务器只需要变更端口号。
改好后,要以全新的配置文件来启动redis:

sudo redis-server /home/wang/redis-cluster/7001/redis.conf
ps -ef|grep redis

如果发现默认的6379的redis还开着,就把它关掉:

sudo /etc/init.d/redis-server stop

此时redis的进程应该是这样的:
在这里插入图片描述
确认六台redis都按照指定的配置和端口启动后,就可以创建集群了。

安装ruby

sudo apt-get install ruby
sudo apt-get install rubygems
sudo gem install redis

创建集群

找到创建集群的脚本文件redis-trib.rb,把它拷贝到bin目录下:

cp redis-trib.rb /usr/local/bin/redis-trib

随便找一台服务器,执行一次集群的创建命令:

sudo redis-trib create --replicas 1 192.168.252.128:7001 192.168.252.130:7002 192.168.252.131:7003 192.168.252.132:7004 192.168.252.134:7005 192.168.252.135:7006 

看到如下提示:
在这里插入图片描述
确认主从没问题,输入yes,即可创建成功。
我们输入以下命令确认集群的状态:

redis-trib check 192.168.252.130:7002

可以看到集群的信息:
在这里插入图片描述
通过以下命令也能查看集群状态:

redis-cli -p 7111 cluster nodes

在这里插入图片描述

高可用测试

进入192.168.252.128:7001,杀掉redis的进程,过几秒,看看集群的状态,发现7001的主节点已经挂掉,对应的从节点7004已经变为主节点:
在这里插入图片描述
下面恢复192.168.252.128:7001

sudo redis-server /home/wang/redis-cluster/7001/redis.conf
redis-cli -c -p 7001
cluster nodes

在这里插入图片描述
发现挂掉的7001节点已经变为7004的从节点。这说明,在master节点下线后,slave节点会自动提升为master节点,保存集群持续提供服务;fail节点恢复后,会自动添加到集群中,变成slave节点。

redis集群的扩展

为了演示redis集群的扩展,我们使用7和8两台服务器扩展现有的6台集群。
进入7号和八号服务器,按照前面的方式,分别安装redis,创建集群的目录和配置文件并启动。

将7号机添加为新的master节点

使用redis-trib脚本的add-node命令将一个节点添加到集群里面,第一个是新节点 ip:port,第二个是任意一个已存在节点 ip:port。

cp redis-trib.rb /usr/local/bin/redis-trib
redis-trib add-node 192.168.252.150:7007 192.168.252.128:7001

在这里插入图片描述
以上操作结果表示节点添加成功,新增的节点不包含任何数据, 因为它没有分配任何 slot。
为新节点分配哈希槽(slot):你只需要指定集群中其中一个节点的地址,redis-trib 就会自动找到集群中的其他节点。目前redis-trib只能在管理员的协助下完成重新分片的工作,命令如下:

redis-trib reshard 192.168.252.150:7007

在这里插入图片描述
它会问你想分配多少个槽位过来,填个500吧。他又问你要分配主机(7号服务器)的ID,我的是e131a6564a1e935da2ceab59813c5ccb5dfd9c11。他又问你从哪些服务器取槽位过来,就填all表示所有。输入yes确认即可。
可以通过下图看到集群的状态,可以看到7号机的槽位分配成功。
在这里插入图片描述
以上集群状态输出信息解析:

  1. 节点 ID
  2. IP:PORT
  3. 节点状态标识: master、slave、myself、fail?、fail
  4. 如果是从节点,表示主节点的ID;
  5. 如果是主节点,则为 ‘-’ 集群最近一次向各个节点发送 PING 命令后,过去多长时间还没有接到回复
  6. 节点最近一次返回 PONG 的时间戳
  7. 节点的配置纪元
  8. 本节点的网络连接情况: connected、disconnected
  9. 如果是主节点,表示节点包含的槽

添加从节点

进入八号服务器192.168.252.133,输入:

redis-trib add-node 192.168.252.133:7008 192.168.252.128:7001

在这里插入图片描述
这时新增的服务器还是master,我们将其转为slave,命令后跟7号服务器的id:

redis-cli -c -p 7008
cluster replicate ab31611b3424990e2b9bbe73135cb4cb0ace394f

这时就变为slave了:

cluster nodes

在这里插入图片描述

删掉一个slave节点

redis-trib del-node 192.168.252.133:7008 5256e05a17c106c93285a03aff1b1b9e7ca7bf0c

在这里插入图片描述
再看节点状态,发现八号机已被删除:
在这里插入图片描述

删除master节点

先移走master节点的槽位,再移除服务器:

redis-trib reshard 192.168.252.150:7007

要删除槽位的数量,填499,接收槽位的 master 节点 ID,填4号服务器ID,删除槽位的master节点ID,填7号的ID.最后输入done。
在这里插入图片描述

redis-cli -c -p 7006 cluster nodes

这时发现7号服务器的槽位已被移除,可以开始删了。
在这里插入图片描述

redis-trib del-node 192.168.252.150:7007 ab31611b3424990e2b9bbe73135cb4cb0ace394f

这时7号节点也被关闭:
在这里插入图片描述


http://www.ppmy.cn/news/506129.html

相关文章

安卓禁止录屏和截屏

我们在看一些精彩图片或直播的时候,有时候想要截个屏或者录屏,但是会提示无法抓取屏幕截图,录像也是黑的,那是怎么做到的呢,其实很简单一行代码: getWindow().addFlags(WindowManager.LayoutParams.FLAG_S…

使用adb命令对手机屏幕截图

使用adb命令对手机屏幕截图 使用 screencap 命令,截图保存在 sdcard/01.png adb shell screencap -p /sdcard/01.png 导出 sdcard/01.png 图片 adb pull /sdcard/01.png

Git安装详细教程(win11)

Git安装详细教程(win11) 一、下载二、安装三、配置 一、下载 官网下载:点击下载 网盘下载:点击下载 二、安装 双击程序运行,点击next 选择安装路径,我安装在了D盘,如下图所示,…

ffmpeg 屏幕抓取

1、在Windows系统使用libavdevice抓取屏幕数据有两种方法:gdigrab和dshow。 (1)、使用dshow进行屏幕抓取首先要安装:screen capture recorder,下载地址:https://sourceforge.net/projects/screencapturer/…

c++ 抓取桌面屏幕并转为jpg图片

抓取屏幕代码 char* getScreen(unsigned long &jpg_size){ HWND DeskWnd::GetDesktopWindow();//获取桌面窗口句柄RECT DeskRC;::GetClientRect(DeskWnd,&DeskRC);//获取窗口大小HDC DeskDCGetDC(DeskWnd);//获取窗口DCHBITMAP DeskBmp::CreateCompatibleBitmap(DeskD…

利用Windows自带gdi32.dll实现抓取屏幕

internal static void GetScreenShot( ) { //获得当前屏幕的大小 Rectangle rect new Rectangle(); rect Screen.AllScreens[0].WorkingArea; //计算图片的大小,因为图片的长和宽有可能超过目前屏幕的大小 //创建一个以当前屏幕为模板的图象 Control ctl new …

android实时抓取屏幕文字,Android录制屏幕的实现方法

原文:Paul Kinlan 翻译:Agora.io 长久以来,我一直希望能够直接从Android屏幕上进行录制并将其编码为多种格式,以便将录制内容嵌入在任意位置,而不需要安装任何软件。 如今,我们已经接近这个目标。Chrome团队正在添加一种功能,可以通过getUserMedia从Android设备上共享屏…

java获取屏幕截图

全栈工程师开发手册 (作者:栾鹏) java教程全解 java获取屏幕截图 测试代码 public static void main(String[] args) {//文件与BufferedImage间的转换BufferedImage biigetScreen();img2file(bii,"jpg","test1.jpg"); …