完美解決docker安裝mysql后Navicat連接不上的問題
一、docker拉取鏡像
docker pull mysql (默認拉取最新版本的)
二、運行mysql
docker run -p 3308:3306 --name mysql -e MYSQL_ROOT_PASSWORD=123456 -d mysql
容器名:mysql 密碼:123456
三、查看是否運行
docker ps -a
四、查看啟動日志
docker logs mysql
mysql就是剛剛啟動的容器名,確認mysql啟動是正常的
五、錯誤
當我用Navicat進行鏈接的時候,發(fā)現(xiàn)下圖錯誤

我們需要下面的處理方式
1、進入mysql客戶端
docker exec -it c6c8e8e7940f /bin/bash
其中c6c8e8e7940f是我的mysql的容器名
----等價命令 docker exec -it mysql /bin/bash
mysql -u root -p123456
123456就是mysql的登錄密碼,在docker run的時候設(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)閉防火墻)
補充:docker安裝mysql 8 并配置遠程連接
第一步:下載mysql鏡像鏡像
docker pull mysql
默認是下載最新穩(wěn)定版
第二步:啟動mysql鏡像
docker run --name dockermysql -p 3306:3306 -e MYSQL_ROOT_PASSWORD=mysqlpassword -d mysql
1、--name 是鏡像的別名
2、-p 將3306映射到3306(docker是個虛擬機有自己的端口)
3、-e MYSQL_ROOT_PASSWORD=mysqlpassword 設(shè)置mysql 服務器密碼(后面需要,一定記住)
4、-d 后端啟動
5、啟動的鏡像名稱(可以用id代替)
第三步:查詢啟動的鏡像
docker ps
如下:

第四步:進入容器
docker exec -it dockermysql bash
dockermysql是鏡像的名字 ,可以用id替代
第五步:登錄mysql
mysql -u root -p
然后輸入上面設(shè)置的密碼
第六步:設(shè)置遠程訪問
切換數(shù)據(jù)庫(默認應該就是這個,不切換也行,保險起見切換一下)
use mysql;
更改遠程鏈接授權(quán)
grant all privileges on *.* to 'root'@'%';
第七步:navicat鏈接時報 2059 錯誤
報錯原因是加密方式問題
查詢一下:
select Host,User,plugin from user;
沒有修改前結(jié)果如下:

執(zhí)行修改命令:
alter user 'root'@'%' identified with mysql_native_password by 'yourPassword';
修改成你的mysql密碼
修改成功后結(jié)果如下:

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。
- MySQL數(shù)據(jù)庫安裝和Navicat for MySQL配合使用教程
- 安裝mysql8.0.11及修改root密碼、連接navicat for mysql的思路詳解
- MySql 8.0.11 安裝過程及 Navicat 鏈接時遇到的問題小結(jié)
- Mysql安裝 Navicat 出現(xiàn)1044/1045錯誤的解決方法
- Mac系統(tǒng)Navicat的安裝與使用教程
- Navicat Premium15安裝及破解教程詳解親測有效(附破解失敗解決方案)
- Navicat Premium 15 永久破解激活工具及安裝教程(親測可用)
- Mysql+Navicat16長期免費直連數(shù)據(jù)庫安裝使用超詳細教程
相關(guān)文章
啟動docker錯誤systemctl status docker.service問題及解決
文章討論了啟動Docker和執(zhí)行docker ps命令失敗的問題,但docker -v顯示成功,解決辦法包括在阿里云容器鏡像中找到鏡像加速器或使用公共鏡像地址,默認情況下,Docker使用官方地址2025-01-01
Docker網(wǎng)絡(luò)配置與自定義IP容器通信
IP地址是Docker容器在網(wǎng)絡(luò)中的唯一標識,每個Docker都會被分配一個 IP,用于網(wǎng)絡(luò)通信,本文主要介紹了Docker網(wǎng)絡(luò)配置與自定義IP容器通信,感興趣的可以了解一下2024-03-03
docker 中的–mount 和-v 參數(shù)區(qū)別解析
這篇文章主要介紹了docker 中的–mount 和-v 參數(shù)區(qū)別解析,--mount 更為靈活,適用于更復雜的掛載需求,使用哪種方式主要取決于個人或團隊的偏好和具體的使用場景,需要的朋友可以參考下2023-12-12
Ubuntu系統(tǒng)下docker?Pull鏡像錯誤timeout解決辦法
最近在用docker搭個開發(fā)環(huán)境,發(fā)現(xiàn)在拉取鏡像的時候有點問題,這篇文章主要給大家介紹了關(guān)于Ubuntu系統(tǒng)下docker?Pull鏡像錯誤timeout的解決辦法,文中通過代碼介紹的非常詳細,需要的朋友可以參考下2024-07-07
Docker從零構(gòu)建php-nginx-alpine鏡像的方法
這篇文章主要介紹了Docker從零構(gòu)建php-nginx-alpine鏡像的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-11-11
使用docker compose安裝FastDfs文件服務器的實例詳解
這篇文章主要介紹了使用docker compose安裝FastDfs文件服務器的實例詳解,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-10-10

