redis集群密码设置

来源:互联网 发布:阴茎延长手术死亡知乎 编辑:程序博客网 时间:2024/06/07 14:31

一直以来公司使用的redis集群都是基于无密码状态运行,凭着直接,应该是有密码这种安全策略的,不要想,撸起袖子就是干!上网一度,还真有!在本地模拟了下,还真行!奋斗


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

方式二:进入各个实例进行设置
$./redis-cli -c -p 7001
config set masterauth passwd123
config set requirepass passwd123
config rewrite
注意:各个节点密码都必须一致,否则Redirected就会失败

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

class Client    DEFAULTS = {      :url => lambda { ENV["REDIS_URL"] },      :scheme => "redis",      :host => "127.0.0.1",      :port => 6379,      :path => nil,      :timeout => 5.0,      :password => "passwd123",      :db => 0,      :driver => nil,      :id => nil,      :tcp_keepalive => 0,      :reconnect_attempts => 1,      :inherit_socket => false    }

2.带密码访问集群

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

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

<dependency>          <groupId>redis.clients</groupId>          <artifactId>jedis</artifactId>          <version>2.9.0</version>          <type>jar</type></dependency>

服务端(Java部分代码),然后代码里面使用带密码的构造函数

redisCluster = new JedisCluster(nodeList, TIME_OUT, 1000, 1000, "passwd123", poolConfig);

具体Redis的整合工具类以及使用方法可以自行百度或着留言我(为公司资源)!

原创粉丝点击