mysql.sock 文件详解

在mysql的启动过程中有时会遇到下述错误
Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2) 

请问mysql.sock 这个文件到底起什么作用?
如何避免发生如此错误?

答案一、
这个mysql.sock应该是mysql的主机和客户机在同一host(物理服务器)上的时候,使用unix domain socket做为通讯协议的载体,它比tcp快。通常遇到这个问题的原因就是你的mysql server没运行起来。
看看你的 /tmp/mysql.sock 这个文件存在否?正常情况下它应该在那里的,或者用 netstat 看看结果中是否有 
Active UNIX domain sockets 

答案二、
这个文件是用于socket连接的文件。 
也就是只有你的守护进程启动起来这个文件才存在。 
但是你的mysql程序(这个程序是客户端,服务器端时mysqld)可以选择是否使用mysql.sock文件来连接(因为这个方法只适合在Unix主机上面连接本地的mysqld),对于非本地的任何类型的主机。这些在MySQL的手册(包括晏子翻译的中文版本,覆盖3.23/4.0版本)都有说明。只要看看就可以明白。 

前面朋友说不能连接,最大可能就是mysqld的这个守护进程没有启动。 

答案三、
Mysql有两种连接方式:
(1)TCP/IP
(2)socket
对mysql.sock来说,其作用是 mysql客户端程序 mysql与 mysql服务器端程序 mysqlserver处于同一台机器,发起本地连接时可用
例如你无须定义连接host的具体IP得,只要为空或localhost就可以。
在此种情况下,即使你改变mysql的外部port也是一样可能正常连接。
因为 你在my.ini中或my.cnf中改变端口后,mysql.sock是随每一次 mysql server启动生成的。已经根据你在更改完my.cnf后重启mysql时重新生成了一次,信息已跟着变更。

那么对于外部连接,必须是要变更port才能连接的。

找不到 mysql.sock 的处理方法!


出现以下的信息:
Got an error: Connection error: Can't connect to local MySQL server through
socket '/var/lib/mysql/mysql.sock'

mysql.sock 突然消失算是常见的问题。


如果是第一次安装MySQL后运行时出现,那只要找出 mysql.sock 在哪里就可以了。

以上的信息表明,mysql.sock应该是在 /var/lib/mysql/ 下 ,如果你找了没找到

就:

#locate mysql.sock

就会出来了,接着你就可以

#mysqladmin -S /路径/mysql.sock -u root

 

如果是原来很正常的,突然有一天系统告诉你找不到mysql.sock这鬼文件了,怎么办?

那只好用/etc/rc.d/init.d/mysql restart 或者service mysql restart 重启服务了

如果还不行.就先

#ps -aux|grep mysql

找mysql的进程.

#kill mysql进程号

确定全部kill光

再/etc/rc.d/init.d/mysql restart 或者service mysql restart 重启服务


  • 10
    点赞
  • 39
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
MySQL.sock文件MySQL服务器的套接字文件,用于与客户端进行通信。如果这个文件不见了,会导致MySQL服务器无法正常工作。 出现MySQL.sock文件不见的情况可能有以下几种原因: 1. MySQL服务器未启动:在MySQL服务器启动时,会自动生成MySQL.sock文件。如果服务器未启动或启动失败,那么该文件就不会存在。 解决方法:确保MySQL服务器已经正确启动,可以通过命令行或者服务管理工具检查服务器状态。如果服务器未启动,可以尝试重新启动。 2. 文件被删除或移动:MySQL.sock文件可能会被误删或者移动到其他位置,导致服务器无法找到该文件。 解决方法:可以通过查找文件来确定是否被移动或删除。如果找到了该文件,可以将其移回原来的位置。如果没有找到,可以尝试重新安装MySQL服务器。 3. 文件权限问题:MySQL.sock文件的权限配置不正确,导致无法被访问。 解决方法:可以检查MySQL.sock文件的权限和所有者是否正确。一般来说,该文件的所有者应该是MySQL服务器的运行用户,并且权限应该允许MySQL服务器进行读写操作。可以使用chmod和chown命令来修改文件权限和所有者。 总结起来,当MySQL.sock文件不见了时,首先需要确认MySQL服务器是否已经启动,然后检查文件是否被删除或移动,最后检查文件的权限配置是否正确。根据具体的情况,可以采取相应的解决方法来恢复MySQL.sock文件的正常工作。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值