文章详情页
mysql 可以从 TCP 连接但是不能从 socket 链接
浏览:93日期:2022-06-21 17:14:57
问题描述
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损毁出现表找不到。所以要先备份。
问题解答
回答1:mysql> show variables like '%sock%';
看一下mysql启动的时候sock文件放到哪里了,本地使用mysql客户端连接的时候 -S /tmp/mysql.sock指定。如果这个文件不存在要么被误删、要么没权限写,看一下mysql日志。
轻易就把/var/lib/mysql数据文件目录给删了,服了
回答2:表述有问题吧,socket不是对tcp/ip的一层封装么?
回答3:看看文件还在不在,有没有权限,是不是和MySQL的设置一致。如果以前是好的,那么不排除被误删除或更改了权限的可能。
相关文章:
1. mysql优化 - mysql count(id)查询速度如何优化?2. python - django 里自定义的 login 方法,如何使用 login_required()3. javascript - git clone 下来的项目 想在本地运行 npm run install 报错4. node.js - node_moduls太多了5. mysql主从 - 请教下mysql 主动-被动模式的双主配置 和 主从配置在应用上有什么区别?6. angular.js - 不适用其他构建工具,怎么搭建angular1项目7. 主从备份 - 跪求mysql 高可用主从方案8. android-studio - Android 动态壁纸LayoutParams问题9. python如何不改动文件的情况下修改文件的 修改日期10. 在Java中System.out.println 只能在method中使用吗?
排行榜
