从X3.4升级到3.5,是个折磨的过程。涉及到从GBK转码到UTF-8,对数据库的操作是彻底的,中间反复了十多次才最终成功。总结如下几个务必注意的几个问题:
! _9 F; a8 a$ H7 O) m9 f& r1 K( h& E1 u* n
+ s- {1 a1 E* x5 O
1、严格按照官方教程操作,中间不要有任何多余步骤,尤其是是升级UCenter到1.7.0成功后,不要通过浏览器访问论坛程序,否则极易导致数据库出错从而升级失败。0 z* m# C J/ M- f
$ n f' m8 r! r1 L" }
2、最好卸载所有非官方插件、卸载所有不适合于X3.5的插件,并更新缓存、校验数据库,在保证X3.4的数据库无误的前提下再升级。
/ M: k- W$ u, z6 `( @" |1 n/ e- x, p* `0 M
3、升级一旦卡住,只能清空数据库,导入原来数据库后,再依次重新升级UCenter、DX,所以务必做好X3.4的程序文件和数据库的备份,以便随时恢复。' p5 q1 v5 b3 r6 T }
+ F5 w2 a# R+ X4 r1 c3 c/ [ i" r
+ k9 u. k7 b7 P# m5 }/ M4、升级Ucenter到1.7.0之前,最好先查看X3.4的数据库的pre_ucenter_members数据表,在phpmyadmin里点击该数据表,点击“结构”,在mail字段的最后点击修改,为其添加索引(如果已有索引,不可重复)。 d/ c: G, y! T2 B5 u8 v2 _
# R- C$ P2 \& @" q( E/ E! P5、数据库里如果有非官方插件添加的数据表,因为目前绝大多数插件尚不支持新版dx程序,所以最好都删除掉。当然,理论上应该不会影响升级。, G/ H3 g1 C+ w. `
2 ^6 H" I; }, X' [6、Ucenter的升级通常比较容易成功。如果有其他问题,先到官网搜索解决办法。如果成功了,严格按照官方教程进行下一步,不要有任何其他操作!一旦访问网页程序,可能导致对数据库有读写操作,极易出错,导致UC与dx通信失败、涉及文件检测环境“不满足”等。这种情形,在官网论坛有一些修改方法,但通常可能只有重新操作,才可能成功,修改config等配置文件很可能最终还是失败。
- D. [! L2 R4 |: T0 A3 q" y1 f" B
7、因为数据库较大,曾经做过“帖子分表”操作的,一旦运行DX3.5的升级文件,可能会遇到某些字段不唯一、未设置主键等数据库问题,从而导致升级失败,只能从头再操作。所以,对于分表,最好是有提前操作,并重启MySQL服务或重启服务器,保证改动生效。
3 e7 |3 T {: @" v- F2 `8 A8 F8 C0 ?- #在数据库中选中帖子分表对应的数据表pre_forum_post_1(主表没有_1后缀)执行SQL语句命令:3 {3 u: p3 k, K9 s, }
- ALTER TABLE pre_forum_post_1 MODIFY COLUMN position INT unsigned NOT NULL DEFAULT '0'
复制代码 8、之后再运行dx升级程序,通常检测通过,一路绿灯。之后最好重启服务器,以便更新所有与网站有关的缓存,保证后续操作的效果。2 K- i; v, K O5 z! T- Z" H
. z2 r& w2 F4 c9、升级DX3.5成功后,先访问UC后台,确认通信成功后,再通dx后台进行其他操作。! E- m2 V: y) t
8 F) t# G& V3 N希望后来的站长们少走弯路……0 l7 A. ^+ {* x3 b. H X3 ?# R) B* r
|