早上一个应用日志打印报错信息:redis
在应用上telnet端口和ping都没有问题,为何还获取不到值呢。网络
先安装一个redis客户端进行测试:yum -y install rediside
redis-cli -h 192.168.32.12 -p 6887oop
而后就报错了:测试
(error) DENIED Redis is running in protected mode because protected mode is……ui
后来就查看配置发现redis.conf 该行也是注释的:this
# requirepass foobared
spa
继续排查发现和一个参数配置有关系:3d
连接redis 时只能经过本地localhost (127.0.0.1)这个来连接,而不能用网络ip(192.168..)这个连接,问题然若是用网络ip 连接会报如下的错误:
(error) DENIED Redis is running in protected mode because protected mode is enabled, no bind address was specified, no authentication password is requested to clients. In this mode connections are only accepted from the lookback interface. If you want to connect from external computers to Redis you may adopt one of the following solutions: 1) Just disable protected mode sending the command 'CONFIG SET protected-mode no' from the loopback interface by connecting to Redis from the same host the server is running, however MAKE SURE Redis is not publicly accessible from internet if you do so. Use CONFIG REWRITE to make this change permanent. 2) Alternatively you can just disable the protected mode by editing the Redis configuration file, and setting the protected mode option to 'no', and then restarting the server. 3) If you started the server manually just for testing, restart it with the --portected-mode no option. 4) Setup a bind address or an authentication password. NOTE: You only need to do one of the above things in order for the server to start accepting connections from the outside.
是说处于保护模式,只能本地连接,咱们须要修改配置文件../redis.conf
1)打开配置文件把下面对应的注释掉
# bind 127.0.0.1
2)Redis默认不是以守护进程的方式运行,能够经过该配置项修改,使用yes启用守护进程,设置为no
daemonize no
3)保护模式
protected-mode no
rest
报错处理:
1、
在对应配置conf文件中去掉注释,把yes改成no
#protected-mode yes
protected-mode no
重启redis(注意有数据时慎重启)
kill -9 进程号
redis-cli -h 192.168.32.12 -p 6887 shutdown
2、添加认证,设置密码
# requirepass foobared
requirepass redis123456
验证
再次用Java程序创建链接池,没有报错,且能够对redis server进行数据正常处理。程序报错日志再也不显示
问题解决