navicat报错 2003 Can‘t connect to MySQL server on localhost (10061) 以及 2059解决方式

本文提供了一种解决MySQL服务无法安装及启动的方法,包括查找安装路径、使用管理员权限安装服务、初始化数据库、设置密码及解决Navicat连接错误等步骤。

最近连续两次遇到这个问题,网络上千篇一律的开启mysql服务无法解决问题,每次都花了几个小时来找资料解决。记录一下,下次少花点时间。

文中所有命令在管理员身份下执行:

1、在服务中找到mysql的安装路径:
在这里插入图片描述
2、以管理员身份进入mysql安装路径bin目录下(此时输入密码会报错);

3、输入mysqld --install;
安装数据库服务
正常情况会输出 Service successfully installed;
若报错 install/Remove of the Service Denied 则执行3.1 3.2!

3.1 输入sc query mysql;
3.2 输入 sc deletemysql;

在这里插入图片描述
4、输入: mysqld --initialize --user=root --console
初始化
如果出现上图中的ERROR,则删除mysql安装目录下与bin同级的data文件夹(data为之前的数据库数据,建议备份)后再执行命令:

root@localhost后面内容为初始密码

删除data后运行成功
5、启动mysql服务,并输入密码:
修改密码
6、输入:

alter user ‘root’@‘localhost’ inentified by ‘123456’;

修改密码成功,修改密码为123456。

7、navicat连接报错 2059 - authentication plugin…:
查看加密方式并进行更改
8、连接成功:
navicat连接成功
9、恢复数据:
先停止mysql服务:
先暂停mysql服务
将原本data文件夹复制到当前data文件夹下。
开启mysql服务,重新连接。
数据恢复成功

### 错误原因分析 Navicat 连接 MySQL 时出现错误 `2003 - Can't connect to MySQL server on 'localhost' (10061)` 通常意味着客户端无法与 MySQL 服务器建立连接。可能的原因包括: - **MySQL 服务未运行**:如果 MySQL 服务没有启动,Navicat 将无法连接到数据库服务器。 - **端口问题**:MySQL 默认使用 3306 端口,如果该端口被占用、关闭或配置错误,连接请求将被拒绝。 - **防火墙或安全软件限制**:本地或远程防火墙设置可能阻止了对 MySQL 端口的访问。 - **主机名配置错误**:如果连接时使用了错误的主机名或 IP 地址,也会导致连接失败。 - **MySQL 配置文件问题**:`my.cnf` 或 `my.ini` 文件中的配置(如 `bind-address`)可能限制了本地或远程连接。 ### 解决方法 #### 1. 确认 MySQL 服务是否正在运行 在 Windows 上,可以通过以下方式检查 MySQL 服务状态: ```bash services.msc ``` 找到 MySQL 服务(例如 `MySQL80`),确保其状态为“正在运行”。如果不是,请右键选择“启动”或使用命令行启动服务: ```bash net start MySQL80 ``` 在 Linux 系统中,使用以下命令检查 MySQL 服务状态: ```bash systemctl status mysql ``` 如果服务未运行,启动它: ```bash sudo systemctl start mysql ``` #### 2. 检查 3306 端口是否监听 使用以下命令查看 3306 端口是否被 MySQL 占用: ```bash sudo netstat -anp | grep 3306 ``` 如果未看到类似 `tcp6 0 0 :::3306 :::* LISTEN` 的输出,则说明 MySQL 没有正常监听该端口。此时需要检查 MySQL 配置文件 `my.cnf` 或 `my.ini` 中的 `port` 设置是否正确,并确保没有其他程序占用 3306 端口。 #### 3. 防火墙设置 在 Linux 上,使用 `ufw` 或 `iptables` 检查防火墙规则是否允许 3306 端口: ```bash sudo ufw status ``` 如果未开放 3306 端口,执行以下命令: ```bash sudo ufw allow 3306/tcp ``` 在 Windows 上,确保防火墙允许 MySQL 通过入站规则。可以临时禁用防火墙进行测试。 #### 4. 检查 MySQL 配置文件 MySQL 的配置文件通常位于以下路径: - Windows:`C:\ProgramData\MySQL\MySQL Server 8.0\my.ini` - Linux:`/etc/mysql/my.cnf` 或 `/etc/my.cnf` 检查 `bind-address` 配置项: ```ini bind-address = 127.0.0.1 ``` 如果设置为 `0.0.0.0`,则表示允许所有 IP 连接;如果设置为特定 IP,则需确保连接使用的主机名或 IP 与其一致。 #### 5. 更改服务路径(Windows) 如果 MySQL 服务的安装路径与实际路径不一致,可以通过以下方式修改服务路径: 1. 打开命令提示符并执行: ```bash sc config MySQL80 binPath= "D:\MySQL\bin\mysqld.exe --defaults-file=D:\MySQL\my.ini MySQL80" ``` 2. 重启服务: ```bash net stop MySQL80 net start MySQL80 ``` #### 6. 检查 Navicat 连接设置 确保 Navicat 中的连接参数如下: - 主机名/IP 地址:`localhost` 或 `127.0.0.1` - 端口:`3306` - 用户名和密码:正确无误 尝试使用 `127.0.0.1` 替代 `localhost`,因为某些系统在解析 `localhost` 时可能存在差异。 #### 7. 数据恢复与重装(极端情况) 如果 MySQL 数据库损坏,可以尝试以下步骤: 1. 停止 MySQL 服务: ```bash net stop MySQL80 ``` 2. 备份当前 `data` 文件夹,并将原备份数据复制回 `data` 目录。 3. 启动 MySQL 服务: ```bash net start MySQL80 ``` 4. 使用 Navicat 重新连接数据库。 ###
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值