【发布时间】:2015-02-14 05:08:29
【问题描述】:
在 CentOS 7 机器上,当我尝试从终端登录 mysql 时出现以下错误:
ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' (2)
然后我尝试了cd /var/lib/mysql 和ls -al,但生成的文件列表不包含mysql.sock。 那么我在哪里可以找到mysql.sock,我该如何解决这个错误?
以下是我已经尝试过的一些方法:
1.) 当我看到systemctl status mysqld显示mysql已停止时,我也尝试了systemctl start mysqld,但终端只是给出了一个无响应的光标,没有新的提示,就好像它在等待什么,但它无限期地保持在那种边缘状态。
2.) 于是我打开了另一个终端窗口并运行systemctl status mysqld,却发现mysqld 再次启动。但错误仍然存在。
3.) 我试过find / -name "mysql.sock",但回复是find: ‘/run/username/1000/gvfs’: Permission denied。
4.) 然后我读了this posting 并尝试了mysqladmin | grep d.sock,但没有结果。
5.) 我什至求助于yum remove mysql,然后是yum install mysql,但随后mysql -u root 在这篇帖子的顶部仍然给出了相同的原始错误。
6.) 然后我读了this other posting,但是mysqladmin variables 给出了同样的错误,因为找不到mysql.sock,所以它无法连接。
7.) 我尝试了ln -s /tmp/mysql.sock /var/mysql/mysql.sock,但即使在我尝试cd /var/lib/mysql/ 和ls -al 时可以看到指向mysql 的链接,同样的错误仍然存在
8.) 由于问题可能与systemctl start mysqld 挂断有关,我阅读了this posting 并尝试了chown -R mysql:mysql /var/lib/mysql 和systemctl start mysqld,但结果是Failed to issue method call: Unit mysqld.service failed to load: No such file or directory.
9.) 然后我阅读了this posting,这导致我运行mysql --help | grep "Default options" -A 1。结果打印了mysql 查找my.cnf 的位置。因此,我检查了每个位置,没有找到my.cnf 文件。但是我确实找到了mysql.cnf.rpmsave,所以我尝试了mv mysql.cnf mysql.cnf.rmpsave。这导致预期目录中有my.cnf,但systemctl status mysqld 表示找不到mysqld。我再次尝试yum install mysql,但它告诉我mysql 已经安装。 所以我怀疑新重命名的my.cnf 已损坏。如果是这样,我该如何解决? 将Here is the link 复制到文件共享站点上新重命名的my.cnf 的副本。
【问题讨论】:
-
你修好了吗???