ERROR 2003: Can't connect to MySQL server on 'localhost' (10061)

本文记录了一次系统重装后MySQL服务无法启动的问题排查过程。通过调整服务安装路径和配置文件设置,最终解决了ERROR2003无法连接到MySQL服务器的问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

昨晚中刀了,系统不得不重装,好在Netbeans啊,MySQL, Tomcat之类的东西装在其他盘符,所以损失不大。

一早重灌系统后,试试Netbeans。Tomcat启动正常,MySQL倒是有点问题。
Services - Databases - Register MySQL database
因为MySQL安装目录什么都没有改变,所以MySQL Server Properties 安照之前配置;
但是配置完毕后MySQL Server at localhost:3306 显示not connected。
想想大概是重装系统后,没有添加服务的关系,于是在系统里添加路径,
然后在Start- command -cmd Dos窗口里直接输入
mysqld-nt --install MySQL50 --defaults-file="I:\Program Files\MySQL\MySQL Server 5.0\my.ini" (MySQL安装在I:\Program Files\MySQL\MySQL Server 5.0\)
提示Service installed。但是运行service提示:
ERROR 2003: Can't connect to MySQL server on 'localhost' (10061)开始考虑到是不是防火墙关系,关闭防火墙问题依旧,并发现同样使用localhost的Java DB运行ok,
想来不是localhost的问题,检查services 发现MySQL50的服务并没有运行,再看MySQL服务属性
Path to executable的设置上,mysqld-nt的位置被设置在C:\了,问题就在这里,原来服务装错了。

发现问题了,可是如何删除(修改)服务又成了新问题,在dos窗口想用mysql-nt -remove来删除服务,提示服务没有安装。
最后只能直接在注册表里修改的方法:
Start - command - regedit
\HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services、MySQL50
ImagePath 将错误的路径改成 "I:\Program Files\MySQL\MySQL Server 5.0\bin\mysqld-nt"--defaults-file="I:\Program Files\MySQL\MySQL Server 5.0\my.ini" MySQL50
完了,服务里启动MySQL50 服务,Netbeans里MySQL连接测试ok!

总结: 所谓的ERROR 2003: Can't connect to MySQL server on 'localhost' (10061) 估计应该是MySQL服务没有正常运行造成的,
所以只要重新正确启动MySQL服务,问题就迎刃而解了!

--转自internal
根据你提供的引用内容,出现"ERROR 2003 (HY000): Can't connect to MySQL server on 'localhost' (10061)"错误通常是由于以下几个原因导致的: 1. MySQL服务器未启动:请确保MySQL服务器已经成功启动。你可以在终端中输入以下命令来检查MySQL服务器的状态: ```shell sudo service mysql status ``` 如果MySQL服务器未启动,你可以使用以下命令来启动它: ```shell sudo service mysql start ``` 2. MySQL服务器监听的IP地址不正确:请确保MySQL服务器配置文件中的bind-address参数设置为正确的IP地址。你可以编辑MySQL配置文件(通常是/etc/mysql/mysql.conf.d/mysqld.cnf)并将bind-address参数设置为正确的IP地址,例如: ```shell bind-address = 0.0.0.0 ``` 然后重新启动MySQL服务器。 3. 防火墙阻止了连接:请确保防火墙允许从本地主机连接到MySQL服务器的端口(默认为3306)。你可以使用以下命令来打开防火墙的3306端口: ```shell sudo ufw allow 3306 ``` 如果你使用的是其他防火墙软件,请根据其文档或配置文件进行相应的设置。 4. MySQL用户权限问题:请确保你使用的MySQL用户具有从远程主机连接到MySQL服务器的权限。你可以使用以下命令来为用户授予远程访问权限: ```shell GRANT ALL PRIVILEGES ON *.* TO 'username'@'%' IDENTIFIED BY 'password' WITH GRANT OPTION; ``` 其中,'username'是你要授予权限的用户名,'password'是该用户的密码。请注意,这样做会允许任何远程主机连接到MySQL服务器,请谨慎使用。 如果你仍然无法解决问题,请提供更多关于你的环境和配置的详细信息,以便我们能够更好地帮助你解决问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值