使用redis2-nginx-module连接带密码的redis时报NOAUTH Authentication required. 错误解决方案

个人博客原文地址:http://www.lampnick.com/php/746

使用redis2-nginx-module连接带密码的redis时报NOAUTH Authentication required. 错误解决方案

版本:redis2-nginx-module-0.15

使用redis2-nginx-module连接redis报错的nginx.conf代码如下:

location /foo {
     default_type 'text/plain';
     redis2_query set hello 'world';
     redis2_query get hello;
     redis2_query auth 'pwd';
     redis2_pass ip:port;
 }

报错信息如下:

使用redis2-nginx-module连接带密码的redis时报NOAUTH Authentication required. 错误解决方案

网上找了很多资料都没有找到有相关的错误解决方案。后来仔细分析了错误信息,发现redis2_query一共有3个地方写了,错误有2个地方报NOAUTH Authentication required.一个地方报OK,刚好和nginx.conf里面的语句对应,想想redis2_query的原理应该是依次向下执行的,刚开始没有授权肯定会报NOAUTH Authentication required错误,由于将授权语句写到最前面redis2_query auth ‘pwd’;进行测试

location /foo {
     default_type 'text/plain';
     redis2_query auth 'pwd';
     redis2_query set hello 'world';
     redis2_query get hello;
     redis2_pass ip:port;
 }

重启nginx服务器后,发现已经成功连接上redis了。这问题花了半天的时间才解决。回头想想是不应该的。

使用redis2-nginx-module连接带密码的redis时报NOAUTH Authentication required. 错误解决方案

特别说明:有台线上服务器的代码这样的,也能连接成功,应该是redis2-nginx-module版本问题。
有时使用nginx -s reload配置不会重新加载 ,建议测试时使用nginx -s stop,然后再启动nginx

location = /redis {
     set $env $arg_env;
     redis2_query hget env $env;
     redis2_query auth 'pwd';
     redis2_pass ip:port;
 }