redis高可用集群数据库的安装部署(6.2.12版本)

news/2024/9/22 14:31:21/

第三阶段基础

时  间:2023年7月3日

参加人:全班人员

内  容:

6.2.12版本redis集群部署

目录

一、环境配置:【两台服务器】

二、redis多实例配置:

三、构建redis cluster集群

四、创建主从

五、故障转移实验

六、拓  展


安装部署:(一台主机,三主三从,redis版本为6.2.12)

实验基本条件:

服务器huyang2

主 库

Node1

Node2

Node3

8001

8002

8003

192.168.59.138

从 库

Node4

Node5

Node6

8004

8005

8006

一、环境配置:【两台服务器】

 1、关闭防火墙

systemctl stop firewalld

iptables -F

setenforce 0

2.安装相关基础环境

 yum -y install wget gcc gcc-c++ make tar openssl

openssl-devel cmake

3.上传相关软件安装包

rz  redis-6.2.12.tar.gz  

4.解压安装包并调整位置

mkdir /usr/local/redis

tar xf redis-6.2.12.tar.gz -C /usr/local/redis

5、编译、配置、安装

cd /usr/local/redis

make  && make install

6、验证redis的安装

./src/redis-server redis.conf

7、优化redis程序命令

mkdir -p /usr/local/redis_cluster

cd /usr/local/redis_cluster

mkdir -p 8001/data 8002/data 8003/data

8004/data 8005/data 8006/data

mkdir bin

cd /usr/local/redis/redis-6.2.12/src

cp mkreleasehdr.sh redis-benchmark redis-check-aof

redis-cli redis-server redis-trib.rb /usr/local/redis_cluster/bin

 ln -s  /usr/local/redis_cluster/bin*

/usr/local/bin/

8.系统调优配置

echo never >

/sys/kernel/mm/transparent_hugepage/enabled

echo never >

/sys/kernel/mm/transparent_hugepage/defrag

echo 'echo never >

/sys/kernel/mm/transparent_hugepage/enabled' >>

/etc/rc.local

echo 'echo never >

/sys/kernel/mm/transparent_hugepage/defrag' >>

/etc/rc.local

echo "* - nofile 10240" >> /etc/security/limits.conf        --文件并发数

echo "net.core.somaxconn = 10240" >> /etc/sysctl.conf    --监听队列

echo "vm.overcommit_memory = 1" >> /etc/sysctl.conf    -- 0内存不够,就会拒绝申请

1物理内存都允许分配给你,只要有内存就给你用,这样可以避免申请内存失败的问题。

sysctl -p

二、redis多实例配置:

主库配置

步骤一:复制配置文件并修改

cp   /usr/local/redis/redis-6.2.12/redis.conf

/usr/local/redis_cluster/8001

cp redis.conf{,.bak}

egrep -v "^$|^#" redis.conf.bak > conf/redis.conf

步骤二:修改配置文件

vim 8001/redis.conf

修改配置如下:

cluster-enabled yes

bind 0.0.0.0

port 8001

pidfile /data/redis-cluster/8001/redis.pid

logfile "/data/redis-cluster/8001/redis.log"

dir /data/redis-cluster/8001/

tcp-backlog 1024

daemonize yes

同理,将8002和8003配置文件修改,与上述端口不一,其他一致

步骤三:启动服务

redis-server 8001/redis.conf

redis-server 8002/redis.conf

redis-server 8003/redis.conf

netstat -antup | grep redis-server

从库配置:

步骤一:复制配置文件并修改

cp   /usr/local/redis/redis-6.2.12/redis.conf

/usr/local/redis_cluster/8004

cp redis.conf{,.bak}

egrep -v "^$|^#" redis.conf.bak > conf/redis.conf

步骤二:修改配置文件

vim 8004/redis.conf

修改配置如下:

cluster-enabled yes

bind 0.0.0.0

port 8004

pidfile /data/redis-cluster/8004/redis.pid

logfile "/data/redis-cluster/8004/redis.log"

dir /data/redis-cluster/8004/

tcp-backlog 1024

daemonize yes

同理,将8005和8006配置文件修改,与上述端口不一,其他一致

步骤三:启动服务

redis-server 8004/redis.conf

redis-server 8005/redis.conf

redis-server 8006/redis.conf

netstat -antup | grep redis-server

三、构建redis cluster集群

步骤一:创建集群节点

redis-cli -p 8001 -c  (以集群模式登录任意节点)

cluster  meet    ip+端口 

(把其他实例全部添加到集群中,登录进集群内操作)

cluster nodes 查看集群节点信息

步骤二:分配槽(退出集群操作)

redis-cli  -p 8001 cluster addslots   {0..5000}        

