gpt4 book ai didi

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

转载 作者:可可西里 更新时间:2023-11-01 00:14:25 24 4
gpt4 key购买 nike

我正在使用 OpCache,因为它随 PHP 5.5.x 一起提供,我真的很喜欢它,但我想调整它的内存设置,而这正是我理解不足的地方......

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

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

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

你能给我一个提示吗?

最佳答案

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

enter image description here

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

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

引用资料 D. Shafik: Everything You Need to Know About OpCode Caches

关于php - OpCache - 了解缓存是如何工作的,每个用户或每个资源?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20329035/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com