解决ERROR 2003 (HY000): Can‘t connect to MySQL server on ‘localhost‘ (111)的问题

10 篇文章 0 订阅

在这里插入图片描述


Can‘t connect to MySQL server on ‘localhost‘

最近在学习Django框架,于是在windows系统上搭建了Django环境,并使用虚拟机ubuntu系统上安装的mysql作为项目的远程数据库,前几天一直用得好好的,今天在虚拟机上连接数据库时,
在这里插入图片描述
出现了如下错误:
在这里插入图片描述

本地数据库没法连接,第一反映是查看下mysql数据库是否启动,使用如下命令查看:
在这里插入图片描述

发现mysql是正常启动状态。仔细思考了下,既然mysql是正常启动的,本地连接不上,是否和mysql绑定ip有关,因为之前将其作为远程数据库使用的,因此对其绑定的ip进行了修改。
切换到对应路径,打开mysql配置文件:
在这里插入图片描述

在这里插入图片描述

可以看到绑定的ip地址为192.168.xx.xxx,这是当时设置mysql远程连接时ubuntu的ip地址

使用ip addr命令查看当前系统的ip,发现系统ip为192.168.17.129可见在我重启电脑的时候电脑的ip改变过。对于作为远程数据库的电脑来说,如果ip地址会改变显然不是长久之计,关于这个问题,稍后会详细研究,此处只是记录下暂时解决当前问题的方法。

既然绑定ip与系统ip不一致,当然要把绑定ip改一下,将mysql配置文件中的bind-address改为系统ip地址:192.168.17.129,输入:wq保存,发现该文件为只读文件,先退出文件修改其权限然后再对其进行修改。
查看当前文件的权限,普通用户只有可读权限
在这里插入图片描述

采用以下命令修改当前文件权限
在这里插入图片描述

再次修改mysql配置文件,就可以成功修改保存了。
再次连接mysql数据库,输入密码后发现是可以连接的,但是上面有一句警告:mysql: [Warning] World-writable config file ‘/etc/mysql/mysql.conf.d/mysqld.cnf’ is ignored这是由于我们刚刚改过mysql配置文件导致的。
在这里插入图片描述

为了防止mysql配置文件被随意改动,可以将其权限再改为只读。
在这里插入图片描述

查看其权限发现普通用户只有可读权限。

再次打开mysql,就没有刚才那句警告啦。

至此,问题已经解决,可以使用mysql进行后续操作啦

  • 5
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 4
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

敲代码敲到头发茂密

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值