完美解決docker安裝mysql后Navicat連接不上的問題
docker pull mysql (默認拉取最新版本的)
二、運行mysqldocker 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;
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替代
第五步:登錄mysqlmysql -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密碼
修改成功后結果如下:
以上為個人經驗,希望能給大家一個參考,也希望大家多多支持好吧啦網。如有錯誤或未考慮完全的地方,望不吝賜教。
相關文章:
1. 恢復從 Access 2000、 Access 2002 或 Access 2003 中數據庫刪除表的方法2. Mysql入門系列:建立MYSQL客戶機程序的一般過程3. 啟動MYSQL出錯 Manager of pid-file quit without updating file.4. Microsoft Office Access修改代碼字體大小的方法5. MySQL中InnoDB和MyISAM類型的差別6. MySQL 8.0 之索引跳躍掃描(Index Skip Scan)7. MySQL 字符串函數:字符串截取8. Mysql入門系列:MYSQL創建、刪除、索引和更改表9. ACCESS轉SQL數據庫相關的幾個技能10. mysql數據存放的位置在哪
