redis集群密码设置

布满荆棘的人生 2022-07-13 00:10 288阅读 0赞

1.密码设置
方式一:修改所有redis集群中的redis.conf文件加入:
masterauth passwd123
requirepass passwd123
说明:这种方式需要重新启动各节点

方式二:进入各个实例进行设置:
./redis-cli -c -p 7000
config set masterauth passwd123
config set requirepass passwd123
config rewrite
之后分别使用./redis-cli -c -p 7001,./redis-cli -c -p 7002…..命令给各节点设置上密码
注意:各个节点密码都必须一致,否则Redirected就会失败, 推荐这种方式,这种方式会把密码写入到redis.conf里面去,且不用重启

2.设置密码之后如果需要使用redis-trib.rb的各种命令
如:redis-trib.rb check 127.0.0.1,则会报错ERR] Sorry, can’t connect to node 127.0.0.1:7000
解决办法:
vim /usr/lib/ruby/gems/1.8/gems/redis-3.3.0/lib/redis/client.rb,然后修改passord

  1. class Client
  2. DEFAULTS = {
  3. :url => lambda { ENV["REDIS_URL"] },
  4. :scheme => "redis",
  5. :host => "127.0.0.1",
  6. :port => 6379,
  7. :path => nil,
  8. :timeout => 5.0,
  9. :password => "passwd123",
  10. :db => 0,
  11. :driver => nil,
  12. :id => nil,
  13. :tcp_keepalive => 0,
  14. :reconnect_attempts => 1,
  15. :inherit_socket => false
  16. }

2.带密码访问集群

  1. ./redis-cli -c -p 7000 -a passwd123

3.java客户端使用
在java程序里面使用最新的 redis.clients架包,老版本的包里可能没有提供密码访问的方式
例如maven程序:

  1. <dependency>
  2. <groupId>redis.clients</groupId>
  3. <artifactId>jedis</artifactId>
  4. <version>2.9.0</version>
  5. <type>jar</type>
  6. </dependency>

然后代码里面使用带密码的构造函数

  1. redisCluster = new JedisCluster(nodeList, TIME_OUT, 3000, 5, "passwd123", poolConfig);

下一篇分享一个简单的redis集群的java demo

发表评论

表情:
评论列表 (有 0 条评论,288人围观)

还没有评论,来说两句吧...

相关阅读