|
drupal慢的几个原因总结 1,drupal慢的原因不是drupal的错,而是php的错,使用php加速器如APC,EA至少可以提高3倍的性能.
5 ?* Q$ b. `0 f1 q y2,减少数据库通讯次数.尽管减少数据库通信次数似乎对响应时间减少不太明显,可是对一个访问量大的网站应该有帮助吧.
9 }( `* } d3 q- }8 Nphp天生的弱点,使得APC有了用武之地.drupal里面可以通过APC的apc_store和apc_fetch来优化locale和variable模块,经本人修改,最终local和variable模块都不会访问数据库./ E( j3 U8 [( V4 d$ P- \
如对variable_init的修改% y( R @8 P i' k
function variable_init($conf = array()) {8 E5 K8 b: W2 t
// NOTE: caching the variables improves performance by 20% when serving cached pages. $cached = apc_fetch('cache_variables'); if ($cached ) {
1 U. d9 S. u5 m" h$variables = $cached;
. ^" D* H4 z8 x2 S$ H7 M}, T/ F3 X( A4 ]
else {" \; Y1 ?: l P8 }7 x
$result = db_query('SELECT * FROM {variable}');
! f k) r6 v. \: f( K# bwhile ($variable = db_fetch_object($result)) { $variables[$variable->name] = unserialize($variable->value); }
7 i9 f" @' j- p//var_dump($variables);
/ q3 u& ~, h2 o6 yapc_store('cache_variables',($variables)); } foreach ($conf as $name => $value) {
, F- @) \# Y& V5 |+ t- Y$variables[$name] = $value;
! w. ], D' j1 |- a} return $variables; j2 m S- u% T$ `
}1 C) L" Q1 I0 A# H
使用apc cache来替代数据库可以显著提高访问速度(apc是共享内存访问) 3,通过用devel模块观察,似乎drupal慢的原因并非数据库通信,而是CPU耗时 一些提高速度的建议 1、非技术层次上就是把t函数输入的某些东东,直接更换为要输出的中文内容.. 2、应用上能够做到的就是尽管合理的使用模组,不使用华而不实的模组,模块使用太多是很消耗cpu的。 3、在使用中能够做到的就是处理好内容组织:其实,我觉得这一个是很多的人都忽略了的,举例说,很多的人都喜欢把一个网站的所有信息都调用到首页,最近评论,论坛最新主题,活跃主题,最新用户,最新公告,用户排名榜等等,太多太多的信息放置在首页上,可能这样有利于做一个针对于搜索引擎的索引,事实上对用户的访问就吃力了,就算启用了cache机制,但是对第一次访问的用户来说,这简直就是一种折磨..事实上我们可以分开列出一些页面如/recent /recent_comments
/ v; u. M7 G+ {5 D# j( r/active_topic;/we_r_newbie;/user_by_points 等等页面, 或者说重新设计首页,把这些内容综合起来,用户可以根据自己的需要访问不同的页面等等..减少首页的数据库访问负载分担给网站的分页面,让用户对网站的第一印象稍微改善一些.. 0 U* _6 a( g9 ` h0 W
|