一般类似drupal这样的PHP框架,我们为了提高性能必须要使用opcode来提高PHP的执行速度,PHP也有这样的模块。
' `8 c; j F) q- T我们都知道使用APC或者eAccelerator这样的opcode缓存可以提高网站的性能,但要注意的是需要根据网站的规模做细节的调优,只使用默认设置,可能带来的结果是性能还不如不用他们之前的效果。 ! Y9 ~; x8 ?" ~& i2 f
这里要说的Case是,APC配置中有一项是shm_size,这是用来控制划分多少内存给APC使用,用来缓存文件或者opcode,对于文件缓存,原理大概相当于,预先读取到内存中缓存起来,下次再使用时就不需要占用磁盘I/O了,这个想法当然是很好的,依赖来说效果也是非常明显的。但使用Drupal做的大型项目,开启的模块是很多的,那就意味了需要加载的文件很多,他们放到一起占用的内存是很可观的,一般APC默认的配置可能16M, 那么当文件缓存的内存占用超过16M之后,会有什么问题呢,带来的问题是include_once这样的函数花费很长时间决定如何加载文件,这里可能存在一些算法上的问题,需要觉得那些缓存丢弃,把新读取的文件缓存放在内存中什么位置之类的,总之在这种情况下,APC反而会让性能下降,大概下降3,4倍左右。
\+ v N) }8 N, M- Z所以,在实际应用环境中,需要知道启用了多少个模块,需要提供大概多少内存,对于一个服务器提供多个站点,并且各个站点的Drupal是独立目录的场景中,因为APC的缓存机制,缓存所需内存更是成倍增加的。所以要么不用,用的话,一定要留出足够的内存,另外eAccelerator也是同样的道理,也许在内存溢出时,由于调度算法的差异,性能下降程度可能不一样,但总是会有影响的。
$ ?+ G" q# d1 E8 V因为本文只记录了结论,没有包含分析过程,大家可以参考一下原文的详细分析。
3 e5 s5 h) l' T% E" `
) r" ^: G J- i% V. Z9 {6 u* ^3 e3 X; g7 D
5 t, j# \" R4 n5 ^; u4 P |