时间: 2019-08-27
方式: 压缩包安装
安装包下载: https://www.mysql.com/downloads/
操作路径:
1. 加压压缩包比如: D:\server\mysql-8.0.16-winx64
2. 安装:
> D:
> cd D:\server\mysql-8.0.16-winx64\bin // 切换到mysql目录
> mysql --initialize --console // 初始化,此处控制台会输出一个初始root密码,需要记住
> mysqld --install mysql8 // 注册到windows服务
然后
> net start mysql8 // 启动mysql服务
启动成功,连上去
> mysql -u root -p
输入初始密码,死活登录不上,提示密码不正确。
检查了步骤,确实没有问题, 后来设置了my.ini
[mysqld]
# 设置3306端口
port=3306
# 自定义设置mysql的安装目录,即解压mysql压缩包的目录
basedir=D:/server/mysql-8.0.16-winx64
# 自定义设置mysql数据库的数据存放目录
datadir=D:/server/mysql-8.0.16-winx64/data
# 允许最大连接数
max_connections=200
# 允许连接失败的次数,这是为了防止有人从该主机试图攻击数据库系统
max_connect_errors=10
# 服务端使用的字符集默认为utf8mb4
character-set-server=utf8mb4
# 创建新表时将使用的默认存储引擎
default-storage-engine=INNODB
# 默认使用“mysql_native_password”插件认证
default_authentication_plugin=mysql_native_password
# 时区设置
default-time-zone='+8:00'
[mysql]
# 设置mysql客户端默认字符集
default-character-set=utf8mb4
[client]
# 设置mysql客户端连接服务端时默认使用的端口和默认字符集
port=3306
default-character-set=utf8mb4
指定启动配置:
> mysqld --remove mysql8
Service successfully removed.
> mysqld --install mysql8 --defaults-file=c:/my.ini
然后net start mysql8
系统出错
发生系统错误 1067
进程意外终止
检查了下,自己操作其实是没问题的。为什么有这个错误呢?之后在windows服务里去查看了下mysql8服务的属性:
D:\server\mariadb\bin\mysqld --defaults-file=c:/my.ini mysql8
这里有问题了,安装的mysql服务实际上指向的是mariadb的mysqld。我实际操作的实际上mysql8下的mysqld,查看了自己windows path中的信息,存在D:\server\mariadb\bin\,也就是mysql8下mysqld在安装服务的时候使用了windows path里的mysql信息。
更改path配置D:\server\mariadb\bin为D:\server\mysql-8.0.16-winx64\bin,重复:
mysqld --remove mysql8
mysqld --install mysql8 --defaults-file=c:/my.ini
net start mysql8
mysql -u root -p
Enter password: ************
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 8
Server version: 8.0.16
Copyright (c) 2000, 2019, Oracle and/or its affiliates. All rights reserved.
Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
mysql>
成功,心下一爽。
问题的发生原因往往是因为忽略一些细节,细心谨慎才不会犯低级错误。
勉之。