温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

mysql连接时mysql.sock为什么找不到

发布时间:2020-06-29 10:05:55 来源:亿速云 阅读:275 作者:清晨 栏目:编程语言

小编给大家分享一下mysql连接时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连接时mysql.sock为什么找不到有了一定的了解,想了解更多相关知识,欢迎关注亿速云行业资讯频道,感谢各位的阅读!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI