启动mysql遇到问题Can't connect to local MySQL server through socket '/tmp/mysql.sock' (示例代码

Posted James老赵

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了启动mysql遇到问题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\' (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才能连接的。
 
以上内容来自:http://blog.csdn.net/kerwin612/article/details/8568206
 
针对以上问题,其实有时等同于
  启动 mysqld 时经过很长时间显示 Timeout error occurred trying to start MySQL Daemon.
这个错误!
参见上一篇博客内容:http://www.cnblogs.com/adair/p/7775155.html
 
 

以上是关于启动mysql遇到问题Can't connect to local MySQL server through socket '/tmp/mysql.sock' (示例代码的主要内容,如果未能解决你的问题,请参考以下文章

在启动MYSQL时出现问题:“ERROR 2003 (HY000): Can't connect to MySQL server on 'localhost' (10061)”

学习python3 MySQL数据库语法遇到的问题:"Can't connect to MySQL server on 'localhost'

UnicodeEncodeError: 'latin-1' codec can't encode characters in position 0-3: ordinal not

Can''t connect to MySQL server on localhost (10061)解决方法

docker启动mysql报错Can't read dir of '/etc/mysql/conf.d/'

连接MySQL的10060错误:Can't connect to MySQL server on '*.*.*.*'(10060) (转自https://www.cnblo