redis-cli  -p 8002 cluster addslots {5001..10000}

redis-cli  -p 8003 cluster addslots {10001..16383}

cluster nodes 查看集群节点信息,都有了槽

步骤三:验证加入集群和未加入集群的区别

创建数据:

redis-cli -p 8001 -c 登录集群

set name huyang1

查看数据:

可以发现,加入到集群之中的节点和创建数据本省的节点可以查看数据之外,其余未加入集群的节点不可以查看数据,由此可见集群的特性。

四、创建主从

步骤一:添加从库节点进入集群

redis-cli -p 8001 -c

cluster  meet    192.168.59.138 8004

cluster  meet    192.168.59.138 8005

cluster  meet    192.168.59.138 8006

都为主库

步骤二:退出集群,命令行操作

redis-cli  -p 端口 cluster replicate id号

例:redis-cli  -p 8004 cluster replicate

cbcc0afc179ffe4b1626b26b2ceb9ecab9c29e96

登录集群,查看信息

redis-cli  -p 8004 -c

cluster nodes

同理,将8005,8006添加为8002,8003的从库

五、故障转移实验

实验一:模拟主库8001宕机,查看变化

登录集群,查看信息

故障转移,如下:

实验二:使用不同ip地址的不同端口接入集群

观察变化

变化:

实验三:使用集群中的两条主库,进入新的集群

特性,

两个主库居然合在一起共用一个数据库!!!!

六、拓  展

(一)添加节点

集群伸缩-添加节点

redis-cli --cluster add-node  加新节点IP:端口   

原任意节点IP/:端口

例:

redis-cli --cluster add-node 192.168.59.137:7005  192.168.59.137:7002

可以发现,以上述方法添加的节点都为主库

(二)删除节点

redis-cli --cluster del-node IP:端口号  id号

例:

redis-cli --cluster del-node 192.1 68.59.137:7005 9c73cbfbbc09b214f6136d6a337d052911290914


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

相关文章

把图片中的表格数据转换为excel版本

需要引用网络上一些数据时发现只有pdf版本的文档,直接对着文档把数据敲到表格里太慢了,人工成本有点高。网络上的大部分方法需要使用Python或者下载专门的软件,Python小白(透明)实在不想敲代码,电脑内存也不…

如何将图片转化为表格?分享一个转换的方法

在日常学习或工作的时候,小伙伴们有遇到过需要将数据图片转为excel的情况吗?大家都会怎么操作呢?是根据图片的数据,手动编辑一份excel表格吗?这样子的操作虽然是可以实现图片转excel的操作,但是有点费时费力…

图片转excel方法

最近工作中遇到一个问题,把图片转成excel,原文件不在我这儿,我只有一个word里的截图,非常大的表格有好几个,到处找人要原文件,都没有。于是我怒而查找图片转excel的方法,当然如果不嫌麻烦的可以…

怎么把图片里的表格转成电子版表格?说一个渠道

我们在日常学习办公时,经常遇到需要提取手头上或者同事发来图片中的表格的情况,手动录入费时费力。其实不用这么麻烦,现在市面上已经有很多识别软件可以快速帮助我们做到表格转换,下面就给大家推荐两种,一起来看看吧~ …

图片怎么转换成excel文档?

当我们创建excel文档中,里面无疑是需要各种表格内容,而如果是我们一个一个编辑起来,这就会比较繁琐。而现在许多需求可以通过网络很容易地得到满足。比如有把图片转换成excel表格的需求。下载一个小工具,这就相当方便了&#xff0…

如何将图片中的表格变成Excel?这几个操作很简单

你们还在为转换图片表格而烦恼吗?其实我们只需借用一些工具就可以轻松解决这个问题。如果你们想知道图片表格转excel怎么转的话,就继续往下看看这篇文章吧!今天我来分享两种实用的图片转表格的方法给你们,能帮你们快速提高工作效率…

Rust 第四天—Rust进阶1

上一篇介绍了Rust的所有权特性,今天就把剩下一些之前没介绍但项目中常用的内容总结一下. 结构体泛型trait 1 结构体 和c语言一样,Rust使用struct关键字来定义一个结构体,结构体可以将不同的类型数据进行整合,加快内存访问速度. 1.1 结构体定义 struct Test{username:Strin…

将长表格图片转Excel表格

大家好,我是小小明。 最近很多朋友和同事问我如何将图片转Excel表格,老实说这方面现成的工具基本都不好使,不过百度AI有支持进行表格图片识别的接口,我们只要按照百度AI的要求传入相应的数据进行识别即可。 需求与技术点 需求,有两张超长的表格图片: 现在希望将其识别…