安装MySQL8.0时,遇到 MySQL 服务无法启动 服务没有报告任何错误
我是安装在E:\MySQL下的,
1.找到E:\MySQL,新建my.ini文件,在其中写入
[mysql]
# 设置mysql客户端默认字符集
default-character-set=utf8
[mysqld]
# 设置3306端口
port = 3306
# 设置mysql的安装目录
basedir=E:\MySQL
# 设置mysql数据库的数据的存放目录
datadir=E:\MySQL\data
# 允许最大连接数
max_connections=20
# 服务端使用的字符集默认为8比特编码的latin1字符集
character-set-server=utf8
# 创建新表时将使用的默认存储引擎
default-storage-engine=INNODB
保存。
2.找到E:\MySQL\bin中的mysql_config.pl文件,打开
找到其中这几行
my $ldata = 'C:/Program Files/MySQL/MySQL Server 8.0/data';
my $execdir = 'C:/Program Files/MySQL/bin';
my $bindir = 'C:/Program Files/MySQL/bin';
# ----------------------------------------------------------------------
# If installed, search for the compiled in directory first (might be "lib64")
# ----------------------------------------------------------------------
my $pkglibdir = fix_path('C:/Program Files/MySQL/lib',"libmysql/relwithdebinfo",
"libmysql/release","libmysql/debug","lib/mysql","lib");
my $pkgincludedir = fix_path('C:/Program Files/MySQL/include', "include/mysql", "include");
将其改为你的sql安装安装路径,我的安装路径是E:\MySQL,datadir是E:\MySQL\data
my $ldata = 'E:/MySQL/data';
my $execdir = 'E:/MySQL/bin';
my $bindir = 'E:/MySQL/bin';
# ----------------------------------------------------------------------
# If installed, search for the compiled in directory first (might be "lib64")
# ----------------------------------------------------------------------
my $pkglibdir = fix_path('E:/MySQL/lib',"libmysql/relwithdebinfo",
"libmysql/release","libmysql/debug","lib/mysql","lib");
my $pkgincludedir = fix_path('E:/MySQL/include', "include/mysql", "include");
3.以管理员身份运行cmd,输入:mysqld -install(如果不用管理员身份运行,将会因为权限不够而出现错误:Install/Remove of the Service Denied!)
4.运行mysqld --initialize(标题问题所在,若没有init则不存在data目录,自然无法启动成功)
5.安装成功后就要启动服务了,继续在cmd中输入:net start mysql,服务启动成功!
6.服务启动成功之后,就可以登录了
在mysql目录下搜索*.err,以文本形式打开才能看到如下内容:
016-02-25T15:09:43.033062Z 1 [Note] A temporary password is generated for root@localhost: >mso 红色字母即为第一次的登陆密码 输入 mysql -u root -p 回车,再输入上面获取的临时密码即可登录。 参考:https://www.cnblogs.com/nuomin/p/8179394.html