博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
redis配置认证密码
阅读量:7081 次
发布时间:2019-06-28

本文共 2720 字,大约阅读时间需要 9 分钟。

hot3.png

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

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,接管道删除(命令行执行)

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

-cli KEYS "site_msg_999*”

 

接linux管道删除之

-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

你可能感兴趣的文章
leetcode725
查看>>
LLVM3.8停止了旧Windows版本,取消Autoconf,改进Clang
查看>>
《快学 Go 语言》第 9 课 —— 接口
查看>>
Swift 中的利刃,函数和闭包
查看>>
HOWTO: 为GitHub for Windows指定代理服务器(转)
查看>>
联通混改再现反转:中车集团确认参与
查看>>
用C/C++开发基于VLC SDK的视频播放器
查看>>
grpc vs2015编译
查看>>
注解的使用
查看>>
X264 ratecontrol 码率控制
查看>>
iOS中 UISearchController 搜索栏 UI技术分享
查看>>
新手神器!不用部署深度学习环境、上传数据集!(附代码&视频教程)
查看>>
使用Python+OpenCV进行图像模板匹配(Match Template)
查看>>
Assembly Loop
查看>>
Windows注册密码能保护你的数据安全吗?
查看>>
新工具填补Docker管理空白
查看>>
行为驱动开发使用体验
查看>>
智慧城市:中国特色新型城镇化的发展方向
查看>>
新恶意软件使用Tor在Mac OS X系统打开“后门”
查看>>
微信自动化工具---自动发送朋友圈(非root权限)
查看>>