redis配置认证密码

redis配置密码

1.通过配置文件进行配置
yum方式安装的redis配置文件通常在/etc/redis.conf中,打开配置文件找到

#requirepass foobared  

去掉行前的注释,并修改密码为所需的密码,保存文件

requirepass myRedis  

重启redis

sudo service redis restart  

#或者  

sudo service redis stop  

sudo redis-server /etc/redis.conf  

这个时候尝试登录redis,发现可以登上,但是执行具体命令是提示操作不允许

redis-cli -h 127.0.0.1 -p 6379  

redis 127.0.0.1:6379>  

redis 127.0.0.1:6379> keys *  

(error) ERR operation not permitted  

redis 127.0.0.1:6379> select 1  

(error) ERR operation not permitted  

redis 127.0.0.1:6379[1]>   

尝试用密码登录并执行具体的命令看到可以成功执行

redis-cli -h 127.0.0.1 -p 6379 -a myRedis  

redis 127.0.0.1:6379> keys *  

1) "myset"  

2) "mysortset"  

redis 127.0.0.1:6379> select 1  

OK  

redis 127.0.0.1:6379[1]> config get requirepass  

1) "requirepass"  

2) "myRedis"  


2.通过命令行进行配置

redis 127.0.0.1:6379[1]> config set requirepass my_redis  

OK  

redis 127.0.0.1:6379[1]> config get requirepass  

1) "requirepass"  

2) "my_redis"  

无需重启redis
使用第一步中配置文件中配置的老密码登录redis,会发现原来的密码已不可用,操作被拒绝

redis-cli -h 127.0.0.1 -p 6379 -a myRedis  

redis 127.0.0.1:6379> config get requirepass  

(error) ERR operation not permitted  

使用修改后的密码登录redis,可以执行相应操作

redis-cli -h 127.0.0.1 -p 6379 -a my_redis  

redis 127.0.0.1:6379> config get requirepass  

1) "requirepass"  

2) "my_redis  

尝试重启一下redis,用新配置的密码登录redis执行操作,发现新的密码失效,redis重新使用了配置文件中的密码

sudo service redis restart  

Stopping redis-server:                                     [  OK  ]  

Starting redis-server:                                     [  OK  ]  

redis-cli -h 127.0.0.1 -p 6379 -a my_redis  

redis 127.0.0.1:6379> config get requirepass  

(error) ERR operation not permitted  

redis-cli -h 127.0.0.1 -p 6379 -a myRedis  

redis 127.0.0.1:6379> config get requirepass  

1) "requirepass"  

2) "myRedis"  


除了在登录时通过 -a 参数制定密码外,还可以登录时不指定密码,而在执行操作前进行认证。

redis-cli -h 127.0.0.1 -p 6379  

redis 127.0.0.1:6379> config get requirepass  

(error) ERR operation not permitted  

redis 127.0.0.1:6379> auth myRedis  

OK  

redis 127.0.0.1:6379> config get requirepass  

1) "requirepass"  

2) "myRedis"  


3.master配置了密码,slave如何配置

若master配置了密码则slave也要配置相应的密码参数否则无法进行正常复制的。
slave中配置文件内找到如下行,移除注释,修改密码即可

#masterauth  mstpassword  

参考:http://blog.csdn.net/zyz511919766/article/details/42268219

redis的通配符和批量删除Key

1. DEL 直接加键名称

DEL key1 key2 key3

127.0.0.1:6379>  DEL site_msg_99973  false site_msg_99974   false site_msg_99979false

 

2. 批量删除key

可用keys ‘str*’ 列出要删除的key,接Linux管道删除(linux命令行执行)

根据通配符查看待删除的key

Redis-cli KEYS "site_msg_999*”

 

接linux管道删除之

redis-cli KEYS "site_msg_999*"|xargs redis-cli DEL

有密码删除

redis-cli -a abc keys "site_msg_999*" |xargs redis-cli -a abc DEL

3.更好的方式

keys * 命令在数据量很大的情况下,直接在redis cli中执行会严重影响服务器性能,更好的方式是在lua脚本中执行

eval方式执行redis lua

lua方式通配符查找

redis-cli eval "return redis.call('keys','site_msg_888*')” 0

lua方式通配符删除

eval "return redis.call('del',unpack(redis.call('keys',ARGV[1])))" 0 ‘site_msg_888*’

参考:http://blog.csdn.net/l_ieluil/article/details/52174630

转载于:https://my.oschina.net/u/1260221/blog/1510167

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值