OpCache - 了解每个用户或每个资源的缓存是如何工作的?

Posted

技术标签:

【中文标题】OpCache - 了解每个用户或每个资源的缓存是如何工作的?【英文标题】:OpCache - understanding how the cache works, per user or per resource? 【发布时间】:2013-12-18 04:54:46 【问题描述】:

我正在使用 OpCache,因为它是 php 5.5.x 附带的,我对它非常满意,但我想调整它的内存设置,这就是我的理解不足的地方......

当给定用户请求给定页面时,服务器会响应此请求,调用 PHP 解释器,解释器将操作码存储在缓存中,提供内容,仅此而已。下一次请求进来时,如果请求的操作码相同,缓存就会启动,但我的问题是......

缓存是在每个用户的基础上工作的(并且缓存的操作码仅适用于该特定用户的请求)或者它们是否适用于使用这些缓存操作码的任何请求?

我想做的是调整 OpCache 以使用一定数量的内存,但我不知道内存池是基于每个用户工作还是像共享资源池一样工作。

你能给我一个提示吗?

【问题讨论】:

【参考方案1】:

关于操作码如何存储在缓存中并从共享内存中读取,您已经说对了。然而,它不是基于用户,而是基于脚本级别。每个被解析编译为操作码的php文件都将被保存到共享内存并从那里执行。 解析编译步骤本来很慢,对于每个已缓存的脚本都会被缩短。

为了回答您的问题,不,缓存不适用于每个用户,而是基于每个脚本。缓存的操作码仍然由每个请求的脚本引擎(主要是 Zend)执行。

是的,它确实从共享内存中读取。

参考 D. Shafik: Everything You Need to Know About OpCode Caches

【讨论】:

太棒了!就像我想让它表现得那样。现在我可以轻松调整内存设置。非常感谢:) @Awemo 我在这里对共享内存感到困惑。你能告诉我究竟什么是共享内存。硬盘还是内存? @sandipshirsale 是服务器系统的RAM,看这个answer。

以上是关于OpCache - 了解每个用户或每个资源的缓存是如何工作的?的主要内容,如果未能解决你的问题,请参考以下文章

每个 php-fpm 池都有自己的内存池吗?

PHP7 opcache缓存清理问题

PHP7 opcache缓存清理问题

PHP7 opcache缓存清理问题

如何为每个用户或系统范围配置 Ivy 缓存目录?

PHP 被设置为移除内联块,这将导致多个核心应用无法访问。 这可能由缓存/加速器导致的,例如 Zend OPcache 或 eAccelerator。