Linux centos7开放MySQL8 端口3306给远程访问
安装mysql后,默认mysql的用户是没有远程访问的权限的,因此需要开启mysql的远程访问权限。第一步:mysql允许其他非localhost用户访问开启mysql用户的远程访问权限,有两种方法:1.改表法和授权法1.改表法:修改mysql库的user表,将host项,从localhost改为%。%这里表示的是允许任意host访问,如果只允许某一个ip访问,则可改为相应的ip,...
安装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'@'%'; #查看用户的权限
更多推荐
所有评论(0)