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

当我尝试登录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 ?是的,我尝试了安装提示,我在配置文件中找不到这些变量。


当前回答

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

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

其他回答

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

使用(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连接-

这是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

对于那些在macOS上安装最新MariaDB并遵循MariaDB文档中的本教程的用户,请运行:

sudo mariadb-secure-installation

而不是只给出mariadb-secure-installation命令。否则,运气不好,尽管出现错误提示:

In order to log into MariaDB to secure it, we'll need the current
password for the root user. If you've just installed MariaDB, and
haven't set the root password yet, you should just press enter here.

Enter current password for root (enter for none):
ERROR 1698 (28000): Access denied for user 'root'@'localhost'
Enter current password for root (enter for none):
ERROR 1698 (28000): Access denied for user 'root'@'localhost'
Enter current password for root (enter for none):
Aborting!

第一步:进入/etc/phpmyadmin/config.inc.php文件,然后取消注释你发现“AllowNoPassword”的行。

第二步:登录MySQL默认帐户

mysql -u root -p

use mysql;
update user set plugin="" where user='root';
flush privileges;

这就是全部!

步骤1。-u root -p

步骤2。使用mysql;

步骤3。ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password

这里的“admin”是你的新密码,但你可以修改它。

步骤4。退出

你完成了。