Centos7 mysql5.7 远程登录解决方案

查看服务器安全组是否开放3306端口

未开放添加安全组规则,以开放接着一下步

如果是初次登录,未设置密码,请移步 https://blog.csdn.net/DK_ajie/article/details/88170734

进行赋权

mysql 5.7   

登陆进去mysql终端

use mysql;

update user set host = '%' where user = 'root'; (使mysql root用户可以连接上任意的ip地址)

FLUSH PRIVILEGES

防火墙相关

 CentOS7的默认防火墙为firewall,且默认是不打开的。

  shell > systemctl start firewalld 启动friewall

  shell > systemctl status firewalld 查看firewall启动情况

  shell > firewall-cmd --zone=public --add-port=3306/tcp --permanent 开启3306端口

  然后重启 firewalld  #firewall-cmd --reload

  使用 # firewall-cmd --query-port=3306/tcp 检查3306端口是否已经开启,如果显示yes,则表示防火墙已开启该端口。

  (当然也可以关闭centos7的默认防火墙 #systemctl stop firewalld 和禁用#systemctl mask firewalld。然后使用iptables防火墙,centos7默认是没有安装iptables的,同样#yum install iptables #yum install iptables-services两步进行安装即可。这有一博友的详细iptables安装配置和讲解,我这就直接借用了。https://www.cnblogs.com/anne32184/p/5961806.html)

  然后回到window 再进行MySQL远程连接时(mysql -h 168.x.x.x -u root -p),报同样的错误,这让我很是无语,然后又试了各种方法,逛各种博客网站,连mysql版本不同,端口为tcp6等不着边的都去想了,但还是无解。(v _ v)

你可能感兴趣的:(Centos7 mysql5.7 远程登录解决方案)