mysql sock找不到

mysql sock找不到

大家好,又见面了,我是全栈君。

今天运行人员发现,运营后台进不去,登录后果然有问题

mysql sock找不到

首先介绍下mysql.sock文件:

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

使用sql语句登录MySQL出现如下报错

mysql sock找不到

ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)

进入/tmp 文件夹,果然tmp 下面mysql.sock文件不存在了,

启动mysqld 服务失败

 sudo service mysqld restart

mysql sock找不到非常疑惑的是什么问题导致的mysq.sock 文件找不到的呢?

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

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

解决步骤:

1)检查服务有没有启动(本次故障属于这种)

重启,问题解决

$ sudo /etc/init.d/mysql restart

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

 

参考连接:https://blog.csdn.net/keil_wang/article/details/88641735

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/111880.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • hdu 4891—水的问题 但WA非常多

    hdu 4891—水的问题 但WA非常多

    2022年1月17日
    32
  • Win知识 – 程序是怎样跑起来的(合集)

    Win知识 – 程序是怎样跑起来的(合集)操作系统的硬件控制功能,通常是通过一些小的函数集合体的形式来提供的。这些函数及调用函数的行为统称为系统调用(systemcall),也就是应用对操作系统(system)的功能进行调用(call)的意思。在前面的程序中用到了time()及printf()等函数,这些函数内部也都使用了系统调用。这里之所以用“内部”这个词,是因为在Windows操作系统中,提供返回当前日期和时刻,以及在显示器中显示字…

    2022年6月28日
    29
  • heapdump.phd分析工具_dump文件分析工具

    heapdump.phd分析工具_dump文件分析工具heapdump分析工具是一款强大的数据分析工具,它可以用图表的形式来展现相应的分析结果,在使用heapdump分析工具之前请先安装JDK1.6。运行环境1.运行环境要求JDK1.6或以上如果JDK版本过低,报错如下:Exceptioninthread”main”java.lang.NoClassDefFoundError:java/util/regex/PatternSyntaxEx…

    2022年10月2日
    0
  • Codeblocks断点调试

    Codeblocks断点调试首先,新建一个C/C++的codeblocks项目。具体步骤如下:1.新建一个工程(project),注意路径中不要包含中文,否则后面断点调试时会出现问题2.直接选择空工程3.选择C或者C++项目即可4.点开工作空间(workspace)中的Source文件夹,即可对文件进行编辑然后,在.c或者.cpp文件中编写程序,设置断点进行调试。下面以一个小程序为例:

    2022年5月11日
    39
  • HDU 1085-Holding Bin-Laden Captive!(生成功能)

    HDU 1085-Holding Bin-Laden Captive!(生成功能)

    2022年1月12日
    38
  • Pytest(2)使用和调用方法

    Pytest(2)使用和调用方法Pytest执行用例规则Pytest在命令行中支持多种方式来运行和选择测试用例1.对某个目录下所有的用例pytest2.对模块中进行测试pytesttest_mod.py3.对文件夹进行

    2022年7月30日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号