我的问题开始与我不能登录根在我的mysql安装更多。我试图运行mysql没有密码打开…但每当我执行命令时

# mysqld_safe --skip-grant-tables &

我再也拿不回提示了。我试图按照这些说明恢复密码。

屏幕看起来是这样的:

root@jj-SFF-PC:/usr/bin# mysqld_safe --skip-grant-tables
120816 11:40:53 mysqld_safe Logging to syslog.
120816 11:40:53 mysqld_safe Starting mysqld daemon with databases from /var/lib/mysql

我没有得到开始输入SQL命令重置密码的提示。

当我按CTRL + C杀死它时,我得到以下消息:

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

Check that mysqld is running and that the socket: '/var/run/mysqld/mysqld.sock' exists!

如果我重试该命令并将其放置足够长的时间,我确实会得到以下一系列消息:

root@jj-SFF-PC:/run/mysqld# 120816 13:15:02 mysqld_safe Logging to syslog.
120816 13:15:02 mysqld_safe Starting mysqld daemon with databases from /var/lib/mysql
120816 13:16:42 mysqld_safe mysqld from pid file /var/run/mysqld/mysqld.pid ended

[1]+  Done                    mysqld_safe --skip-grant-tables
root@jj-SFF-PC:/run/mysqld#

但如果我尝试以root用户登录,执行以下操作:

# mysql -u root

我得到以下错误消息:

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

/var/run/mysqld/mysqld.Sock文件不存在。文件夹有,但文件没有。

此外,我不知道这是否有帮助,但我运行find / name mysqld,它出现了:

/var/run/mysqld - folder
/usr/sbin/mysqld - file
/run/mysqld - folder

我不知道这是否正常。但我把这些信息也包括进来,以防有用。

我最终决定卸载并重新安装mysql。

apt-get remove mysql-server
apt-get remove mysql-client
apt-get remove mysql-common
apt-get remove phpmyadmin

在按照上面相同的顺序重新安装所有包之后,在phpmyadmin安装期间,我得到了相同的错误:

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

所以我再次尝试卸载/重新安装。这一次,在我卸载包之后,我还手动将所有mysql文件和目录重命名为mysql。在各自的位置都不好。

/var/lib/mysql 
/var/lib/mysql/mysql
/var/log/mysql
/usr/lib/perl5/DBD/mysql
/usr/lib/perl5/auto/DBD/mysql
/usr/lib/mysql
/usr/bin/mysql
/usr/share/mysql
/usr/share/dbconfig-common/internal/mysql
/etc/init.d/mysql
/etc/apparmor.d/abstractions/mysql
/etc/mysql

然后我尝试重新安装mysql-server和mysql-client。但我注意到它并没有提示我输入密码。它不是应该要求输入管理员密码吗?


当前回答

确保您无法访问的套接字文件路径与'/var/run/mysqld/mysqld相同。Sock ',否则改变你的路径。 停止mysqld

$ sudo /etc/init.d/mysqld stop

如果进程仍在运行;

$ sudo pkill -9 mysqld

删除将要创建socket的mysql目录。对我来说,它不允许移除,所以我必须用力移除。

$ sudo mkdir -p /var/run/mysqld

设置目录的所有权

$ sudo chown mysql:mysql /var/run/mysqld

启动mysql

$ sudo /etc/init.d/mysql start

尝试连接mysql

$ sudo mysql -u dbuser -p

其他回答

用户加载步骤的答案对我来说是有效的。 有时需要编辑/etc/mysql/my.cnf文件添加行到客户端

[client]
password = your_mysql_root_password
port  = 3306
host  = 127.0.0.1
socket  = /var/lib/mysql/mysql.sock

我也有同样的问题。在挣扎了一个小时后,我找到了一种无需重新安装mysql-common、mysql-client、mysql-server的方法来纠正它。

首先,进入“/var/run/mysqld”。你会发现mysql。Sock并不存在。只需删除整个mysqld目录并重新创建它并为其提供必要的特权。

# rm -rf /var/run/mysqld && mkdir /var/run/mysqld && chown mysql /var/run/mysqld/

现在,完整地杀死mysql进程。它可能会在运行“/etc/init”时显示“等待页面清理器”。D /mysql status”命令,即使关闭服务。

要完全关闭服务,请使用

# pkill -9 mysqld

进程终止后,尝试再次使用

# /etc/init.d/mysql start

你会发现它工作得很好!而且阻止它也没有问题。

我在Ubuntu的虚拟机上运行我的MySQL,所以当我重启我的主机和虚拟机时,IP发生了变化。我已经配置mysql在IP 192.168.0.5上运行,现在由于IP的动态分配,我的新IP是192.168.0.8

如果你有同样的问题,用ifconfig命令检查你的ip。

使用cat /etc/mysql/my.cnf | grep bind-address命令检查MySQL绑定

如果两个IP相同,请重新安装mysql服务器

如果不是,那么在/etc/network/interfaces中使用nano, vi, vim或任何你喜欢的东西更改你的IP。

我更喜欢sudo nano /etc/network/interfaces

并输入以下内容

auto eth0
iface eth0 inet static
address 192.168.0.5
netmask 255.255.255.0

保存接口文件,重新启动你的接口sudo ifdown eth0 && sudo ifup eth0用你的网络接口替换“eth0”

重新启动MySQL sudo service MySQL stop,然后执行sudo service MySQL start

如果你和我有同样的问题,你可以去!

我在CentOS VPS上也遇到了类似的问题。如果MySQL启动后无法启动或一直崩溃,请尝试以下步骤:

1)找到my.cnf文件(我的文件位于/etc/my.cnf),并添加一行:

innodb_force_recovery = X

将X替换为从1到6的数字,从1开始,如果MySQL不启动,则递增。设置为4,5或6可以删除您的数据,所以要小心,并阅读http://dev.mysql.com/doc/refman/5.7/en/forcing-innodb-recovery.html之前。

2)重启MySQL服务。只有SELECT将运行,这在此时是正常的。

3)用mysqldump逐个转储你所有的数据库/模式,不要压缩转储,因为以后你必须解压缩它们。

4)仅移动(或删除!)/var/lib/mysql中的bd目录,保留根目录中的单个文件。

5)停止MySQL,然后取消注释1)中添加的行。

6)恢复所有bd的倾倒在3)。

好运!

在archlinux上,我遇到了这个错误,问题是mysql服务没有运行。

然而,我无法启用mysql-service与systemctl启动mysqld在Archlinux文档中的指示。我想这个错误是

mysqld。未找到服务

我首先需要重新启动系统。

然后我再次输入命令(并输入systemctl enable mysqld),现在mysql能够找到创建的mysql.sock。