从X3.4升级到3.5,是个折磨的过程。涉及到从GBK转码到UTF-8,对数据库的操作是彻底的,中间反复了十多次才最终成功。总结如下几个务必注意的几个问题:
$ D# o9 z1 \8 s9 }. Q
3 X1 @8 u9 {$ a9 e( B; z. D' v! r+ J0 i
1、严格按照官方教程操作,中间不要有任何多余步骤,尤其是是升级UCenter到1.7.0成功后,不要通过浏览器访问论坛程序,否则极易导致数据库出错从而升级失败。6 Y5 k5 \0 c+ j" m
7 m- O& A1 z- K7 D1 U+ ~( A
2、最好卸载所有非官方插件、卸载所有不适合于X3.5的插件,并更新缓存、校验数据库,在保证X3.4的数据库无误的前提下再升级。# X4 K/ B) e( u" |
/ O/ Y, k' y* R( I4 E" n4 [. V9 Z
3、升级一旦卡住,只能清空数据库,导入原来数据库后,再依次重新升级UCenter、DX,所以务必做好X3.4的程序文件和数据库的备份,以便随时恢复。
& R8 N ?0 \1 L
+ g( N8 w0 Q+ s9 D
1 A* s: y" H/ {+ J" T9 J% O4、升级Ucenter到1.7.0之前,最好先查看X3.4的数据库的pre_ucenter_members数据表,在phpmyadmin里点击该数据表,点击“结构”,在mail字段的最后点击修改,为其添加索引(如果已有索引,不可重复)。( e; y& c9 h( K4 t1 S
# T$ ?! _- m, V' ]5、数据库里如果有非官方插件添加的数据表,因为目前绝大多数插件尚不支持新版dx程序,所以最好都删除掉。当然,理论上应该不会影响升级。9 D# E9 a1 z1 n! @
2 c; c9 N4 g5 d6、Ucenter的升级通常比较容易成功。如果有其他问题,先到官网搜索解决办法。如果成功了,严格按照官方教程进行下一步,不要有任何其他操作!一旦访问网页程序,可能导致对数据库有读写操作,极易出错,导致UC与dx通信失败、涉及文件检测环境“不满足”等。这种情形,在官网论坛有一些修改方法,但通常可能只有重新操作,才可能成功,修改config等配置文件很可能最终还是失败。
( n% c# l2 D6 g; Z) G
7 {9 u' L9 n! j6 @7、因为数据库较大,曾经做过“帖子分表”操作的,一旦运行DX3.5的升级文件,可能会遇到某些字段不唯一、未设置主键等数据库问题,从而导致升级失败,只能从头再操作。所以,对于分表,最好是有提前操作,并重启MySQL服务或重启服务器,保证改动生效。
( g2 t9 O* J- k- #在数据库中选中帖子分表对应的数据表pre_forum_post_1(主表没有_1后缀)执行SQL语句命令:) U, k6 R$ V: |2 ]
- ALTER TABLE pre_forum_post_1 MODIFY COLUMN position INT unsigned NOT NULL DEFAULT '0'
复制代码 8、之后再运行dx升级程序,通常检测通过,一路绿灯。之后最好重启服务器,以便更新所有与网站有关的缓存,保证后续操作的效果。
) R2 B X; _, \' H' `8 t
+ e/ o# G1 N# J+ A. L$ i9、升级DX3.5成功后,先访问UC后台,确认通信成功后,再通dx后台进行其他操作。
4 x% X1 W" V9 k6 K# ?, v( R
' O1 y# w# W) t希望后来的站长们少走弯路……
3 W+ M" B- v, A3 L" V |