3

我已经设置 Zend_Db_Table_Abstract 所以它使用元数据缓存,然后用 xhprof 进行分析以查看它使用了多少内存。

结果从 _setupMetadata 到 Zend_Cache_Core::load 的 34 次调用占用了 7mb 内存,其中大部分是通过调用反序列化来使用的。

元数据缓存的配置是:

resources.cachemanager.db_metadata.frontend.name = Core
resources.cachemanager.db_metadata.frontend.options.automatic_serialization = true
resources.cachemanager.db_metadata.frontend.options.lifetime = null

resources.cachemanager.db_metadata.backend.name = File
resources.cachemanager.db_metadata.backend.options.cache_dir = APPLICATION_PATH "/../data/cache/db_metadata"

这是一个常见问题,还是我错过了什么?

4

1 回答 1

0

由于您正在序列化对象,因此需要大量内存。特别是 Zend_Db_* 对象。

在这里,我们遇到了同样的问题,我们最终让您拥有自己的缓存系统。

您可以做的是定义睡眠/唤醒,以便您从 Zend_Db_Table_Row_Abstract 中删除所有不必要的 ivar,但您必须确保不破坏类不变量。

祝你好运。:)

于 2010-07-28T13:49:58.940 回答