从X3.4升级到3.5,是个折磨的过程。涉及到从GBK转码到UTF-8,对数据库的操作是彻底的,中间反复了十多次才最终成功。总结如下几个务必注意的几个问题:) y( o M7 x5 u5 C6 ^! `# L7 \
1 Y m. G8 z( w; B/ J9 ~( T3 W0 o% F6 C. g7 o
1、严格按照官方教程操作,中间不要有任何多余步骤,尤其是是升级UCenter到1.7.0成功后,不要通过浏览器访问论坛程序,否则极易导致数据库出错从而升级失败。
4 W& T# o" A3 a8 K# F( k8 A$ u, H; f* E, X1 O# l
2、最好卸载所有非官方插件、卸载所有不适合于X3.5的插件,并更新缓存、校验数据库,在保证X3.4的数据库无误的前提下再升级。
- T) Q% I/ Y* Z$ ^, P; w
+ ?2 Y4 e# l: V' _3、升级一旦卡住,只能清空数据库,导入原来数据库后,再依次重新升级UCenter、DX,所以务必做好X3.4的程序文件和数据库的备份,以便随时恢复。, ~! ~& \: i: q) s
* K" a9 B9 _. n- _" B' [6 ^6 w3 Y, R0 F, o1 u4 d2 Y' j9 G7 d X
4、升级Ucenter到1.7.0之前,最好先查看X3.4的数据库的pre_ucenter_members数据表,在phpmyadmin里点击该数据表,点击“结构”,在mail字段的最后点击修改,为其添加索引(如果已有索引,不可重复)。! x0 n# u' ]+ Z
( ?( e2 c9 k, f. [& A F# X! Y
5、数据库里如果有非官方插件添加的数据表,因为目前绝大多数插件尚不支持新版dx程序,所以最好都删除掉。当然,理论上应该不会影响升级。8 S2 q# o& H; B% H) C0 x
4 u7 {! D) i) h8 Q% Y; h( e6、Ucenter的升级通常比较容易成功。如果有其他问题,先到官网搜索解决办法。如果成功了,严格按照官方教程进行下一步,不要有任何其他操作!一旦访问网页程序,可能导致对数据库有读写操作,极易出错,导致UC与dx通信失败、涉及文件检测环境“不满足”等。这种情形,在官网论坛有一些修改方法,但通常可能只有重新操作,才可能成功,修改config等配置文件很可能最终还是失败。# j( p/ v$ R- y) i) g
3 O8 M) K* ?# m0 m+ Z. V* a7、因为数据库较大,曾经做过“帖子分表”操作的,一旦运行DX3.5的升级文件,可能会遇到某些字段不唯一、未设置主键等数据库问题,从而导致升级失败,只能从头再操作。所以,对于分表,最好是有提前操作,并重启MySQL服务或重启服务器,保证改动生效。
, G9 d7 S3 a4 C- R- #在数据库中选中帖子分表对应的数据表pre_forum_post_1(主表没有_1后缀)执行SQL语句命令:
& C4 P6 V: `$ p( ]. Y - ALTER TABLE pre_forum_post_1 MODIFY COLUMN position INT unsigned NOT NULL DEFAULT '0'
复制代码 8、之后再运行dx升级程序,通常检测通过,一路绿灯。之后最好重启服务器,以便更新所有与网站有关的缓存,保证后续操作的效果。
. Z* G; w% g% F) Q, ]) Y
1 E& X) C( A t3 [9 `8 F$ x3 D9、升级DX3.5成功后,先访问UC后台,确认通信成功后,再通dx后台进行其他操作。' G% c/ I" S; t- k7 T
8 S4 b+ Q% v7 M; S b
希望后来的站长们少走弯路…… S; G1 a9 k; T" G) B1 v
|