首先浏览器请求报504,然后Postman请求无返回,长这样
然后代码中打印出如下结果:
最开始排查的时候考虑是不是内存问题 后来加大内存后还是出现同样的问题
如上图可以看出 $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;
}