Linux centos7开放MySQL8 端口3306给远程访问

安装mysql后,默认mysql的用户是没有远程访问的权限的,因此需要开启mysql的远程访问权限。

第一步:mysql允许其他非localhost用户访问

开启mysql用户的远程访问权限,有两种方法:1.改表法和授权法

1.改表法:

修改mysql库的user表,将host项,从localhost改为%。%这里表示的是允许任意host访问,如果只允许某一个ip访问,则可改为相应的ip,比如可以将localhost改为192.168.81.130,这表示只允许局域网的192.168.81.130这个ip远程访问mysql。

[helen@linuxprobe ~]$ mysql -uroot -p

mysql> use mysql;

mysql> update user set host = '%' where user = 'root';

mysql> select host, user from user;

mysql> flush privileges;

[helen@linuxprobe ~]$ mysql -uroot -p

Enter password:

mysql> use mysql

Reading table information for completion of table and column names

You can turn off this feature to get a quicker startup with -A

Database changed

mysql> update user set host = '%' where user = 'root';

Query OK, 1 row affected (0.24 sec)

Rows matched: 1  Changed: 1  Warnings: 0

mysql> select host, user from user;

+-----------+------------------+

| host      | user             |

+-----------+------------------+

| %         | root             |

| localhost | mysql.infoschema |

| localhost | mysql.session    |

| localhost | mysql.sys        |

+-----------+------------------+

4 rows in set (0.01 sec)

mysql> flush privileges;

Query OK, 0 rows affected (0.27 sec)

2.授权法

mysql> GRANT ALL PRIVILEGES ON *.* TO root@"%" IDENTIFIED BY "Hu12345@";

mysql> flush privileges;

第二步:查看端口是否打开

[helen@linuxprobe ~]$ netstat -an|grep 3306

tcp6       0      0 :::33060                :::*                    LISTEN     

tcp6       0      0 :::3306                 :::*                    LISTEN

第三步:centos-7防火墙firewall开放端口3306,运行命令,并重启

[root@linuxprobe etc]# firewall-cmd --zone=public --add-port=3306/tcp --permanent

Success

[root@linuxprobe etc]# firewall-cmd --reload

success

--->注意:这里需用Linux管理员用户root执行此命令(其他用户会提示Authorization failed.)

第4步:navicat连接mysql数据库

出现问题:navicat连接mysql数据库时提示:2059错误

出现原因:navicat链接mysql8以后的版本时,会出现2059的错误,这个错误出现的原因是在mysql8之前的版本中加密规则为mysql_native_password,而在mysql8以后的加密规则为caching_sha2_password。

解决方式有两种方法,1. 是更新navicat驱动来解决此问题,2.将mysql用户登录的加密规则修改为mysql_native_password。

解决方法2:此处是将mysql用户登录的加密规则修改为mysql_native_password。

mysql> ALTER USER 'root'@'%' IDENTIFIED BY 'Hu12345@' PASSWORD EXPIRE NEVER;

Query OK, 0 rows affected (0.01 sec)

mysql> ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY 'Hu12345@';

Query OK, 0 rows affected (0.01 sec)

mysql> FLUSH PRIVILEGES;

Query OK, 0 rows affected (0.01 sec)

#FLUSH PRIVILEGES;刷新权限后,navicat再连接试试,连接成功,yet。

其他:

#创建远程访问%新用户     
mysql> create user myuser@'%' identified by 'Hu12345@';
Query OK, 0 rows affected (0.01 sec)

mysql> ALTER USER 'myuser'@'%' IDENTIFIED BY 'Hu12345@' PASSWORD EXPIRE NEVER;
Query OK, 0 rows affected (0.28 sec)

mysql> ALTER USER 'myuser'@'%' IDENTIFIED WITH mysql_native_password BY 'Hu12345@';
Query OK, 0 rows affected (0.00 sec)

mysql> FLUSH PRIVILEGES;
Query OK, 0 rows affected (0.00 sec)

#授权用户访问mysql数据库

mysql> grant all privileges on *.* to myuser;    #授权

mysql> show grants for 'myuser'@'%';   #查看用户的权限
 

  • 2
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

宁宁可可

您的鼓励是我创作的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值