用drupal开发网站的时候,经常会遇到白屏(WSOD,White Screen Of Death)。 白屏的原因,有很多种,其中一种是缓存中表项内容错乱所引起的,下面就介绍此原因对应的解决办法:清除缓存表项。
5 A& `# Y% a9 p9 `- S5 w6 C1.当白屏的时候,有时候是可以进入主页的。如果可以进入主页,安装了devel模块+Administration menu模块的情况下,是可以通过 鼠标移动到左上角->Flush All Cache,去清除所有缓存,或者Flush All Caches -> Cache Tables,只清除表项的缓存,来试图解决白屏的问题。
+ @6 r4 l3 @7 Q) }- q! [7 M2.但是很多时候,白屏的时候,是连主页也进入不了的,所以就要想别的办法去实现清除表项。 - A3 s2 ?6 w0 e' ~* F6 j# e
此法有老外已经整理了: Clearing Drupal's cache to recover from WSODs
' b8 ^9 ]/ G9 j8 i/ }0 j! u \简单翻译和整理如下(假定你是用的PhpMyAdmin来管理MySQL数据库的): 1.登陆PHPMyAdmin 2.左边那一列中,找到你当前drupal网站所使用的数据库,并点击之。 / _3 i1 V, T2 X: d: w

+ N# H5 z- ]( ]
3. 数据库的表项会在左栏显示,找到“cache”并点击之。 ' @4 S/ z5 x% o \

9 }9 i3 E% b6 @' n9 {) R' e5 @
4. 在cache表中的项就会在右边主页面中显示了。在页面顶部右上角有个“Empty”: 8 p" @" C0 r U3 f, H; x
 " [! J! a5 s' j0 Y) J. F
意思是清空(缓存)。点击“Empty”,会弹出对话框问你是否真的想要清空(数据库操作中对应的是TRUNCATE),点击“确定”。 , q ?' k# Q D8 z8 R7 M4 f% u
 $ S$ r2 W2 Q$ B
5. 此时就可以清除表项的缓存了。回到你的浏览器中,重新多刷新几次页面,(如果是缓存表项错乱所引起白屏的话),那么此时你可以可以看到你的drupal网站又可以正常显示了,^_^。 % N4 G/ I- a. k% a
|