mysql:Can‘t connect to local MySQL server through socket ‘/var/run/mysqld/mysqld.sock‘解决方法

前言

在管理数据库的时候,服务器出现了如下问题

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

截图如下:
在这里插入图片描述

1. 原理

出现以上问题,主要是因为默认连接数据库的主机名-p 为localhost作为主机名。通过该主机名连接mysql服务器的时候,会以socket的方式进行连接,而配置文件的“/etc/mysql.cnf”的路径,未找到相应的socket文件,就会引发此错误

2. 解决方案

知道原理便可以修复bug
主要是路径找不到了
那我们可以修改配置文件或者是设置一个软链接

2.1 软链接

设置软链接,主要是能找到这个socket的文件
设置方式如下

root@gaokaoli:/opt/mycat/conf# ls /var/lib/mysql/mysql.sock
ls: cannot access '/var/lib/mysql/mysql.sock': No such file or directory
root@gaokaoli:/opt/mycat/conf# mkdir /var/lib/mysql
root@gaokaoli:/opt/mycat/conf# ls /var/lib/mysql/mysql.sock
ls: cannot access '/var/lib/mysql/mysql.sock': No such file or directory
root@gaokaoli:/opt/mycat/conf# ln -s /storage/db/mysql/mysql.sock /var/lib/mysql/mysql.sock
root@gaokaoli:/opt/mycat/conf# ls /var/lib/mysql/mysql.sock
/var/lib/mysql/mysql.sock

截图如下:
在这里插入图片描述
注意事项:

以上设置软链接的同时还需要创建一个mysql文件
不然会出现:

ln: creating symbolic link `/var/lib/mysql/mysql.sock’: No such file or directory

在这里插入图片描述

2.2 配置文件

修改配置文件主要通过etc上的/etc/php.ini这个文件
主要修改以下文件路径相同即可

[mysqld]
datadir=/storage/db/mysql
socket=/storage/db/mysql/mysql.sock

 
[client]
default-character-set=utf8
socket=/storage/db/mysql/mysql.sock
 
[mysql]
default-character-set=utf8
socket=/storage/db/mysql/mysql.sock

之后重启mysql服务即可

3. 万能方法

发现复制软连接之后没反应或者找不到其配置文件

建议重新下载一个mysql的包 重新安装一遍

  • 输入wget http://repo.mysql.com/mysql-community-release-el7-5.noarch.rpm
  • 输入rpm -ivh mysql-community-release-el7-5.noarch.rpm
  • 输入yum install mysql-server

或者查看这篇文章
ERROR 2002 (HY000): Can’t connect to local MySQL server through socket ‘/var/run/mysqld/mysqld.sock’


版权声明:本文为weixin_47872288原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。