怎么在Docker中運行多個MySQL容器?很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。
10年積累的成都網(wǎng)站制作、網(wǎng)站設計經(jīng)驗,可以快速應對客戶對網(wǎng)站的新想法和需求。提供各種問題對應的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡服務。我雖然不認識你,你也不認識我。但先網(wǎng)站制作后付款的網(wǎng)站建設流程,更有橋西免費網(wǎng)站建設讓你可以放心的選擇與我們合作。
1.使用mysql/mysql-server:latest鏡像快速啟動一個Mysql實例
docker run --name ilink_user_01 -e MYSQL_ROOT_PASSWORD=123456 0d 0p 3307:3306 mysql/mysql-server:latest
ilink_user_01是容器名稱,通過--name指令指定
123456為數(shù)據(jù)庫root的密碼,通過-e指定環(huán)境MYSQL_ROOT_PASSWORD為123456,-e (指定容器內的環(huán)境變量)
-d 使用-d參數(shù),容器會進入到后臺,用戶無法看到容器中的信息,也無法進行操作
3307:3306 為端口映射,指定本地主機端口3307映射到容器的3306端口
2.進入實例修改mysql配置信息
docker exec -it ilink_user_01 bash
exec 可以在容器內部直接執(zhí)行人員命令
參數(shù) -it 用來保存表中輸入的打開,在不影響容器內其他應用的潛艇先,用戶可以很容易的與容器進行交互
3.查看MYSQL數(shù)據(jù)庫中所有用戶
SELECT DISTINCT CONCAT('User: ''',user,'''@''',host,''';') AS query FROM mysql.user;
4.修改mysql的root用戶允許從任何ip登錄用戶
update mysql.user set host='%' where user='root'; flush privileges;
5.使用navicat測試連接
出現(xiàn)authentication plugin 'caching_sha2_password',因為mysql鏡像是使用caching_sha2_password進行加密的,而navicat沒有支持caching_sha2_password加密方式,
6.解決authentication plugin 'caching_sha2_password'
ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '123456';
7.重新使用navicat 連接
看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝您對創(chuàng)新互聯(lián)的支持。