建站学院

当前位置:

Discuz如何解决安装时报错run_sql_error

浏览量:579次

本文实现功能解决在MySQL8.0安装discuz报错run_sql_error如果想直接看解决结果,直接去看解决问题目录

问题环境

  1. VMware虚拟机

  2. Centos7.3

  3. PHP7.0

  4. MySQL8.0

  5. NGINX1.14

  6. Discuz3.4

问题还原

本地环境为PHP5.6+MySQL5.6在安装discuz没有任何问题。

在虚拟机的centos上出现以下问题MySQL的表无法创建,安装报错

image.png

宿主机使用Xsheel和Ftp

由于在centos的终端截图不方便,下面的所有环境修改都会在xshell上进行操作,并且直接在宿主机上访问。

关于配置如何使用xsheel连接虚拟机

连接模式为NAT,并且已经安装了tools

image.png

使用xsheel连接,在虚拟机使用ifconfig查看ip地址

image.png

然后进行连接,需要输入账号密码,账号密码就是你的虚拟机账号密码

image.png

连接成功就是以下样子,可以输入PHP -v来查看PHP版本信息

image.png

还有一个就是ftp,由于需要传输点东西所以也使用了宿主机的ftp连接了虚拟机。同理也是输入ip地址并且端口为22

image.png

连接成功后就可以获取到虚拟机的文件

image.png

解决问题

这个问题的根源就是在MySQL的版本上。discuz支持的版本为PHP5.3.但是所有的数据库文件都是在MySQL5.5上创建的。所以就会造成字符集乱码的情况。

这个时候我们打开/etc/my.ini,这个是默认的一些配置,下面的那个mysqldump不用管,那个是咔咔在之前配置MySQL主从复制以有数据的情况配置的。

image.png

在这个文件里边加上以下代码

init_connect='SET NAMES utf8'

default-storage-engine=INNODB
character-set-server=utf8
collation-server=utf8_general_ci

default_authentication_plugin=mysql_native_password
登录后复制

[声明]本网转载网络媒体稿件是为了传播更多的信息,此类稿件不代表本网观点,本网不承担此类稿件侵权行为的连带责任。故此,如果您发现本网站的内容侵犯了您的版权,请您的相关内容发至此邮箱【915688610@qq.com】,我们在确认后,会立即删除,保证您的版权。