前言
在管理数据库的时候,服务器出现了如下问题
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版权协议,转载请附上原文出处链接和本声明。