windows安装mysql8.0.16踩了的坑

时间: 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>

成功,心下一爽。

 

问题的发生原因往往是因为忽略一些细节,细心谨慎才不会犯低级错误。

勉之。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值