构建redis集群

一 . 条件准备

## 创建redis用户用户组
groupadd redis;
useradd -d /home/redis -g redis -m redis

## 安装gcc-c++
yum install gcc-c++

二 redis 集群搭建(以redis用户操作)

本案例以redis 4.x版本和5.x版本为例(一台服务器上搭建集群案例)

1)目录规划

## 数据文件目录
mkdir -p /home/redis/cluster/{7001,7002,7003,7004,7005,7006}/data
## 日志文件目录
mkdir -p /home/redis/cluster/{7001,7002,7003,7004,7005,7006}/data

## /home/redis/bin redis 脚本目录

 

2)安装redis集群步骤(手动创建集群)

  • 安装redis集群
## 解压安装redis到指定目录
tar -xvzf  redis-4.0.1.tar.gz -C /home/redis/
## 创建软链接
ln -sv redis-4.0.1 redis
cd /home/redis/redis
## (默认安装到/usr/local/bin)
make PREFIX=/home/redis/bin install
  • 创建目录
mkdir -p /home/redis/cluster/{7001,7002,7003,7004,7005,7006}/data
mkdir -p /home/redis/cluster/{7001,7002,7003,7004,7005,7006}/log
  • 依次创建各节点配置文件(简单配置如下,仅作参考,实际根据线上实际情况配置)
port 7001
daemonize yes
bind 170.100.104.46
dir /home/redis/cluster/7001/data/
pidfile /home/redis/cluster/7001/redis_7001.pid
cluster-enabled yes
cluster-config-file /home/redis/cluster/7001/nodes7001.conf
cluster-node-timeout 15000
appendonly yes
maxmemory 3GB
maxmemory-policy allkeys-lru
appendfsync no
masterauth passwd1234
requirepass passwd1234
logfile "/home/redis/cluster/7001/log/redis.log"
protected-mode no
  • 启动各个节点
/home/redis/bin/redis-server /home/redis/cluster/7001/redis.conf
/home/redis/bin/redis-server /home/redis/cluster/7002/redis.conf
/home/redis/bin/redis-server /home/redis/cluster/7003/redis.conf
/home/redis/bin/redis-server /home/redis/cluster/7004/redis.conf
/home/redis/bin/redis-server /home/redis/cluster/7005/redis.conf
/home/redis/bin/redis-server /home/redis/cluster/7006/redis.conf

此时执行查看集群节点信息发现,各节点没有建立联系,redis集群搭建需要3步(准备节点,节点握手,分配槽),可以手动执行命令完成redis集群搭建,也可以通过工具命令完成redis集群搭建(redis 4.x版本 可通过redis-trib.rb完成,redis5.x可以通过redis-cli 完成)

  • 节点握手

登录7001节点执行以下命令完成节点握手

## 连接redis
/home/redis/bin/redis-cli -c -a passwd1234 -p 7001
## 节点握手
cluster meet 127.0.0.1 7002
cluster meet 127.0.0.1 7003
cluster meet 127.0.0.1 7004
cluster meet 127.0.0.1 7005
cluster meet 127.0.0.1 7006
  • 创建分区槽

Redis集群把所有的数据映射到16384个槽中。每个key会映射为一个固 定的槽,只有当节点分配了槽,才能响应和这些槽关联的键命令。通过 cluster addslots命令为节点分配槽。这里利用bash特性批量设置槽(slots), 命令如下:

redis-cli -a "passwd1234" -p 7001 cluster addslots {0...5461}
redis-cli -a "passwd1234" -p 7002 cluster addslots {5462..10922}
redis-cli -a "passwd1234" -p 7003 cluster addslots {10923..16383}

把16384个slot平均分配给7001、7002、7003三个节点。执行cluster info 查看集群状态,如下所示:

当前集群状态是OK,集群进入在线状态。所有的槽都已经分配给节 点,执行cluster nodes命令可以看到节点和槽的分配关系

目前还有三个节点没有使用,作为一个完整的集群,每个负责处理槽的 节点应该具有从节点,保证当它出现故障时可以自动进行故障转移。集群模 式下,Reids节点角色分为主节点和从节点。首次启动的节点和被分配槽的 节点都是主节点,从节点负责复制主节点槽信息和相关的数据。使用cluster replicate{nodeId}命令让一个节点成为从节点。其中命令执行必须在对应的 从节点上执行,nodeId是要复制主节点的节点ID,命令如下:

127.0.0.1:7004>cluster replicate cfb28ef1deee4e0fa78da86abe5d24566744411e 
OK
127.0.0.1:7005>cluster replicate 8e41673d59c9568aa9d29fb174ce733345b3e8f1 
OK
127.0.0.1:7006>cluster replicate 40b8d09d44294d2e23c7c768efc8fcd153446746 
OK

3)用redis-trib.rb搭建集群

  • 安装ruby
## 下载ruby
wget https:// cache.ruby-lang.org/pub/ruby/2.3/ruby-2.3.1.tar.gz 
## 安装ruby 
tar -xvzf ruby-2.3.1.tar.gz 
./configure -prefix=/usr/local/ruby 
make&&make install 
cd /usr/local/ruby 
cp bin/ruby /usr/local/bin 
cp bin/gem /usr/local/bin
  • 安装rubygem redis依赖
wget http:// rubygems.org/downloads/redis-3.3.0.gem
gem install -l redis-3.3.0.gem 
gem list --check redis gem
  • 安装 redis-trib.rb
cp /home/redis/src/redis-trib.rb /usr/local/bin
安装完 Ruby 环境后,执行 redis-trib.rb 命令确认环境是否正确,输出如
 

  • 创建集群
redis-trib.rb create --replicas 1 127.0.0.1:7001 127.0.0.1:7002 127.0.0.1:7003 127.0.0.1:7004 127.0.0.1:7005 127.0.0.1:7006

--replicas参数指定集群中每个主节点配备几个从节点,这里设置为1,我们出于测试目的使用本地IP地址127.0.0.1,如果部署节点使用不同的IP地 址,redis-trib.rb会尽可能保证主从节点不分配在同一机器下,因此会重新排 序节点列表顺序。节点列表顺序用于确定主从角色,先主节点之后是从节 点。创建过程中首先会给出主从节点角色分配的计划,如下所示(图为)

  • 检查集群完整性
redis-trib.rb check 127.0.0.1:7001
redis-trib.rb check 127.0.0.1:7002
当最后输出如下信息,提示集群所有的槽都已分配到节点

 

  • 4)5.x版本创建集群方式
redis-cli -a "passwd1234" --cluster create 170.100.104.132:7001 170.100.104.132:7002 170.100.104.132:7003 170.100.104.132:7004 170.100.104.132:7005 170.100.104.132:7006 --cluster-replicas 1
wAAACH5BAEKAAAALAAAAAABAAEAAAICRAEAOw==

 

 

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值