本文记录MySQL艰难的安装过程。
MySQL 5.7.28 在Windows 10 专业版上安装,总是失败,其原因主要是更新的操作系统(2019年11月)和老旧的安装包mysql-installer-community-5.7.28.0.msi不兼容了。
最关键的点是inno db创建数据库初始文件的时候参数不对,installer安装过程中无法在my.ini中添加如下参数。
innodb_flush_method=normal
可选的一个方法是在官网下载的mysql-5.7.28-winx64.zip,以手工方式配置安装,记录步骤如下:
下载解压安装文件到用户目录下,如C:\Users\Kevin\mysql-5.7.28-winx64;
在安装目录下创建my.ini配置文件,内容如下:
[mysql]
# 设置mysql客户端默认字符集
default-character-set=utf8
[mysqld]
# 设置3306端口
port = 3306
# 设置mysql的安装目录
basedir=C:\Users\Kevin\mysql-5.7.28-winx64
# 设置mysql数据库的数据的存放目录
datadir=C:\Users\Kevin\mysql-5.7.28-winx64\data
# 允许最大连接数
max_connections=200
# 设置mysql服务端默认字符集
character-set-server=utf8
# 创建新表时将使用的默认存储引擎
default-storage-engine=INNODB
# 注意这个参数,MySQL默认值导致在Windows 10 专业版上无法安装
innodb_flush_method=normal
以管理员身份运行命令行工具,并进入安装目录下的bin目录,如C:\Users\Kevin\mysql-5.7.28-winx64\bin>;
执行MySQL初始化命令,在指定的目录中(数据目录配置my.ini配置文件中)初始化数据库,及生成root用户和无密码;
mysqld --initialize-insecure
- 在Windows中安装MySQL系统服务;
mysqld -install
- 启动MySQL服务;
net start mysql
- 登录MySQL数据库,提示输入密码时,直接回车;
mysql -uroot -p
- 修改root用户密码为123456,这里的密码为示意,强烈建议为root用户设置非常复杂的密码;
set password = password('123456');
- 退出MySQL管理端,使用root用户和修改后的密码(例如123456)重新登录;
quit
mysql -uroot -p
- 检查MySQL是否正常;
show databases;
如能正确显示MySQL中的数据库(MySQL初始化时会创建4个数据库),则说明安装成功;
- 使用图形化工具(如Navicat ),连接到MySQL,检查确认数据库是否可以正常使用。
Kevin 2019.11.4,成都。