我正在设置一个新的服务器,但一直遇到这个问题。

当我尝试登录MySQL数据库与根用户,我得到的错误:

错误1698(28000):用户“root”@“localhost”被拒绝访问

不管我是通过终端(SSH)连接,还是通过phpMyAdmin或MySQL客户端(例如Navicat)连接。他们都失败了。

我看了mysql。用户表,得到如下:

+------------------+-------------------+
| user             | host              |
+------------------+-------------------+
| root             | %                 |
| root             | 127.0.0.1         |
| amavisd          | localhost         |
| debian-sys-maint | localhost         |
| iredadmin        | localhost         |
| iredapd          | localhost         |
| mysql.sys        | localhost         |
| phpmyadmin       | localhost         |
| root             | localhost         |
| roundcube        | localhost         |
| vmail            | localhost         |
| vmailadmin       | localhost         |
| amavisd          | test4.folkmann.it |
| iredadmin        | test4.folkmann.it |
| iredapd          | test4.folkmann.it |
| roundcube        | test4.folkmann.it |
| vmail            | test4.folkmann.it |
| vmailadmin       | test4.folkmann.it |
+------------------+-------------------+

如您所见,root用户应该具有访问权限。

服务器非常简单,因为我已经尝试了一段时间来解决这个问题。

它运行Ubuntu 16.04.1 LTS (Xenial Xerus)和Apache, MySQL和PHP,这样它就可以托管网站,iRedMail 0.9.5-1,这样它就可以托管邮件。

在安装iRedMail之前,登录MySQL数据库工作正常。我也试过只安装iRedMail,但根也不能用。

如何解决MySQL登录问题,或者如何在现有的MySQL安装上安装iRedMail ?是的,我尝试了安装提示,我在配置文件中找不到这些变量。


当前回答

这适用于我的mysql版本15.1:

$ sudo mysql

MariaDB [mysql]> use mysql;
MariaDB [mysql]> set password for 'root'@'localhost' = password('YOUR_ROOT_PASSWORD_HERE');
MariaDB [mysql]> flush privileges;
MariaDB [mysql]> quit

以“root”身份登录

mysql -u root -p

归功于Raoul HATTERER

其他回答

我已经完成了以下步骤来摆脱这个问题。

使用(sudo MySQL -p -u root)登录到您机器中的MySQL,并执行以下查询。

CREATE USER 'jack'@'localhost' IDENTIFIED WITH mysql_native_password BY '<>'; 授予所有特权。“杰克”@“localhost”; SELECT user,plugin,host FROM mysqlWHERE user = 'root'; +------+-------------+-----------+ |用户|插件|主机| +------+-------------+-----------+ | root | auth_socket | localhost | .使用实例 +------+-------------+-----------+ ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '<>'; 冲洗特权;

请尝试一次,如果您仍然得到错误。我希望这段代码对你有很大的帮助!!

有一个很好的和定期更新的指南,如何为最新的MySQL设置新密码:

如何在Ubuntu 20.04上安装MySQL

最好从上面的页面中阅读整个主题,但简而言之,这可能会有所帮助。

运行安全脚本:

sudo mysql_secure_installation

mysql_secure_installation的详细信息

之后,您可以按照以下步骤修改密码:

sudo mysql

mysql> ALTER USER 'root'@'localhost' IDENTIFIED WITH cache_sha2_password BY 'password'

修改root用户密码的详细信息

如果遇到问题,可能需要重新安装MySQL。

你想用root用户访问MySQL,但是你没有提供root用户的正确密码。

如果你需要为root用户设置一个新密码,MySQL的网站上有很多关于如何做的文档:B.3.3.2如何重置root用户密码

我不会在这里展示这个过程,因为上面链接的MySQL文档是清晰而简洁的。

我建议删除MySQL连接-

这是MySQL 5.5版。如果你的版本不同,请相应地更改第一行。

sudo apt-get purge mysql-server mysql-client mysql-common mysql-server-core-5.5 mysql-client-core-5.5
sudo rm -rf /etc/mysql /var/lib/mysql
sudo apt-get autoremove
sudo apt-get autoclean

然后再次安装,但是这次你自己设置root密码。 这将节省很多精力。

sudo apt-get update
sudo apt-get install mysql-server

对于任何尝试这里的解决方案,没有工作,确保你使用了正确的命令,sudo sudo mysql -u root -p而不是mysql mysql -u root -p。

您需要输入两个密码,一个是当前用户的密码,一个是根用户的密码。