首頁 > 軟體

完美解決docker安裝mysql後Navicat連線不上的問題

2021-03-19 10:00:34

一、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進行連結的時候,發現下圖錯誤

我們需要下面的處理方式

1、進入mysql使用者端

docker exec -it c6c8e8e7940f /bin/bash

其中c6c8e8e7940f是我的mysql的容器名

----等價命令 docker exec -it mysql /bin/bash

mysql -u root -p123456

123456就是mysql的登入密碼,在docker run的時候設定的

2、檢視使用者資訊

select host,user,plugin,authentication_string from mysql.user;

3、重新設定密碼

ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY 'newpassword'

newpassword就是新的密碼

我把密碼設定成了‘mysql'

4、使用Navicat重新連線

附:也能是防火牆的問題

sudo firewall-cmd --add-port=3306/tcp (放開3306的埠)

或者

sudo systemctl stop firewalld (關閉防火牆)

補充:docker安裝mysql 8 並設定遠端連線

第一步:下載mysql映象映象

docker pull mysql

預設是下載最新穩定版

第二步:啟動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 設定mysql 伺服器密碼(後面需要,一定記住)

4、-d 後端啟動

5、啟動的映象名稱(可以用id代替)

第三步:查詢啟動的映象

docker ps

如下:

第四步:進入容器

docker exec -it dockermysql bash

dockermysql是映象的名字 ,可以用id替代

第五步:登入mysql

mysql -u root -p

然後輸入上面設定的密碼

第六步:設定遠端存取

切換資料庫(預設應該就是這個,不切換也行,保險起見切換一下)

use mysql;

更改遠端連結授權

grant all privileges on *.* to 'root'@'%';

第七步:navicat連結時報 2059 錯誤

報錯原因是加密方式問題

查詢一下:

select Host,User,plugin from user;

沒有修改前結果如下:

執行修改命令:

alter user 'root'@'%' identified with mysql_native_password by 'yourPassword';

修改成你的mysql密碼

修改成功後結果如下:

以上為個人經驗,希望能給大家一個參考,也希望大家多多支援it145.com。如有錯誤或未考慮完全的地方,望不吝賜教。


IT145.com E-mail:sddin#qq.com