Opcache状态内存大小问题

时间:2016-11-15 12:32:26

标签: php opcache

我目前在使用PHP7.0-FPM时遇到一些问题使一些麻烦的opcache条目无效。

当我在opcache_get_status中查看时,某些文件正在缓存,内存大小为680.00b。这些文件的大小通常约为50kb,并且似乎正确缓存,但Opcache报告的这些文件数量正好是680.00b。

Opcache设置:

; configuration for php opcache module
; priority=10
zend_extension=opcache.so
opcache.memory_consumption=16384
opcache.max_accelerated_files=32531
opcache.validate_timestamps=0
opcache.revalidate_freq=600
opcache.max_file_size=0
opcache.fast_shutdown=1

这是一个不寻常的设置,其中生成的文件正在被缓存,因此偶尔存在问题并且文件被替换/重新访问。

有没有理由让人想到为什么opcache将这些文件显示为680.00b? opcache_reset或opcache_invalidate没有帮助。我必须完全替换文件并使用opcache_reset来显示它们的真实文件大小,并且它使监视/故障排除变得困难。

提前致谢。

1 个答案:

答案 0 :(得分:5)

当涉及到显示相同消耗的不同脚本时:一个可能的原因是opcache需要为当前平台上的最佳性能分配内存。

例如(此代码都不是真实的):

void *mem = zend_opcache_alloc(sizeof(void*));

mem将为sizeof void* + ZEND_MM_ALIGNMENT(sizeof void*, platform)

所以在区域的末尾有一些填充以强制最佳对齐,这意味着你可以分配(例如)8个字节或64个字节,并返回一个128字节的块(没有这些数字是正确的。)

这可能导致不同的脚本具有相同的大小巧合。

当谈到为什么有些脚本使用非常少量的内存时:

<?php
$a = 1;
?>

产生以下统计数据:

["/usr/src/php-src/test.php"]=>
array(6) {
  ["full_path"]=>
  string(25) "/usr/src/php-src/test.php"
  ["hits"]=>
  int(0)
  ["memory_consumption"]=>
  int(696)
  ["last_used"]=>
  string(24) "Wed Nov 16 05:47:26 2016"
  ["last_used_timestamp"]=>
  int(1479275246)
  ["timestamp"]=>
  int(1479275244)
}

因此,您应该怀疑代码没有正确缓存,除非这些文件包含类似的(单个语句,单个指令)代码。