由于某些奇怪的原因,我在PHP7上每100个请求都会收到此错误,我无法摆脱它,直到我重新启动fpm恶魔,然而,真正的问题是我无法解释错误是什么开始诊断这个。< / p>
我看了一下文档http://php.net/manual/en/function.json-last-error.php,它不是很有用,似乎没有任何真正的链接。
我知道这个错误实际上并不与递归深度(JSON_ERROR_DEPTH
)有关,那么这个错误究竟意味着什么呢?
这是失败的数组的var_dump()
:
array (
'ns' => 'user',
'where' => '{"_id":"MongoDB\\\\BSON\\\\ObjectID(5505a4f647ac1824618b4567)","status":10}',
'projection' =>
array (
),
'sort' =>
array (
),
'limit' => NULL,
'skip' => NULL,
)
答案 0 :(得分:4)
JSON_ERROR_RECURSION
表示传递给json_encode()
的数据包含一个或多个递归引用。
$data = array();
$data['foo'] = &$data; // <-- recursive reference here
var_dump(json_encode($data)); // bool(false)
var_dump(json_last_error_msg()); // string(18) "Recursion detected"
var_dump(json_last_error() === JSON_ERROR_RECURSION); // bool(true)
这样的代码可以工作:
$data['foo'] = 'hello';
$data['bar'] = &$data['foo'];
但不喜欢这个(另一个递归引用):
$data['foo'] = [1, 2, 3];
$data['foo'][] = &$data['foo'];
递归引用意味着引用指向一个变量,而该变量又包含相同的引用。
答案 1 :(得分:0)
最有可能需要更新mongodb驱动程序(或者可能是其他扩展程序)。带bug的扩展可能会写入共享内存(不可变数组) - 不允许这样做。
可以使用opcache.protect_memory
(http://php.net/manual/en/opcache.configuration.php#ini.opcache.protect-memory)