mysql 可以从 TCP 连接但是不能从 socket 链接

 le__citron 发布于 2022-11-06 12:30

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损毁出现表找不到。所以要先备份。

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

    2022-11-12 01:48 回答
  • 表述有问题吧,socket不是对tcp/ip的一层封装么?

    2022-11-12 01:48 回答
  • mysql> show variables like "%sock%";

    看一下mysql启动的时候sock文件放到哪里了,本地使用mysql客户端连接的时候 -S /tmp/mysql.sock指定。如果这个文件不存在要么被误删、要么没权限写,看一下mysql日志。

    轻易就把/var/lib/mysql数据文件目录给删了,服了

    2022-11-12 01:48 回答
撰写答案
今天,你开发时遇到什么问题呢?
立即提问
热门标签
PHP1.CN | 中国最专业的PHP中文社区 | PNG素材下载 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有