mysql 可以从 TCP 连接但是不能从 socket 链接
本文介绍了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
数据文件目录给删了,服了
这篇关于mysql 可以从 TCP 连接但是不能从 socket 链接的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文