mysql启动失败:mysql服务无法启动 服务没有报告任何错误 排查过程及解决方法

mysql启动失败:mysql服务无法启动 服务没有报告任何错误 排查过程及解决方法

一直使用Navicat连接远程数据库,在心血来潮连接本地数据时发现无法连接。下面是我的排查过程及解决方法。


排查过程如下:
- 1、使用“net start mysql”命令启动mysql服务,结果失败;
- 2,手动开启mysql服务时发现计算机“服务”列表中没有mysql;

结论:mysql没有安装
PS:前面提到过我一直使用Navicat连接远程数据库,不知道本地Mysql服务和Navicat的使用是不是相互独立的。

解决一: 下载Mysql 5.7.17

我下载的是ZIP Archive版,解压后按以下步骤安装服务。
- 1、新建my.ini;

.ini文件是window里面的配置文件。保存里面各种默认的数据。安装版的是在安装的时候让你自己选然后系统给你保存进来,zip archive是自己写,都一样。
my.ini会替换掉下面的my-default.ini文件

代码如下:(把里面D:\mysql\mysql-5.7.17-winx64改成你自己的软件路径,保存)

[mysql]
# 设置mysql客户端默认字符集
default-character-set=utf8 
[mysqld]
#设置3306端口
port = 3306 
# 设置mysql的安装目录
basedir=D:\Mysql\mysql-5.7.17-winx64
# 设置mysql数据库的数据的存放目录
datadir=D:\Mysql\mysql-5.7.17-winx64\data
# 允许最大连接数
max_connections=200
# 服务端使用的字符集默认为8比特编码的latin1字符集
character-set-server=utf8
# 创建新表时将使用的默认存储引擎
default-storage-engine=INNODB
  • 2、以管理员的身份运行cmd.exe,切换目录至解压文件的bin目录下。
    运行” mysqld –install “命令,成功后运行“net start mysql”
问题来了,运行“net start mysql”命令,出错!

mysql启动失败:mysql服务无法启动 服务没有报告任何错误

如图所示,安装提示成功,开启服务失败。

之后查到运行“mysqld - -console ”命令可以显示出启动错误信息。
谨慎起见,我想看下mysql是否真的安装成功。

于是,执行命令“mysqld –remove”将其删除并重新运行” mysqld –install “命令进行安装。提示成功。
执行” mysqld - -console “命令。果然有问题。
找不到data文件夹

可以看到,my.ini中用的一个名为data的文件,需要我们手动添加。或者也可以通过命令”mysqld –initialize “初始化data目录

重新上面步骤,发现又有了一个新的错误。
这里写图片描述

其中第一个错误有提示。“run mysql——upgrade”。于是我在bin目录下找到它并执行。
这里写图片描述

看到“localhost”,我突然想起来之前开发时好像有改过本地域名!!
于是”C:\Windows\System32\drivers\etc\hosts“果然!⊙﹏⊙b汗
这里写图片描述

取消注释!

重新执行上述命令,成功!
这里写图片描述

连接成功!
这里写图片描述


心得:作为一个新手菜鸟,在开发过程中遇到错误总是很慌张,完全不知道该从何下手,这个时候心我往往是找身边的大牛来帮忙看,但其实像这种不是经常碰到的问题其实大牛们一开始也是不清楚的。虽然不清楚,但他们却能淡定地抽丝剥茧,逐步排查并找到问题所在。这一次,我决定自己尝试去找出问题,并记录下来。虽然过程并不像上面写的那么顺畅,但最终我还是找到了!(尽管最后知道真相的我眼泪掉下来。)
我的第一篇博客,算是我开发生涯成长的一个见证!同时也希望能够帮到跟我遇到同样问题的朋友。

  • 34
    点赞
  • 77
    收藏
    觉得还不错? 一键收藏
  • 22
    评论
评论 22
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值