Ubuntu 下运行
mysql -u root -p
报错显示 ERROR 1698 (28000): Access denied for user ‘root’@‘localhost’ ,原因是root用户空密码,
- 登录查看MySQL账户信息
sudo mysql
SELECT User, Host, HEX(authentication_string) FROM mysql.user;
可以知道root用户一直为空密码,但无论使用何种方式设置密码都是设置不上的。
- 原因是MySQL验证密码使用授权插件(使用的授权插件类型可以在mysql.user表中看到)
SELECT user, plugin FROM mysql.user;
-
我们在使用apt命令安装mysql-server时并没有设置root密码(也没有提示设置,无法设置),MySQL就为root用户自定义授权插件为auth_socket插件。
-
这个插件不关心也不需要密码,它只是通过UNIX套接字的用户名进行验证,如果验证通过,那么就鉴权成功。这就是root用户可以正常使用mysql的原因,因为root用户在mysql的user表中。
解决方法
重新设置授权插件,并设置密码
update mysql.user set authentication_string=PASSWORD('123456'), plugin='mysql_native_password' where user='root';
在更新的mysql8版本中会提示语法错误,改为
ALTER USER 'username'@'localhost' IDENTIFIED WITH 'mysql_native_password' BY '123456';
附:
mysql跳过认证的方法
- 编辑 MySQL 的配置文件,通常为 /etc/mysql/my.cnf 或 /etc/my.cnf
vim /etc/mysql/my.cnf
- 在配置文件中找到 [mysqld] 部分,添加一行并保存退出
[mysqld]
skip-grant-tables
- 重新启动 MySQL 服务,以使更改生效
sudo service mysql restart
现在,MySQL 将启动并忽略授权表。请记住,启用了 skip-grant-tables 选项后,任何连接到 MySQL 的用户都将具有 root 权限,因此请确保在使用完 skip-grant-tables 后及时禁用它,并重新启动 MySQL 服务。
清除数据库中多余权限记录
如果 SELECT 查询结果显示了一个已经被删除的用户(例如 “wordpress ubuntu”),那么很可能是由于数据库中的权限记录没有被正确清除而导致的。
DELETE FROM mysql.db WHERE Db = 'database_name' AND User = 'username';