开发者

Redis本地/远程(外部)连接失败问题及解决

目录
  • 问题现象
  • 问题分析
    • 1.报错信息
    • 2.知识点分析
      • 2.1Redis 的配置文件的区别
      • 2.2Redis 的 bind 配置
      • 2.3Redis 的 protected-mode 配置
      • 配置步骤
      • 好了,接下来就是验证实验的时刻了
      • 必杀技
  • 解决方法
    • 总结

      问题现象

      今天在 192.168.2.220(Windows服务器)上安装并启动了一个 Redis服务,如下:

      点击 redis-server.exe:

      Redis本地/远程(外部)连接失败问题及解决

      启动成功:

      Redis本地/远程(外部)连接失败问题及解决

      然后在192.168.2.101(本地)php 连接 192.168.2.220 Redis服务,出现报错,如下:

      Redis本地/远程(外部)连接失败问题及解决

      随后,启动本地的Java项目,配置 Redis,如下:

      Redis本地/远程(外部)连接失败问题及解决

      Redis本地/远程(外部)连接失败问题及解决

      然后访问需要使用到 Redis服务 的接口,出现如下报错:

      Redis本地/远程(外部)连接失败问题及解决

      问题分析

      1.报错信息

      根据报错信息可知,大概意思就是说:

      Redis连接 是以 “protected” 模式mode),该模式具有以下的特点:没有绑定可具体的ip地址,访问cli工具不需要认证密码,该模式下只支持“loopback”(回环)接口的调用。

      //注:回环的意思大概就是说,只能在配置了redis的机器上访问redis连接,而不允许外部ip连接。

      如果你想要连接该redis服务,你需要采用以下其中一种解决方法:

      方案1.2.3:前三种的意思几乎一致,都是说让你去修改该 Redis的配置 ,让Redis以“protected-mode no”的配置来启动。

      方案4:修改该 Redis的配置,让Redis绑定一个ip地址或一个认证密码。

      Redis本地/远程(外部)连接失败问题及解决

      2.知识点分析

      2.1Redis 的配置文件的区别

      可以看到有两个配置文件:

      Redis本地/远程(外部)连接失败问题及解决

      那该使用哪个呢?那就来说说 redis.windows.confredis.windows-service.conf 的区别:

      查阅网上资料发现,网上流传着这样的说法:“当redis安装后,就会在系统服务中出现一个名为Redis的服务,通过点击启动来启动Redis”

      通过 win+r 中,输入 compmgmt.msc ,打开管理工具点击服务,可以找到redis服务,然后看见类似下图:

      Redis本地/远程(外部)连接失败问题及解决

      通过这个图片可以看到,这个名为Redis的系统服务,默认是使用了 “redis.windows-service.conf ” 这个配置文件来启动的。

      奇怪的是我看了一下却没有Redis这个系统服务。。。。。。好吧,有可能是Redis的版本的问题:

      Redis本地/远程(外部)连接失败问题及解决

      问题不大,因为我们其实完全就没必要把redis变成一个系统服务,从而实现开机自启动(后台);我觉得想用的时候,直接点击 redis-server.exe 启动 不香么???

      现在要思考的问题其实是:当我们点击 redis-server.exe 启动 Redis 时,会不会也是使用了 “redis.windows-service.conf ” 这个配置文件来启动的呢?

      我猜想:redis-server.exe 启动 Redis 时是使用“redis.windows.conf ”这个配置文件来启动的,否则,这个文件就没有存在的意义了。

      搜了很久,没有在网上找到对应的资料,于是就自己来实验一下吧!!!!!!

      2.2Redis 的 bind 配置

      首先我们打开 redis.windows-service.conf,可以看见默认绑定了127.0.0.1(本地ip地址)

      Redis本地/远程(外部)连接失败问题及解决

      Redis本地/远程(外部)连接失败问题及解决

      redis 中的 bind 配置作用就是:

      • 配置该redis连接 的 固定ip,配置完之后,就只有它绑定的那这个 ip 能访问到该redis连接;其他ip就不能。
      • 而由于 redis 默认绑定了 127.0.0.1 ,也就是只有 127.0.0http://www.devze.com.1 所映射的(192.168.2.220)这个ip能访问该 redis,其他ip就不能;
      • 因此这个配置会阻碍外部(192.168.2.101)对该 redis的访问。

      2.3Redis 的 protected-mode 配置

      “redis.windows-service.conf ” 文件中,可以找到如下配置:

      Redis本地/远程(外部)连接失败问题及解决

      通过查看注解,我们可以知道:

      • 该配置是默认启动(enabled)的;
      • 如果你想让其他主机(ip)连接该redis,则必须设置该配置为不可用的(disable),即使你不配置认证密码,也没有 通过 bind 配置绑定外部ip地址
      • 由此可知:该配置就是用于限制外部ip访问的,且要和 bind 配置一起使用。

      心得

      从上面的知识点可知,要解决问题,就需要对 redis的配置文件中的 bind 和 protected-mode 配置进行修改。

      配置步骤

      步骤1打开 “redis.windows-service.conf ” 文件,为Redis绑定一个ip地址

      //注:我们一般都不需要在访问redis时使用到认证密码,所以没有要求的话,可以不配置

      把该bing 配置(bind 127.0.0.1)注释掉,这样就能让所有ip都能访问到这个redis,修改如下:

      Redis本地/远程(外部)连接失败问题及解决

      步骤2打开 “redis.windows-service.conf ” 文件,修改www.devze.comRedis的 protected-mode 配置

      下拉,找到 protected-mode 配置,修改为如下:

      Redis本地/远程(外部)连接失败问题及解决

      然后把原来的redis服务关闭,再点击redis-server.exe 启动。

      然后再在本地(192.168.2.101)连接 192.168.2.220 Redis服务,出现如下报错:

      Redis本地/远程(外部)连接失败问题及解决

      再调用接口试试,发现还是报错:

      Redis本地/远程(外部)连接失败问题及解决

      好了,接下来就是验证实验的时刻了

      1. 关闭redis窗口,将“redis.windows-service.conf ” 还原成初始状态;

      2. 将以上步骤应用到 &http://www.devze.comldquo;redis.windows.conf” 这个配置文件上;

      3. 点击 redis-server.exe 启动;

      Redis本地/远程(外部)连接失败问题及解决

      发现还是会报同样的错误,那就不知道是为什么了。。。尴尬

      于是,我又把“redis.windows.conf” 和 “redis.windows-service.conf ” 两个配置文件都做了修改,然后再点击 rejavascriptdis-server.exe 启动,结果还是不行

      这样就不好说问题出在哪里,但是能确定的是:这两个配置文件的修改都没有生效!!!!!!

      必杀技

      自己写个启动脚本(redis-start.BAT),配置redis的启动命令并指定了配置文件,来启动redis,终于可以了:

      Redis本地/远程(外部)连接失败问题及解决

      双击 “redis-start.bat” 文件

      Redis本地/远程(外部)连接失败问题及解决

      启动成功:

      Redis本地/远程(外部)连接失败问题及解决

      接口调用成功:

      Redis本地/远程(外部)连接失败问题及解决

      Redis本地/远程(外部)连接失败问题及解决

      注意:这里不要指定 “redis.windows-service.conf ” 配置文件,否则会出现以下情况:

      Redis本地/远程(外部)连接失败问题及解决

      虽然启动了,但是一片黑暗,啥信息都看不到,由此似乎可以证明了我的猜想:

      redis-server.exe 启动 Redis 时是使用“redis.windows.conf ”这个配置文件来启动的

      因为,redis-server.exe 启动 Redis 时,是有信息可以看见的,所以说

      “redis.windows-service.conf ” 这个配置文件,应该是用来将Redis配置成一个Windows系统服务而存在的!!!

      总之,最靠谱的方法,还是用脚本启动!!!

      解决方法

      1. 打开 “redis.windows​​​​​​​” 文件,把该bing 配置(bind 127.0.0.1)注释掉

      Redis本地/远程(外部)连接失败问题及解决

      Redis本地/远程(外部)连接失败问题及解决

      2. 修改Redis的 protected-mode 配置 protected-mode no ,如下:

      Redis本地/远程(外部)连接失败问题及解决

      3. 创建启动脚本文件(redis-start.bat),写入启动命令并指定配置文件:

      Redis本地/远程(外部)连接失败问题及解决

      4. 双击 “redis-start.bat” 文件启动:

      Redis本地/远程(外部)连接失败问题及解决

      Redis本地/远程(外部)连接失败问题及解决

      5. 访问接口成功:

      Redis本地/远程(外部)连接失败问题及解决

      总结

      以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程客栈(www.devze.com)。

      0

      上一篇:

      下一篇:

      精彩评论

      暂无评论...
      验证码 换一张
      取 消

      最新数据库

      数据库排行榜