mysql – MariaDB – 无法以root用户身份登录

前端之家收集整理的这篇文章主要介绍了mysql – MariaDB – 无法以root用户身份登录前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

我试图在Ubuntu(16.04.02)上设置MariaDB(10.0.29).在我安装它并启动进程(sudo service mysql start)之后,即使我最初将密码设置为空白,也无法以root身份登录.

MysqL -u root将拒绝我访问.我通过sudo MysqL登录并检查了用户表,即.从MysqL.user中选择user,password,authentication_string并按预期方式:

+---------+----------+-----------------------+ 
| User    | password | authentication_string |
+---------+----------+-----------------------+
| root    |          |                       |
+---------+----------+-----------------------+

我还创建了一个新用户,即.创建用户’test’@’localhost’标识”;当我尝试做MysqL -u test(空密码)时,它按预期工作并登录我.

用户表如下所示:

+---------+----------+-----------------------+
| User    | password | authentication_string |
+---------+----------+-----------------------+
| root    |          |                       |
| test    |          |                       |
+---------+----------+-----------------------+

所以,任何人都可以告诉我为什么我不能以root密码登录,但我可以登录为测试?

最佳答案
与本机MariaDB软件包(由MariaDB本身提供的软件包)不同,Ubuntu生成的软件包默认为本地root用户进行unix_socket认证.检查,运行

SELECT user,host,plugin FROM MysqL.user;

如果你在插件列中看到unix_socket,那就是原因.

要返回通常的密码验证,请运行

UPDATE MysqL.user SET plugin = '' WHERE plugin = 'unix_socket';
FLUSH PRIVILEGES;

(选择适合您目的的WHERE子句,上面只是一个例子)

猜你在找的MySQL相关文章