解决Ubuntu18.04下MySQL只能使用sudo连接
程序员文章站
2022-07-14 20:04:25
...
解决Ubuntu18.04下MySQL只能使用sudo连接
1、修改root用户
查看用户的权限,是否是mysql_native_password,如果不是,则将auth_sock改为mysql_native_password
update user set plugin = 'mysql_native_password' where user = 'root';
或者执行下面语句,这样就不需要执行Step2的内容啦!
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'password';
然后
flush privileges;
退出mysql。
2、修改或者设置root用户密码
退出后使用 mysql -u root -p 发现登录不了Mysql, 报的错为:
ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES)
然后修改root密码(密码可与之前的一样):
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'root';
然后,quit;退出。
如果 root还是无法远程访问,则进行下面操作:
netstat -ntpl 查看3306监听在127.0.0.1 的话 改成监听IP为你的IP 或者为0.0.0.0
sudo nano /etc/mysql/mysql.conf.d/mysqld.cnf
找到 bind-address = 127.0.0.1 去掉#注释改成
bind-address = 0.0.0.0
mysql远程连接 Host * is not allowed to connect to this MySQL server
执行use mysql;
执行update user set host = '%' where user = 'root';这一句执行完可能会报错,不用管它。
执行FLUSH PRIVILEGES;
上一篇: Centos7安装mysql8的完整记录
下一篇: Manjaro安装及配置