Magento 1.4.2+;APC:清除缓存对更改设置没有影响
我们得到了一个带有Magento 1.4.2 CE的服务器,安装了APC 3.1.9,Magento被配置为将其用作后端缓存 我们在缓存方面遇到了一种奇怪的行为。我们在后端所做的每一项更改都不会显示,直到apache2重新启动/APC操作码缓存被清除。这包括更改欢迎信息或激活/停用Google Analytics 问题:为什么APC缓存完整页面?我们不希望这种行为,而且它似乎不是标准行为。对于后端中的每一个小更改,我们都需要清除操作码缓存。清除Magento缓存没有帮助 为了完整起见,这里是我们的Magento 1.4.2+;APC:清除缓存对更改设置没有影响,magento,apc,Magento,Apc,我们得到了一个带有Magento 1.4.2 CE的服务器,安装了APC 3.1.9,Magento被配置为将其用作后端缓存 我们在缓存方面遇到了一种奇怪的行为。我们在后端所做的每一项更改都不会显示,直到apache2重新启动/APC操作码缓存被清除。这包括更改欢迎信息或激活/停用Google Analytics 问题:为什么APC缓存完整页面?我们不希望这种行为,而且它似乎不是标准行为。对于后端中的每一个小更改,我们都需要清除操作码缓存。清除Magento缓存没有帮助 为了完整起见,这里是我们
/etc/php5/conf.d/apc.ini
:
extension=/usr/lib/php5/20090626/apc.so
apc.enabled=1
apc.file_update_protection=2
apc.optimization=0
apc.shm_size=128M
apc.include_once_override=0
apc.shm_segments=1
apc.gc_ttl=7200
apc.ttl=7200
apc.num_files_hint=1024
apc.enable_cli=0
启用/禁用Google Analytics在7200s TTL后也将无效。可能是因为我们的缓存此时没有满。其容量的40%被使用,命中率约为98%
这是apc.php的完整设置输出:
apc.cache_by_default 1
apc.canonicalize 1
apc.coredump_unmap 0
apc.enable_cli 0
apc.enabled 1
apc.file_md5 0
apc.file_update_protection 2
apc.filters
apc.gc_ttl 7200
apc.include_once_override 0
apc.lazy_classes 0
apc.lazy_functions 0
apc.max_file_size 1M
apc.mmap_file_mask
apc.num_files_hint 1024
apc.preload_path
apc.report_autofilter 0
apc.rfc1867 0
apc.rfc1867_freq 0
apc.rfc1867_name APC_UPLOAD_PROGRESS
apc.rfc1867_prefix upload_
apc.rfc1867_ttl 3600
apc.serializer default
apc.shm_segments 1
apc.shm_size 128M
apc.slam_defense 1
apc.stat 1
apc.stat_ctime 0
apc.ttl 7200
apc.use_request_time 1
apc.user_entries_hint 4096
apc.user_ttl 0
apc.write_lock 1
APC保留终端和基于web的缓存。由于您只能从基于web的URL调用中清除“web”缓存命中,而不能从命令行中清除,因此在重新启动apache后,将清除基于APC web的缓存。您很可能希望设置一个脚本,用类似的脚本清除缓存,以便只需从CLI或脚本调用它
echo "Clearing APC web cache\n";
system('wget --spider --quiet http://localhost/clear_apc_cache.php');
echo "Clearing APC command line user cache\n";
apc_clear_cache('user');
echo "Clearing APC command line opcode cache\n";
apc_clear_cache();
显然,您需要创建clear_apc_cache.php
对应的文件,其中包含相同的两个apc内部方法调用,apc_clear_cache()代码>和apc_清除_缓存(“用户”)代码>
此外,我还设置了一个本地区域来查看APC缓存:
APC同时保留终端和基于web的缓存。由于您只能从基于web的URL调用中清除“web”缓存命中,而不能从命令行中清除,因此在重新启动apache后,将清除基于APC web的缓存。您很可能希望设置一个脚本,用类似的脚本清除缓存,以便只需从CLI或脚本调用它
echo "Clearing APC web cache\n";
system('wget --spider --quiet http://localhost/clear_apc_cache.php');
echo "Clearing APC command line user cache\n";
apc_clear_cache('user');
echo "Clearing APC command line opcode cache\n";
apc_clear_cache();
显然,您需要创建clear_apc_cache.php
对应的文件,其中包含相同的两个apc内部方法调用,apc_clear_cache()代码>和apc_清除_缓存(“用户”)代码>
此外,我还设置了一个本地区域来查看APC缓存:
您还可以将apc.stat设置为零。(apc.stat=0)在PHP.ini文件中
如果设置为1,则不会查找文件更新,这会提供更好的性能,但需要在更新后重新启动apache。设置为0时,它将检查文件更新并将其添加到缓存中(即,您的更新将在站点上可见)。您还可以将apc.stat设置为零。(apc.stat=0)在PHP.ini文件中
如果设置为1,则不会查找文件更新,这会提供更好的性能,但需要在更新后重新启动apache。设置为0时,将检查文件更新并将其添加到缓存中(即,您的更新将在站点上可见)。我得到了禁用Magento后端缓存的提示,因为它对性能的影响小于APC操作码缓存本身。停用local.xml中的缓存并清除var/cache确实有帮助。存储速度几乎和以前一样快,但每次更改单个设置时都必须清除操作码缓存的错误消失了。我得到了禁用Magento后端缓存的提示,因为它对性能的影响比APC操作码缓存本身要小。停用local.xml中的缓存并清除var/cache确实有帮助。存储速度几乎和以前一样快,但每次更改单个设置时都必须清除操作码缓存的错误已经消失。好吧,这并不是为了修复Magento的奇怪行为,但是不用每次重新启动Web服务器很好。所以这是可以接受的。顺便说一句,我们已经运行了缓存信息,请参阅本文中对apc.php的引用。好吧,这不是关于修复Magento的奇怪行为,但是不必每次重新启动Web服务器非常好。所以这是可以接受的。顺便说一句,我们已经运行了缓存信息,请参阅文本中对apc.php的引用。很抱歉告诉您,这是错误的。它正好相反。apc.stat=1将允许apc检查更改的文件,而apc.stat=0将禁用检查更改的文件。在问题的配置中选择的设置是ok。我很抱歉告诉你这是错误的。它正好相反。apc.stat=1将允许apc检查更改的文件,而apc.stat=0将禁用检查更改的文件。在问题的配置中选择的设置是ok。看见