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'@'%';   #查看用户的权限
 

发布了112 篇原创文章 · 获赞 6 · 访问量 23万+

猜你喜欢

转载自blog.csdn.net/fen_fen/article/details/105031986