q789321 发表于 2018-11-4 11:28:41

redis解决(DENIED Redis is running in protected mode because prote)

  早上一个应用日志打印报错信息:

  在应用上telnet端口和ping都没有问题,为什么还获取不到值呢。
  先安装一个redis客户端进行测试:yum -y install redis
  redis-cli -h 192.168.32.12 -p 6887
  然后就报错了:
  (error) DENIED Redis is running in protected mode because protected mode is……
  后来就查看配置发现redis.conf 该行也是注释的:
  # requirepass foobared
  继续排查发现和一个参数配置有关系:
  链接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)>  是说处于保护模式,只能本地链接,我们需要修改配置文件../redis.conf
  1)打开配置文件把下面对应的注释掉
  # bind 127.0.0.1
  2)Redis默认不是以守护进程的方式运行,可以通过该配置项修改,使用yes启用守护进程,设置为no
  daemonize no
  3)保护模式
  protected-mode no
  报错处理:
  一、
  在对应配置conf文件中去掉注释,把yes改为no
  #protected-mode yes
  protected-mode no
  重启redis(注意有数据时慎重启)
  kill -9 进程号
  redis-cli -h 192.168.32.12 -p 6887 shutdown
  二、添加认证,设置密码
  # requirepass foobared
  requirepass redis123456
  验证
  再次用Java程序建立连接池,没有报错,且可以对redis server进行数据正常处理。程序报错日志不再显示
  问题解决

页: [1]
查看完整版本: redis解决(DENIED Redis is running in protected mode because prote)