php redis set 时 nginx 502 解决

 

PHP Version 5.5.30-1+deb.sury.org~trusty+1

redis 3.0.1,

通过 下载 pr.tar.gz 安装的 php-redis扩展,版本为2.10。

执行 $redis->set('test', 'hello world'),报nginx 502错误(nginx 502错误真是个很头疼的问题)。

 

问题定位在  $this->_redis->setOption(Redis::OPT_SERIALIZER,Redis::SERIALIZER_PHP);

 

原因是 php-redis扩展版本 2.10, 太低,可以使用 sudo apt-get install  php5-redis 或者 在 gitHub 上下载

https://github.com/phpredis/phpredis

通过编译安装。

apt-get install 安装的版本为 2.2.7.

 

 

 public function conn() {

        try {

            $this->_redis->pconnect($this->host, $this->port, $this->timeout);

            // Set client option. must AFTER connected

            //var_dump(Redis::OPT_SERIALIZER,Redis::SERIALIZER_PHP);exit();

           $this->_redis->setOption(Redis::OPT_SERIALIZER,Redis::SERIALIZER_PHP);

           //$this->_redis->setOption(0, 0);

            $this->_redis->auth("xxxrs");         // 此处是为 redis 配置的验证密码

 

            $this->connected = true;

 

        } catch (RedisException $e) {

            throw new CHttpException(500, "Redis occurs an error:" . $e->getMessage());

        }

    }

用红色的代码那段,就会报502错误,而用绿色代码这段就没问题。

 

setOption 这个是个神马东西呢?查了下php-redis api

 

$redis->setOption(Redis::OPT_SERIALIZER, Redis::SERIALIZER_NONE);   // don't serialize data  不序列化数据

$redis->setOption(Redis::OPT_SERIALIZER, Redis::SERIALIZER_PHP);    // use built-in serialize/unserialize  用php内置的序列化

$redis->setOption(Redis::OPT_SERIALIZER, Redis::SERIALIZER_IGBINARY);   // use igBinary serialize/unserialize 用扩展IGBINARY序列化

$redis->setOption(Redis::OPT_PREFIX, 'myAppName:'); // use custom prefix on all keys redis key前缀

 

$redis->setOption(Redis::OPT_SERIALIZER, Redis::SERIALIZER_PHP);  用此就报502

 

为什么用php内置的序列化就会出错呢?到底发生了什么?

后来又安装了IGBINARY 扩展,还是不行。最后把php-redis安装了最新的版本2.24,再运行,就完全没问题了。

 

2.24版本php-redis源码地址https://github.com/nicolasff/phpredis

 

参考网址: http://blog.csdn.net/tengzhaorong/article/details/12704759

 

======================

 

Redis::__construct构造函数
$redis = new Redis();

connect, open 链接redis服务
参数
host: string,服务地址
port: int,端口号
timeout: float,链接时长 (可选, 默认为 0 ,不限链接时间)
注: 在redis.conf中也有时间,默认为300

pconnect, popen 不会主动关闭的链接
参考上面

setOption 设置redis模式

getOption 查看redis设置的模式

ping 查看连接状态

 

参考网址: http://www.cnblogs.com/zcy_soft/archive/2012/09/21/2697006.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值