redis-cluster集群搭建演示

安装部署任何一个应用其实都很简单,只要安装步骤一步一步来就行了。下面说一下 Redis 集群搭建规划,由于集群至少需要6个节点(3主3从模式),所以,没有这么多机器给我玩,我本地也起不了那么多虚拟机(电脑太烂),现在计划是在一台机器上模拟一个集群,当然,这和生产环境的集群搭  建没本质区别。

1. 安装redis

太简单了,参考https://blog.csdn.net/weixin_42214548/article/details/102888249 这篇文章,就不介绍了

2. 创建文件夹

我们计划集群中 Redis 节点的端口号为 9001-9006 ,端口号即集群下各实例文件夹。数据存放在 端口号/data 文件夹

mkdir /usr/local/redis-cluster

cd redis-cluster/

mkdir -p 9001/data 9002/data 9003/data 9004/data 9005/data 9006/data

3. 复制脚本

在 /usr/local/redis-cluster 下创建 bin 文件夹,用来存放集群运行脚本,并把安装好的 Redis 的 src 路径下的运行脚本拷贝过来。看命令: 

cd /usr/local/redis-cluster

mkdir bin

 

Cd /usr/local/redis-3.2.9/src

 

 cp mkreleasehdr.sh redis-benchmark redis-check-aof  redis-cli redis-server redis-trib.rb /usr/local/redis-cluster/bin

 

4. 复制一个新 Redis 实例

我们现在从已安装好的 Redis 中复制一个新的实例到 9001 文件夹,并修改 redis.conf 配置。

cp -r /usr/local/redis    /usr/local/redis-cluster/9001

 

注意,修改 redis.conf 配置和单点唯一区别是下面部分,其余还是常规的这几项:

 

port 9001(每个节点的端口号)

daemonize yes

bind 170.21.1.10(绑定当前机器 IP)

dir /usr/local/redis-cluster/9001/data/(数据文件存放位置)

pidfile /var/run/redis_9001.pid(pid 9001和port要对应)

cluster-enabled yes(启动集群模式)

cluster-config-file nodes9001.conf(9001和port要对应)

cluster-node-timeout 10000

appendonly yes 开启AOF持久化

5. 再复制出五个新 Redis 实例

我们已经完成了一个节点了,其实接下来就是机械化的再完成另外五个节点,其实可以这么做:把 9001 实例 复制到另外五个文件夹中,唯一要修改的就是 redis.conf 中的所有和端口的相关的信息即可,其实就那么四个位置。开始操作,看图:

\cp -rf /usr/local/redis-cluster/9001/*   /usr/local/redis-cluster/9002

\cp -rf /usr/local/redis-cluster/9001/*   /usr/local/redis-cluster/9003

\cp -rf /usr/local/redis-cluster/9001/*   /usr/local/redis-cluster/9004

\cp -rf /usr/local/redis-cluster/9001/*   /usr/local/redis-cluster/9005

\cp -rf /usr/local/redis-cluster/9001/*   /usr/local/redis-cluster/9006

\cp -rf 命令是不使用别名来复制,因为 cp 其实是别名 cp -i,操作时会有交互式确认,比较烦人。

6. 修改 9002-9006 的 redis.conf 文件

其实非常简单了,你通过搜索会发现其实只有四个点需要修改,我们全局替换下吧,进入相应的节点文件夹,做替换就好了。命令非常简单,看图:

 

vi /usr/local/redis-cluster/9002/redis/etc/redis.conf

 

vi /usr/local/redis-cluster/9003/redis/etc/redis.conf

vi /usr/local/redis-cluster/9004/redis/etc/redis.conf

vi /usr/local/redis-cluster/9005/redis/etc/redis.conf

vi /usr/local/redis-cluster/9006/redis/etc/redis.conf

 

%s/9001/9002

%s/9001/9003

%s/9001/9004

%s/9001/9005

%s/9001/9006

 

 

其实我们也就是替换了下面这四行:

 

 

port 9002

dir /usr/local/redis-cluster/9002/data/

cluster-config-file nodes-9002.conf

pidfile /var/run/redis_9002.pid

 

 

 

7. 启动9001-9006六个节点

/usr/local/redis/bin/redis-server  /usr/local/redis-cluster/9001/redis/etc/redis.conf

/usr/local/redis/bin/redis-server  /usr/local/redis-cluster/9002/redis/etc/redis.conf

/usr/local/redis/bin/redis-server  /usr/local/redis-cluster/9003/redis/etc/redis.conf

/usr/local/redis/bin/redis-server  /usr/local/redis-cluster/9004/redis/etc/redis.conf

/usr/local/redis/bin/redis-server  /usr/local/redis-cluster/9005/redis/etc/redis.conf

/usr/local/redis/bin/redis-server  /usr/local/redis-cluster/9006/redis/etc/redis.conf

 

8. 测试一下随便一个节点的服务

usr/local/redis-cluster/9001/redis/bin/redis-cli -h 170.21.1.10 -p 9001

出现下面的错误

(error) CLUSTERDOWN Hash slot not served

这是因为虽然我们配置并启动了 Redis 集群服务,但是他们暂时还并不在一个集群中,互相直接发现不了,而且还没有可存储的位置,就是所谓的slot(槽)。

9. 安装集群所需软件

由于 Redis 集群需要使用 ruby 命令,所以我们需要安装 ruby 和相关接口。

 

yum install ruby

yum install rubygems

gem install redis  使用本地上传方式

 

 

注意: gem install redis 打入这个命令后如果出现了卡停,说明你无法下载该文件,需要使用手动上传的方式.

下载地址: https://pan.baidu.com/s/10ciFz7ak5yZJOezCmKu4Gw 提取码:2lrr 

下载完了之后上传到服务器上,然后执行 gem install -l redis-3.2.1.gem

执行完后出现下图即说明完成了

10. 集群环境测试

/usr/local/redis-cluster/bin/redis-trib.rb create --replicas 1 172.21.0.10:9001 172.21.0.10:9002 172.21.0.10:9003 172.21.0.10:9004 172.21.0.10:9005 172.21.0.10:9006

简单解释一下这个命令:调用 ruby 命令来进行创建集群,--replicas 1 表示主从复制比例为 1:1,即一个主节点对应一个从节点;然后,默认给我们分配好了每个主节点和对应从节点服务,以及 solt 的大小,因为在 Redis 集群中有且仅有 16383 个 solt ,默认情况会给我们平均分配,当然你可以指定,后续的增减节点也可以重新分配。

并向你确认是否同意这么配置。输入 yes 后,会开始集群创建。

11. 验证集群环境

依然是通过客户端命令连接上,通过集群命令看一下状态和节点信息等。

/usr/local/redis-cluster/9001/redis/bin/redis-cli -c -h 172.21.0.10 -p 9001

输入info命令,得到信息9001节点为主,9006节点为从

 

 

到此搭建redis分片集群成功了

发布了60 篇原创文章 · 获赞 5 · 访问量 1万+

猜你喜欢

转载自blog.csdn.net/weixin_42214548/article/details/102944432