PHP 5.6 function_exists与OPCache存在奇怪的行为

时间:2015-03-24 15:35:42

标签: php opcache php-5.6

我在 PHP 5.6 中偶然发现了php函数 function_exists()的奇怪行为。问题是,如果我直接将函数名称参数作为字符串提供,则结果与作为变量提供的结果不同。这是代码:

$f='posix_getpwuid';
$r1=function_exists('posix_getpwuid');
$r2=function_exists($f);

echo phpversion() . "\n";
var_dump($r1);
var_dump($r2);

以下是结果:

5.6.5
bool(true)    # $r1=function_exists('posix_getpwuid');
bool(false)   # $r2=function_exists($f);

我希望,两种情况都应该是 false

当我深入挖掘时,我发现它与 OPCache 有关。禁用OPCache时,结果很好 - 两个调用都返回false。但是启用了OPCache后,在第一次运行时它仍然可以,但在第二次运行时(所以当提供缓存结果时),结果是错误的。

disable_functions 中的PHP配置中禁用了 posix_getpwuid 功能。使用不存在的函数名进行测试时,结果是正确的。

在PHP 5.5.21中进行测试时,结果很好(有或没有OPCache)。

在PHP 5.5和5.6中使用Zend OPcache v7.0.4-dev。

我正在考虑向PHP开发人员提交错误,只是想确保我没有错过任何内容。

感谢。

编辑: 还使用新编译的PHP 5.6.6和5.6.7进行了测试。操作系统完全更新了CentOS 6.6。 5.6.6或5.6.7的结果相同。

PHP构建时没有任何构建选项:

./configure \
    --prefix=/usr/local/php/5.6.7-test

用简单的php.ini

disable_functions = posix_getpwuid
date.timezone = Europe/Prague
zend_extension=/usr/local/php/5.6.7-test/lib/php/extensions/no-debug-non-zts-20131226/opcache.so

测试脚本:

<?
echo phpversion() . "\n";
$f='posix_getpwuid';
$r1=function_exists('posix_getpwuid');
$r2=function_exists($f);
echo "\n\n";

echo "string: ";
var_dump ($r1);
echo "var.  : ";
var_dump ($r2);

echo "opcache status: ";
var_dump(opcache_get_status()['opcache_enabled']);

和结果 - 首先运行并正确结果:

# /usr/local/php/php-TEST/bin/php-cgi -c /data/web/php-test/ fce.php

X-Powered-By: PHP/5.6.7
Content-type: text/html; charset=UTF-8

5.6.7

string: bool(false)
var.  : bool(false)
opcache status: bool(true)

第二次运行 - 由OPCache提供,结果很糟糕:

# /usr/local/php/php-TEST/bin/php-cgi -c /data/web/php-test/ fce.php

X-Powered-By: PHP/5.6.7
Content-type: text/html; charset=UTF-8

5.6.7

string: bool(true)
var.  : bool(false)
opcache status: bool(true)

(现在我不确定为什么,但是当仅使用php执行时,OPCache没有启动,所以我使用php-cgi

1 个答案:

答案 0 :(得分:4)

我在PHP中报告了一个错误 https://bugs.php.net/bug.php?id=69297

现已修复5.6.8。 http://git.php.net/?p=php-src.git;a=commit;h=d380d1cb1ba48c41682f749692b78a10e91dd070

我测试了补丁,它运行正常。

谢谢@tlenss和我一起测试。