千家信息网

Redis中怎么使用redis-trib.rb创建带密码的集群

发表于:2025-01-23 作者:千家信息网编辑
千家信息网最后更新 2025年01月23日,Redis中怎么使用redis-trib.rb创建带密码的集群,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。1、设定集群密码各个节点的配
千家信息网最后更新 2025年01月23日Redis中怎么使用redis-trib.rb创建带密码的集群

Redis中怎么使用redis-trib.rb创建带密码的集群,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。

1、设定集群密码

各个节点的配置中设定密码,注意集群模式下,下面两行都需要

1

2

masterauth passwd123

requirepass passwd123

2、各个节点的配置中开启集群配置的相关选项,如下:

1

2

3

4

5

port 30001

cluster-enabled yes

cluster-config-file nodes-30001.conf

cluster-node-timeout 5000

appendonly yes

3、修改create-cluster工具

新版的Redis中给我们提供了利用redis-trib.rb创建集群的工具,就是:utils/create-cluster/create-cluster

我们稍作修改,把start部分的redis-server命令的参数,直接替换为各个节点配置文件路径

1

2

3

4

5

6

7

8

9

10

if [ "$1" == "start" ]

then

while [ $((PORT < ENDPORT)) != "0" ]; do

PORT=$((PORT+1))

echo "Starting $PORT"

# 通过redis-server并指定各个节点的redis配置文件路径

../../src/redis-server /redis/redis-$PORT.conf

done

exit 0

fi

4、修改redis-trib.rb脚本

如果Redis设定了密码,那么通过redis-trib.rb脚本创建集群时,是会类似这样的错误的:[ERR] Sorry, can't connect to node *.*.*.*:7001

这是因为redis-trib.rb脚本中连接Redis时,并未设定密码,这确实是个很大的坑。我的解决方法时,修改该脚本中连接Redis时的代码,修改内容如下:

找到这一行:

1

@r = Redis.new(:host => @info[:host], :port => @info[:port], :timeout => 60)

修改为:

1

@r = Redis.new(:host => @info[:host], :port => @info[:port], :timeout => 60, :password => "你的密码")

5、修改完成后,依次运行:

./craete-cluster start

./craete-cluster create

即可启动集群

看完上述内容,你们掌握Redis中怎么使用redis-trib.rb创建带密码的集群的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注行业资讯频道,感谢各位的阅读!

0