- 前言
- 1. 原理
- 2. 解决方案
- 2.1 软链接
- 2.2 配置文件
在管理数据库的时候,服务器出现了如下问题
ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/run/mysqld/mysqld.sock' (2)
截图如下:
出现以上问题,主要是因为默认连接数据库的主机名-p 为localhost作为主机名。通过该主机名连接mysql服务器的时候,会以socket的方式进行连接,而配置文件的“/etc/mysql.cnf”的路径,未找到相应的socket文件,就会引发此错误
2. 解决方案知道原理便可以修复bug
主要是路径找不到了
那我们可以修改配置文件或者是设置一个软链接
设置软链接,主要是能找到这个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 directory2.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服务即可



