从零搭建RedisCluster集群_SpringBoot连接集群版的redis

先声明:使用伪集群方式搭建 cluster集群, 进行端口号进行区分redis服务器

1、虚拟机安装 (略) 

        这里就不演示了,我这里安装的是 contos7.4   我的虚拟机IP地址:192.168.37.112

2、关闭防火墙

关闭防火墙  systemctl stop firewalld

3、安装redis

cd /usr/local/src 

wget http://download.redis.io/releases/redis-3.2.9.tar.gz

tar -zxvf redis-3.2.9.tar.gz -C /usr/local

cd /usr/local/redis-3.2.9/

make

cd src

make install PREFIX=/usr/local/redis

cd ..

mv redis.conf /usr/local/redis

配置redis为后台启动
vi /usr/local/redis/redis.conf

将daemonize no 改成daemonize yes


 

5、创建集群文件

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

mkdir /usr/local/redis-cluster

cd /usr/local/redis-cluster/

6、复制文件

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

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

7、复制一个新 Redis 实例

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

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

cd /usr/local/redis-cluster/9001/redis

vi redis.conf

如果你的redis服务器集群要配置密码 请参考这位大佬的配置

Redis集群密码设置_奋斗码农的博客-CSDN博客_redis集群设置密码

8、再复制出五个新 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,操作时会有交互式确认,比较烦人。

修改 9002-9006 的 redis.conf 文件    %S 是替换的意思

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

:%s/9001/9002

:wq

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

:%s/9001/9003

:wq

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

:%s/9001/9004

:wq

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

:%s/9001/9005

:wq

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

:%s/9001/9006

:wq

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

port 9002

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

cluster-config-file nodes-9002.conf

pidfile /var/run/redis_9002.pid

启动redis

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

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

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

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

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

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

ps aux | grep 'redis'  使用命令查询下redis是否启动成功

然后随便找一个节点测试试

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

set name 123456   会发现报错。。。。

(error) CLUSTERDOWN Hash slot not served

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

9、安装集群所需软件ruby  多个服务器的haul 可以只在其中一台上面装

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

https://cache.ruby-lang.org/pub/ruby/

 选择版本进行下载,上传到服务器, 解压缩,进入目录执行 

                命令一:./configure --prefix=

                命令二:make && make install

        使用 ruby -v 查看版本,

gem install redis 

然后开启集群

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

集群开启成功,9001-9003为主节点, 9004-9006位从节点  3主3备 

然后 输入 yes 进行确认

10、验证集群环境

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

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

会发现,我们连接的是9001端口,然后执行命令后, 值是存在 9002端口对应的redis上面,然后自动跳转到了9002节点

代表我们集群环境安装成功

我们可以使用  info 命令查看下 节点信息  发现9002标识是主节点,下面有个从节点是 9005

11、SpringBoot连接集群版的redis  修改yml文件

spring:
  redis:
    database: 1
  #  host: 192.168.37.110
  #  port: 6379
  #  password: 123
    jedis:
      pool:
        max-active: 8
        max-wait: -1
        max-idle: 8
        min-idle: 0
    timeout: 10000
    #集群连接   需要把 上面的 host port 注释掉
    cluster:
      nodes:
        - 192.168.37.112:9001
        - 192.168.37.112:9002
        - 192.168.37.112:9003
        - 192.168.37.112:9004
        - 192.168.37.112:9005
        - 192.168.37.112:9006

连接测试我就不展示了  可以参考我博客中的 另外一篇,springboot2.0集成redis  展示yml里面配置有点差别而已

springboot2.0整合redis框架 集成redis事务_jxpxlinkui的博客-CSDN博客

总结一下

这一篇 Redis 集群部署搭建的文章真的是一步一步的走下来的,只要你安装我的步骤来,就保证你能成功搭建一个 Redis 集群玩玩,也可以这么说,除了步骤繁琐外,几乎不存在技术含量,估计能看完的人都感觉累(说真的,写这种文章真的很累人)。

接下来可能就是动态扩容、增加节点和减少节点,重新分配槽大小等,当然,还有最重要的就是怎么和我们程序结合起来,以及如何更好的把 Redis 缓存集群发挥出应有的效果,这些才是最重要的。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值