代码灵异事件 -- php使用redis的hgetall方法出现的怪问题

首先浏览器请求报504,然后Postman请求无返回,长这样
代码灵异事件 -- php使用redis的hgetall方法出现的怪问题_第1张图片
然后代码中打印出如下结果:
代码灵异事件 -- php使用redis的hgetall方法出现的怪问题_第2张图片
代码灵异事件 -- php使用redis的hgetall方法出现的怪问题_第3张图片
最开始排查的时候考虑是不是内存问题 后来加大内存后还是出现同样的问题
如上图可以看出 $hash变量是已经指向了$result

但是改变 $hash或者 $result的变量名称后还是有问题
后来发现在496行后给$hash重新赋值 [1] 就没有这样的问题了

那应该就是hGetAll方法的问题了 应该是引用的问题?

本地是没有问题的 上传到服务器出现问题 php版本都是7.0 redis扩展 本地3.0.0 服务器 3.1.2(不知道是不是这个原因)

最后并没有找到原因,先记录一下,看看以后能不能找到原因

暂行解决办法,用以下方法代替hGetAll方法:

    private function hGetAll(string $redis_key):array
    {
        $keys = $this->redis->hKeys($redis_key);
        $hash = [];
        if ($keys){
            foreach ($keys as $key){
                $hash[$key] = $this->redis->hGet($redis_key, $key);
            }
        }
        return $hash;
    }

你可能感兴趣的:(redis,php)