Ubuntu 安装MySQL8 解决配置lower_case_table_names=1后启动失败

目录

一、问题描述

二、原因分析

三、解决方法


一、问题描述

同命令sudo apt-get install mysql-server安装后,检查mysql服务状态为:running。

修改/etc/mysql/mysql.conf.d/mysqld.cnf文件,新增和修改内容如下:

复制代码
bind-address = 0.0.0.0
lower_case_table_names=1
character_set_server=utf8

重启服务,启动报错,无法启动。

二、原因分析

mysql 8版本在安装完成后会立即启动,并完成数据库初始化,而且不再支持从mysqld.cnf文件中修改lower_case_table_names等参数。

三、解决方法

不必重新按装,但需要重新初始化数据库 ,过程如下:

1、删除数据后,确认正确配置lower_case_table_names

复制代码
sudo rm -rf /var/lib/mysql
vim /etc/mysql/mysql.conf.d/mysqld.cnf
bind-address = 0.0.0.0
lower_case_table_names=1
character_set_server=utf8

2、手动初始化

复制代码
mkdir /var/lib/mysql
chown mysql:mysql /var/lib/mysql
mysqld --initialize --user=mysql --lower-case-table-names=1

3、启动后获取root密码并登陆验证并修改密码

复制代码
service mysql start
grep password /var/log/mysql/error.log

4、使用以上密码登陆并修改root密码:

复制代码
mysql -uroot -p
ALTER USER 'root'@'localhost' IDENTIFIED with mysql_native_password BY '123456';
create USER 'root'@'%' IDENTIFIED with mysql_native_password BY '123456';
grant all on *.* to  'root'@'%';
flush privileges;

5、重启后登陆验证:

复制代码
show variables like '%character%';
show variables like '%lower_case%';

6、完全卸载 mysql

复制代码
systemctl stop mysql
sudo apt remove --purge mysql-* -y
sudo apt autoremove -y
sudo rm -rf /etc/mysql
sudo rm -rf /var/lib/mysql
sudo rm -rf /var/log/mysql