Navicat工具中設(shè)置MySQL允許外部訪問
在Navicat工具中,設(shè)置MySQL允許外部訪問。
一、在navicat上使用本地連接,先連接上。
二、修改user表訪問權(quán)限。
select * from user; # 查詢mysql庫中的user表是否有user為root的,host為%的數(shù)據(jù)。 # 如果沒有,則進(jìn)行創(chuàng)建。 create user 'root'@'%' identified by '密碼' ; # 密碼使用自己設(shè)置的數(shù)據(jù)庫密碼 # 創(chuàng)建好后,或者有的話,則再執(zhí)行授權(quán)語句 grant all privileges on *.* to 'root'@'%' with grant option; # flush privileges;
然后外部就可以通過賬戶密碼訪問了。
說明:
1、※ grant語法: grant 權(quán)限名(所有的權(quán)限用all) on 庫名(*全部).表名(*全部) to ‘要授權(quán)的用戶名’@’%’(%表示所有的IP,可以只設(shè)一個IP) identified by “密碼”;
2、其它說明:
FLUSH PRIVILEGES; 命令本質(zhì)上的作用是:
將當(dāng)前user和privilige表中的用戶信息/權(quán)限設(shè)置從mysql庫(MySQL數(shù)據(jù)庫的內(nèi)置庫)中提取到內(nèi)存里。
MySQL用戶數(shù)據(jù)和權(quán)限有修改后,希望在”不重啟MySQL服務(wù)”的情況下直接生效,那么就需要執(zhí)行這個命令。
通常是在修改ROOT帳號的設(shè)置后,怕重啟后無法再登錄進(jìn)來,那么直接flush之后就可以看權(quán)限設(shè)置是否生效。
而不必冒太大風(fēng)險。
三、可能存在的其它問題:
執(zhí)行完之后,再用Navicat連接mysql,報錯如下:
Client does not support authentication protocol requested by server;
報錯原因:
mysql8.0 引入了新特性 caching_sha2_password;這種密碼加密方式Navicat 12以下客戶端不支持;
Navicat 12以下客戶端支持的是mysql_native_password 這種加密方式;
解決方案:
1,用如下語句查看MySQL當(dāng)前加密方式
select host,user,plugin from user;
查詢結(jié)果
+-----------+------------------+-----------------------+
| host | user | plugin |
+-----------+------------------+-----------------------+
| % | root | caching_sha2_password |
| localhost | mysql.infoschema | mysql_native_password |
| localhost | mysql.session | mysql_native_password |
| localhost | mysql.sys | mysql_native_password |
+-----------+------------------+-----------------------+
看host為’%'的那一行,root加密方式為caching_sha2_password。
2,使用命令將他修改成mysql_native_password加密模式:
update user set plugin='mysql_native_password' where user='root';
再次連接的時候,就成功了。
四、如果還連接不上
通過以上操作后,依然無法連接上,問題可能出在了防火墻上。
1,MySQL部署在實體服務(wù)器上解決方案如下:
a.開放MySQL的端口號,默認(rèn)端口號是3306。b.直接關(guān)閉防火墻(慎重操作,不建議。當(dāng)然測試玩的話就隨意了。。。。)
2,MySQL部署在云計算機上的方案如下:a.以阿里云為例,找到實例,設(shè)置安全組,開放端口號即可。
附:mysql 允許其他ip訪問
1.改表法
可能是你的帳號不允許從遠(yuǎn)程登陸,只能在localhost。這個時候只要在localhost的那臺電腦,登入mysql后,更改 “mysql” 數(shù)據(jù)庫里的 “user” 表里的 “host” 項,從"localhost"改稱"%"
//執(zhí)行以下sql語句 USE mysql; UPDATE USER SET HOST = '%' WHERE USER = 'root'; SELECT HOST, USER FROM USER; FLUSH PRIVILEGES;
測試連接成功
總結(jié)
到此這篇關(guān)于Navicat工具中設(shè)置MySQL允許外部訪問的文章就介紹到這了,更多相關(guān)MySQL允許外部訪問內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Mysql中 show table status 獲取表信息的方法
這篇文章主要介紹了Mysql中 show table status 獲取表信息的方法的相關(guān)資料,需要的朋友可以參考下2016-03-03mysql中數(shù)據(jù)統(tǒng)計的技巧備忘錄
mysql是常用數(shù)據(jù)庫,對于數(shù)字操作相關(guān)的東西相當(dāng)方便,這篇文章主要給大家介紹了關(guān)于mysql中數(shù)據(jù)統(tǒng)計技巧的相關(guān)資料,非常具有實用價值,需要的朋友可以參考下2018-05-05centos7環(huán)境下創(chuàng)建mysql5.6多實例的方法詳解
這篇文章主要介紹了centos7環(huán)境下創(chuàng)建mysql5.6多實例的方法,詳細(xì)分析了centos7創(chuàng)建mysql5.6多實例的具體步驟、實現(xiàn)方法與操作注意事項,需要的朋友可以參考下2020-02-02MySQL中REPLACE INTO和INSERT INTO的區(qū)別分析
REPLACE的運行與INSERT很相似。只有一點例外,假如表中的一個舊記錄與一個用于PRIMARY KEY或一個UNIQUE索引的新記錄具有相同的值,則在新記錄被插入之前,舊記錄被刪除。2011-07-07設(shè)置MySQL自動增長從某個指定的數(shù)開始方法
下面小編就為大家?guī)硪黄O(shè)置MySQL自動增長從某個指定的數(shù)開始方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-01-01