当使用mysqld_safe启动mysql服务器5.7.17时,出现以下错误。

2017-02-10T17:05:44.870970Z mysqld_safe Logging to '/var/log/mysql/error.log'.
2017-02-10T17:05:44.872874Z mysqld_safe Logging to '/var/log/mysql/error.log'.
2017-02-10T17:05:44.874547Z mysqld_safe Directory '/var/run/mysqld' for UNIX socket file don't exists.

如何解决?


当前回答

如果您的数据库没有任何数据,或者您有另一个方法来恢复该数据,您可以尝试以下操作。你需要知道Ubuntu服务器的根密码,但不需要知道mysql的根密码。

很可能我们中的许多人都安装了“mysql_secure_installation”,因为这是一个最佳实践。进入mysql_secure_installation所在的bin目录。它可以在Ubuntu系统的/bin目录中找到。通过重新运行安装程序,将提示是否修改root数据库密码。

其他回答

发生在我身上。 消息实际上是不正确的(在糟糕的英语:-))。

为了找出有问题的文件,我运行了这个命令(以root身份): Sh -x /etc/init.d / mysqld开始 它打印了这个: 无法通过套接字'/ MySQL -dir/ MySQL .sock'连接到本地MySQL服务器 检查mysqld是否正在运行,并且socket: '/mysql-dir/mysql. conf袜子的存在! 因此,套接字文件似乎需要预先存在,所以我这样做了,同样以root身份: cd / mysql-dir 触摸mysql.sock Chown mysql:mysql mysql.sock 然后: 服务mysqld启动 瞧!

如果您的数据库没有任何数据,或者您有另一个方法来恢复该数据,您可以尝试以下操作。你需要知道Ubuntu服务器的根密码,但不需要知道mysql的根密码。

很可能我们中的许多人都安装了“mysql_secure_installation”,因为这是一个最佳实践。进入mysql_secure_installation所在的bin目录。它可以在Ubuntu系统的/bin目录中找到。通过重新运行安装程序,将提示是否修改root数据库密码。

这个目录在安装时没有创建,这看起来很奇怪——您是否手动更改了my.cfg中套接字文件的路径?

您是否尝试过自己创建这个目录,然后重新启动服务?

mkdir -p /var/run/mysqld
chown mysql:mysql /var/run/mysqld

请看这个错误:https://bugs.launchpad.net/ubuntu/+source/mysql-5.6/+bug/1435823

似乎有一个临时的解决办法

Create a newfile /etc/tmpfiles.d/mysql.conf:

# systemd tmpfile settings for mysql
# See tmpfiles.d(5) for details

d /var/run/mysqld 0755 mysql mysql -

After reboot, mysql should start normally.

在CentOS为我工作:

$ service mysql stop
$ mysqld --skip-grant-tables &
$ mysql -u root mysql

mysql> FLUSH PRIVILEGES;
mysql> ALTER USER 'root'@'localhost' IDENTIFIED BY 'new_password';

$ service mysql restart