十里青山 发表于 2023-9-16 23:35:53

更新Discuz! X3.5的经验之谈

从X3.4升级到3.5,是个折磨的过程。涉及到从GBK转码到UTF-8,对数据库的操作是彻底的,中间反复了十多次才最终成功。总结如下几个务必注意的几个问题:


1、严格按照官方教程操作,中间不要有任何多余步骤,尤其是是升级UCenter到1.7.0成功后,不要通过浏览器访问论坛程序,否则极易导致数据库出错从而升级失败。

2、最好卸载所有非官方插件、卸载所有不适合于X3.5的插件,并更新缓存、校验数据库,在保证X3.4的数据库无误的前提下再升级。

3、升级一旦卡住,只能清空数据库,导入原来数据库后,再依次重新升级UCenter、DX,所以务必做好X3.4的程序文件和数据库的备份,以便随时恢复。


4、升级Ucenter到1.7.0之前,最好先查看X3.4的数据库的pre_ucenter_members数据表,在phpmyadmin里点击该数据表,点击“结构”,在mail字段的最后点击修改,为其添加索引(如果已有索引,不可重复)。

5、数据库里如果有非官方插件添加的数据表,因为目前绝大多数插件尚不支持新版dx程序,所以最好都删除掉。当然,理论上应该不会影响升级。

6、Ucenter的升级通常比较容易成功。如果有其他问题,先到官网搜索解决办法。如果成功了,严格按照官方教程进行下一步,不要有任何其他操作!一旦访问网页程序,可能导致对数据库有读写操作,极易出错,导致UC与dx通信失败、涉及文件检测环境“不满足”等。这种情形,在官网论坛有一些修改方法,但通常可能只有重新操作,才可能成功,修改config等配置文件很可能最终还是失败。

7、因为数据库较大,曾经做过“帖子分表”操作的,一旦运行DX3.5的升级文件,可能会遇到某些字段不唯一、未设置主键等数据库问题,从而导致升级失败,只能从头再操作。所以,对于分表,最好是有提前操作,并重启MySQL服务或重启服务器,保证改动生效。
#在数据库中选中帖子分表对应的数据表pre_forum_post_1(主表没有_1后缀)执行SQL语句命令:
ALTER TABLE pre_forum_post_1 MODIFY COLUMN position INT unsigned NOT NULL DEFAULT '0'8、之后再运行dx升级程序,通常检测通过,一路绿灯。之后最好重启服务器,以便更新所有与网站有关的缓存,保证后续操作的效果。

9、升级DX3.5成功后,先访问UC后台,确认通信成功后,再通dx后台进行其他操作。

希望后来的站长们少走弯路……
页: [1]
查看完整版本: 更新Discuz! X3.5的经验之谈