完美解決docker安裝mysql后Navicat連接不上的問題
一、docker拉取鏡像
docker pull mysql (默認(rèn)拉取最新版本的)
二、運(yùn)行mysql
docker run -p 3308:3306 --name mysql -e MYSQL_ROOT_PASSWORD=123456 -d mysql
容器名:mysql 密碼:123456
三、查看是否運(yùn)行
docker ps -a
四、查看啟動(dòng)日志
docker logs mysql
mysql就是剛剛啟動(dòng)的容器名,確認(rèn)mysql啟動(dòng)是正常的
五、錯(cuò)誤
當(dāng)我用Navicat進(jìn)行鏈接的時(shí)候,發(fā)現(xiàn)下圖錯(cuò)誤
我們需要下面的處理方式
1、進(jìn)入mysql客戶端
docker exec -it c6c8e8e7940f /bin/bash
其中c6c8e8e7940f是我的mysql的容器名
----等價(jià)命令 docker exec -it mysql /bin/bash
mysql -u root -p123456
123456就是mysql的登錄密碼,在docker run的時(shí)候設(shè)置的
2、查看用戶信息
select host,user,plugin,authentication_string from mysql.user;
3、重新設(shè)置密碼
ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY 'newpassword'
newpassword就是新的密碼
我把密碼設(shè)置成了‘mysql'
4、使用Navicat重新連接
附:也能是防火墻的問題
sudo firewall-cmd --add-port=3306/tcp (放開3306的端口)
或者
sudo systemctl stop firewalld (關(guān)閉防火墻)
補(bǔ)充:docker安裝mysql 8 并配置遠(yuǎn)程連接
第一步:下載mysql鏡像鏡像
docker pull mysql
默認(rèn)是下載最新穩(wěn)定版
第二步:?jiǎn)?dòng)mysql鏡像
docker run --name dockermysql -p 3306:3306 -e MYSQL_ROOT_PASSWORD=mysqlpassword -d mysql
1、--name 是鏡像的別名
2、-p 將3306映射到3306(docker是個(gè)虛擬機(jī)有自己的端口)
3、-e MYSQL_ROOT_PASSWORD=mysqlpassword 設(shè)置mysql 服務(wù)器密碼(后面需要,一定記住)
4、-d 后端啟動(dòng)
5、啟動(dòng)的鏡像名稱(可以用id代替)
第三步:查詢啟動(dòng)的鏡像
docker ps
如下:
第四步:進(jìn)入容器
docker exec -it dockermysql bash
dockermysql是鏡像的名字 ,可以用id替代
第五步:登錄mysql
mysql -u root -p
然后輸入上面設(shè)置的密碼
第六步:設(shè)置遠(yuǎn)程訪問
切換數(shù)據(jù)庫(kù)(默認(rèn)應(yīng)該就是這個(gè),不切換也行,保險(xiǎn)起見切換一下)
use mysql;
更改遠(yuǎn)程鏈接授權(quán)
grant all privileges on *.* to 'root'@'%';
第七步:navicat鏈接時(shí)報(bào) 2059 錯(cuò)誤
報(bào)錯(cuò)原因是加密方式問題
查詢一下:
select Host,User,plugin from user;
沒有修改前結(jié)果如下:
執(zhí)行修改命令:
alter user 'root'@'%' identified with mysql_native_password by 'yourPassword';
修改成你的mysql密碼
修改成功后結(jié)果如下:
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。
- MySQL數(shù)據(jù)庫(kù)安裝和Navicat for MySQL配合使用教程
- 安裝mysql8.0.11及修改root密碼、連接navicat for mysql的思路詳解
- MySql 8.0.11 安裝過程及 Navicat 鏈接時(shí)遇到的問題小結(jié)
- Mysql安裝 Navicat 出現(xiàn)1044/1045錯(cuò)誤的解決方法
- Mac系統(tǒng)Navicat的安裝與使用教程
- Navicat Premium15安裝及破解教程詳解親測(cè)有效(附破解失敗解決方案)
- Navicat Premium 15 永久破解激活工具及安裝教程(親測(cè)可用)
- Mysql+Navicat16長(zhǎng)期免費(fèi)直連數(shù)據(jù)庫(kù)安裝使用超詳細(xì)教程
相關(guān)文章
Dockerfile 部署java web的環(huán)境詳解
這篇文章主要介紹了Dockerfile 構(gòu)建java web 環(huán)境詳解的相關(guān)資料,這里對(duì)Dockerfile 進(jìn)行基本介紹,并說明如何構(gòu)建java web環(huán)境進(jìn)行詳解,需要的朋友可以參考下2016-12-12基于Docker的Mysql主備搭建的實(shí)現(xiàn)步驟
本文主要介紹了基于Docker的Mysql主備搭建的實(shí)現(xiàn)步驟,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-01-01詳解docker?制作mysql鏡像并自動(dòng)安裝腳本
這篇文章主要介紹了docker mysql鏡像制作并自動(dòng)安裝腳本,主要包括centos7環(huán)境下 一鍵制作mysql docker鏡像并安裝,對(duì)docker?制作mysql鏡像shell腳本感興趣的朋友一起看看吧2022-05-05docker寫一個(gè)Dockerfile文件的實(shí)現(xiàn)
Dockerfile 是一個(gè)用來構(gòu)建鏡像的文本文件,文本內(nèi)容包含了一條條構(gòu)建鏡像所需的指令和說明,本文主要介紹了docker寫一個(gè)Dockerfile文件的實(shí)現(xiàn)2024-01-01docker中mysql開啟日志的實(shí)現(xiàn)步驟
本文主要介紹了docker中mysql開啟日志的實(shí)現(xiàn)步驟,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-07-07