php连接mysql指定sock文件_MySQL找不到mysql.sock文件怎么办

当MySQL连接提示找不到mysql.sock文件时,可检查服务是否启动,确认my.cnf中的socket参数路径,确保文件存在及访问权限。若文件丢失,可通过重启服务、查找并创建软链接或使用TCP/IP连接。
摘要由CSDN通过智能技术生成

MySQL找不到mysql.sock文件的解决办法:首先检查服务有没有启动;然后在【my.cnf】文件中查看socket参数指定的路径;最后使用TCP/IP来连接即可。

326e3e7e765529179778f8e65f58a1c9.png

MySQL找不到mysql.sock文件怎么办?

mysql.sock文件:

MySQL有两种来连接方式,一种是通过TCP/IP,就是用-h参数指定要连接的mysqlserverI的IP,另一种是套接字socket,在这里就是mysql.sock文件。当我们的客户端与数据库服务器(mysqlserver)在同一台机器上时,就通过该文件来连接数据库。

关于mysql.sock的一些问题:

连接数据库时报错:Can 't connect to local MySQL server through socket '/tmp/mysql.sock '(2) ";

分析:找不到mysql.sock文件,自然连接不了

原因:1)mysql服务没启动;2)sock文件路径设置错误 ;3)sock文件所在目录的权限问题;4)这个文件直接丢失了解决步骤:

1)检查服务有没有启动

2)在my.cnf文件中查看socket参数指定的路径,查看这个路径有没有访问权限

3)到那个路径下去看一下到底有没有这个mysql.sock文件,如果该路径下没有sock文件,我们先用find命令找出这个文件的位置,如果find也找不到,重启一下mysql服务即可,会自动生成一个。然后把他复制到soctek参数指定的路径下去。或者建立一个软连接,这也是比较推荐的方法,比如这个文件在/var/lib/mysql.sock,socket参数指定的路径是/tmp/mysql.sock。我们就可以这样创建:ln -s /var/lib/mysql.sock /tmp/mysql.sock,创建完之后,再尝试连接

另外需要注意的是,mysql.sock文件默认是在/tmp下,数据库启动的时候,系统也默认去这个文件下找mysql.sock文件,但是/tmp目录有时会被某个定时任务给清除,那么我们可以给/tmp目录加一个sticky权限,保护其不被删除,chmod +t /tmp即可,使得/tmp下的文件只能由文件所有者和root用户才能删除

4)如果还是报那个错误,我们就用TCP/IP来连接

mysql -uroot -h 192.168.142.160 -p #-h后面是数据库服务器的IP

或者 mysql -uroot -h 127.0.0.1 -p

更多PHP相关知识,请访问PHP中文网!

f68f2add0b68e4f9810432fce46917b7.png

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值