Can't connect to local MySQL server through socket '/tmp/mysql.sock'
2014-04-22 14:05
357 查看
网站突然报错:
Can't connect to local MySQL server through socket '/tmp/mysql.sock'
在mysql的启动过程中有时会遇到下述错误Can't connect to local MySQL server through socket '/tmp/mysql.sock'
请问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才能连接的。
哦,我说当时用PDO形式连接数据库的方式,是正常的。用普通的mysql_connect()就有问题。
解决办法:
第一步:mysqld_safe &
第二步(软连接):ln -s /var/lib/mysql/mysql .sock /tmp/mysql .sock
重要参考资料:
http://www.cnblogs.com/super-lucky/p/superlucky.html
http://blog.csdn.net/drecik__/article/details/8456333
http://www.cnblogs.com/wwufengg/articles/mysqld-sock-lost.html
解决方法如下:
Mysql文件mysql.sock丢失丢失的原因一般是因为配置文件不一致的原因,mysqld 错误启动,mysqld_safe 会清除一次mysql.sock 。判断解决故障时没有切换到mysql用户,造成权限有问题,无法创建mysql授权表,所以也就无法创建/tmp/mysql.sock 和hostname.pid文件。因此,总结解决方法如下:# /usr/local/bin/mysql_install_db //重建授权表# /usr/local/bin/mysqld_safe /usr/local/bin/mysql //测试mysq>bye;文件已经解决,重新生成新的/tmp/mysql.sock 和 hostname.pid
Can't connect to local MySQL server through socket '/tmp/mysql.sock'
在mysql的启动过程中有时会遇到下述错误Can't connect to local MySQL server through socket '/tmp/mysql.sock'
请问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才能连接的。
哦,我说当时用PDO形式连接数据库的方式,是正常的。用普通的mysql_connect()就有问题。
解决办法:
第一步:mysqld_safe &
第二步(软连接):ln -s /var/lib/mysql/mysql .sock /tmp/mysql .sock
重要参考资料:
http://www.cnblogs.com/super-lucky/p/superlucky.html
http://blog.csdn.net/drecik__/article/details/8456333
http://www.cnblogs.com/wwufengg/articles/mysqld-sock-lost.html
解决方法如下:
Mysql文件mysql.sock丢失丢失的原因一般是因为配置文件不一致的原因,mysqld 错误启动,mysqld_safe 会清除一次mysql.sock 。判断解决故障时没有切换到mysql用户,造成权限有问题,无法创建mysql授权表,所以也就无法创建/tmp/mysql.sock 和hostname.pid文件。因此,总结解决方法如下:# /usr/local/bin/mysql_install_db //重建授权表# /usr/local/bin/mysqld_safe /usr/local/bin/mysql //测试mysq>bye;文件已经解决,重新生成新的/tmp/mysql.sock 和 hostname.pid
相关文章推荐
- Socket不能选择本地IP连接问题如何解决
- 解决time_wait强制关闭socket
- 深入php socket的讲解与实例分析
- filezilla Failed to create listen socket on port 21 for IPv4 解决办法
- php socket方式提交的post详解
- PHP异步调用socket实现代码
- PHP实现Socket服务器的代码
- udp socket客户端和udp服务端程序示例分享
- python实现socket端口重定向示例
- python实现socket客户端和服务端简单示例
- c# socket网络编程接收发送数据示例代码
- 解析:通过php socket并借助telnet实现简单的聊天程序
- 基于PHP Socket配置以及实例的详细介绍
- 基于TCP异步Socket模型的介绍
- .net的socket异步通讯示例分享
- 浅析PHP Socket技术
- php与java通过socket通信的实现代码
- Java实现的基于socket通信的实例代码
- php中使用Curl、socket、file_get_contents三种方法POST提交数据
- python socket网络编程步骤详解(socket套接字使用)