AI智能
改变未来

mysql8.0远程连接权限设置


1.登录MySQL

 

mysql -u root -p

输入您的密码

 

2.选择 mysql 数据库

 

use mysql;

因为 mysql 数据库中存储了用户信息的 user 表。

 

3.在 mysql 数据库的 user 表中查看当前 root 用户的相关信息

 

select host, user, authentication_string, plugin from user; 

 

执行完上面的命令后会显示一个表格

 

 

查看表格中 root 用户的 host,默认应该显示的 localhost,只支持本地访问,不允许远程访问。

 

我们看host和user两列,host和user中root对应的值为localhost,即root用户的访问权限为localhost,想把该用户的访问权限设置可远程连接,我们只需要把localhost更改为通配的%就可以了。上面的权限操作语句没有走通,这里就直接使用update语句来更改吧。

 

update user set host = \”%\” where user = \”root\”;

修改之后就将root用户的访问权限设置成了可远程访问了。

 

FLUSH PRIVILEGES;

 

systemctl start firewalld # 开启防火墙

systemctl stop firewalld  # 关闭防火墙

systemctl status firewalld  #检查防火墙状态

一般需要关闭防火墙才能连接。关闭远端服务器防火墙后,可以连接了

 

如果你觉得关闭防火墙不安全,可打开远端服务器的iptables(安装或升级命令“yum install iptables”)(我用root用户登录的),并用“vi /etc/sysconfig/iptables”检查3306端口是否打开,如没有,在文件中加入“-A INPUT -p tcp -m tcp –dport 3306 -j ACCEPT”(如下所示),保存文件并用“service iptables restart”命令重启iptables

 

赞(0) 打赏
未经允许不得转载:爱站程序员基地 » mysql8.0远程连接权限设置