MySQL8.0设置远程访问权限的方法
上一篇文章讲解了重置MySQL的密码,有同学反馈无法程连接到数据库,这是因为MySQL安装完成后只支持localhost访问,我们必须设置一下才可以远程访问,另外还有一些MySQL8.0连接时的一些问题,本文也会一并进行讲解如何解决。
1.登录MySQL
mysql-uroot-p
输入您的密码
2.选择mysql数据库
usemysql;
因为mysql数据库中存储了用户信息的user表。
3.在mysql数据库的user表中查看当前root用户的相关信息
selecthost,user,authentication_string,pluginfromuser;
执行完上面的命令后会显示一个表格
查看表格中root用户的host,默认应该显示的localhost,只支持本地访问,不允许远程访问。
4.授权root用户的所有权限并设置远程访问
GRANTALLON*.*TO'root'@'%';
GRANTALLON表示所有权限,%表示通配所有host,可以访问远程。
5.刷新权限
所有操作后,应执行
flushprivileges;
6.查看root用户的host
再次执行步骤2,你会发现root用户的host已经变成%,说明我们的修改已经成功,可以远程访问了。
7.访问数据库
远程访问数据库的可视化工具比较多如:Navicat、SQLyog、MySQLworkbench等,我这里使用Navicat
输入访问的host和密码,报2059错误,这是因为MySql8.0版本和5.0的加密规则不一样,而现在的可视化工具只支持旧的加密方式。
此问题有两种方法,一种是更新Navicat驱动来解决此问题,另一种是将MySQL用户登录的加密规则修改为mysql_native_password,第一种方法我试过了没有起作用,我这里采用第二种方法。
8.修改加密规则
ALTERUSER'root'@'localhost'IDENTIFIEDBY'password'PASSWORDEXPIRENEVER;
password为你当前密码。
9.更新root用户密码
ALTERUSER'root'@'%'IDENTIFIEDWITHmysql_native_passwordBY'password';
password为你新设置的密码。
10.刷新权限
FLUSHPRIVILEGES;
OK,设置完成,再次使用Navicat连接数据库
到此这篇关于MySQL8.0设置远程访问权限的方法的文章就介绍到这了,更多相关MySQL8.0远程访问权限内容请搜索毛票票以前的文章或继续浏览下面的相关文章希望大家以后多多支持毛票票!