mysql.sock问题 Can't connect to local MySQL server through socket '/tmp/mysql.sock'

https://www.cnblogs.com/byfboke/p/9095445.html

mysql.sock问题
Can’t connect to local MySQL server through socket ‘/tmp/mysql.sock’

上述提示可能在启动mysql时遇到,即在/tmp/mysql.sock位置找不到所需要的mysql.sock文件,主要是由于my.cnf文件里对mysql.sock的位置设定导致。

mysql.sock默认的是在/var/lib/mysql, 如果发现确实是在该目录下,可以在[mysqld]下面加入mysql.sock的path
vi /etc/my.cnf(my.cnf也可能在其他路径下)

[mysqld]
port = 3306
socket = /var/lib/mysql/mysql.sock

但是要保证使用mysql的用户具有对该目录的写权限,否则这样的改动由于权限限制仍然会报错。

所以为了避免权限问题也可以使用软链接为/var/lib/mysql/mysql.sock创建一个到/tmp/mysql.sock的联接

ln -s /var/lib/mysql/mysql.sock /tmp/mysql.sock

由于/tmp/文件夹默认对other有w权限,这样就可以避免权限问题。

此外,如果发现mysql.sock不在默认的/var/lib/mysql位置,一种解决方法是使用find命令搜索mysql.sock的位置,然后按前面两种解决方案挑一种做即可。
find / -name mysql.sock

注意:首先要看my.cnf中是否指定了sock连接文件,如果指定了,连接方式如下:

[root@iZ11ofs]# mysql -uroot -p'111' -S /DATA/mysql/mysql.sock

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当你遇到"Can't connect to local MySQL server through socket '/tmp/mysql.sock'"错误时,这意味着MySQL客户端无法通过指定的UNIX socket连接到MySQL服务器。UNIX socket是一种在同一台机器上的进程之间进行通信的方法。 该错误通常出现在以下情况下: 1. MySQL服务器没有运行或已经关闭。 2. MySQL服务器正在运行,但UNIX socket文件路径不正确。 3. 对UNIX socket文件路径的访问权限不正确。 要解决此问题,您可以按照以下步骤进行操作: 1. 确保MySQL服务器正在运行。您可以使用以下命令检查MySQL服务器的状态: ``` /usr/local/mysql/bin/mysqladmin -u root -S /var/lib/mysql/mysql.sock status ``` 2. 检查UNIX socket文件的路径是否正确。默认情况下,MySQL UNIX socket文件的路径为`/tmp/mysql.sock`,但在某些情况下,可能已被更改为其他位置。您可以使用以下命令查找UNIX socket文件的路径: ``` mysql_config --socket ``` 3. 如果UNIX socket文件路径不正确,您可以通过编辑MySQL配置文件来更正。MySQL配置文件通常位于`/etc/my.cnf`或`/etc/mysql/my.cnf`,您可以使用任何文本编辑器打开它并找到`socket`参数。将其更改为正确的路径,并保存更改。 4. 确保对UNIX socket文件的访问权限正确。MySQL服务器和客户端都需要对UNIX socket文件具有适当的访问权限。您可以使用以下命令更改文件权限: ``` sudo chmod 777 /tmp/mysql.sock ``` 通过执行上述步骤,您应该能够解决"Can't connect to local MySQL server through socket '/tmp/mysql.sock'"错误,并成功连接到MySQL服务器。 参考文献: ERROR 2002: Can’t connect to local MySQL server through socket ‘/tmp/mysql.sock’ (111) mysql.sock 这个文件有什么用?

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值