mysql 设置从tcp连接不上_mysql 可以从 TCP 连接但是不能从 socket 链接

ERROR 2002 (HY000): Can’t connect to local MySQL server through socket ‘/var/run/mysqld/mysqld.sock’ (2)

服务器上的 mysql 原本是正常的,突然本地无法从 socket 进行连接,也没有 mysqld.sock 文件。本地和远程通过 tcp 都是可以链接的。

我现在修复了,但是不确定是不按照如下方式修复的(可能是凑巧了),大家可以试试。

删除/var/lib/mysql 下的文件,然后重启服务。

sudo find / -type s 就可以找到 mysql.sock了,根据其位置重新设置一下

ini 文件中的路径

但是这样会导致 innodb损毁出现表找不到。所以要先备份。

mysql> show variables like "%sock%";

看一下mysql启动的时候sock文件放到哪里了,本地使用mysql客户端连接的时候

-S /tmp/mysql.sock

指定。如果这个文件不存在要么被误删、要么没权限写,看一下mysql日志。

轻易就把

/var/lib/mysql

数据文件目录给删了,服了

表述有问题吧,socket不是对tcp/ip的一层封装么?

看看文件还在不在,有没有权限,是不是和MySQL的设置一致。如果以前是好的,那么不排除被误删除或更改了权限的可能。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值