Ubuntu 15.10 mysql错误1524 – unix_socket

在Ubuntu 15.10上,某一点(可能在安装和删除mariadb之后),mysql无法运行。 任务已启动,但服务器已关闭。

在命令:

mysql -u root -p 

系统回复如下:

 mysql "ERROR 1524 (HY000): Plugin 'unix_socket' is not loaded" 

无法登录,未找到插件,配置文件中没有错误(全部为默认值)。

如何恢复控制,并使mysql服务器运行?

mysql身份validation过程调用了“unix_socket”(可能与数据库部分迁移到mariadb有关,现已删除)。 为了让所有的东西恢复工作去su:

 sudo su 

然后按照:

 /etc/init.d/mysql stop mysqld_safe --skip-grant-tables & mysql -uroot 

这将完全停止mysql,绕过用户身份validation(无需密码)并使用用户“root”连接到mysql。

现在,在mysql控制台中,使用mysql管理db:

 use mysql; 

要将root密码重置为mynewpassword (根据您的意愿更改),只需确保它:

 update user set password=PASSWORD("mynewpassword") where User='root'; 

这个将覆盖身份validation方法,删除unix_socket请求(以及其他所有),恢复正常和工作密码方法:

 update user set plugin="mysql_native_password"; 

退出mysql控制台:

 quit; 

停止并启动与mysql相关的所有内容:

 /etc/init.d/mysql stop kill -9 $(pgrep mysql) /etc/init.d/mysql start 

不要忘记exit su模式。

现在mySQL服务器启动并运行。 您可以使用root登录:

 mysql -u root -p 

或者你想要什么。 密码使用有效。

而已。

以下是我执行此操作的步骤:

 /etc/init.d/mysql stop sudo killall mysqld_safe sudo killall mysqld sudo mysqld_safe --skip-grant-tables & mysql -u root use mysql; update user set password=PASSWORD("mynewpassword") where User='root'; update user set plugin="mysql_native_password"; quit; /etc/init.d/mysql stop sudo kill -9 $(pgrep mysql) /etc/init.d/mysql start