Docker中部署mysql服務(wù)的方法及遇到的坑
最近一直在學(xué)習(xí)搬運(yùn)工,感覺這么厲害的東西怎么以前不知道呢,把自己搗鼓的過程整理記錄下來,供同學(xué)們參考
第零步:從Docker Hub拉取官方mysql鏡像
docker pull mysql
然后就是進(jìn)入漫長的等待,當(dāng)然如果你配置了鏡像加速器,速度會(huì)快那么一丟丟
第一步:使用docker images命令查看鏡像

你會(huì)看到我們這里已經(jīng)有了MySQL的的鏡像
第二步:啟動(dòng)我們的mysql的鏡像,創(chuàng)建一個(gè)MySQL的容器
使用命令:docker run -d --name mysql -p 3307:3306 -e MYSQL_ROOT_PASSWORD=123456 mysql
解釋一下這里的參數(shù):
-d表示在后臺(tái)運(yùn)行,不隨當(dāng)前命令行窗口的退出而退出
--name給容器起一個(gè)別名,以后可以通過這個(gè)別名管理此容器
-p 3307:3307把宿主機(jī)的3307端口映射到Mysql容器的3306端口
-e MySQL容器的環(huán)境配置
MYSQL_ROOT_PASSWORD=123456 指定mysql的密碼,用戶名默認(rèn)為root,注意如果沒有指定密碼,會(huì)啟動(dòng)失敗
第三步:查看我們已經(jīng)啟動(dòng)的mysql容器
使用命令:docker ps

可以看到,我們的MySQL的的的的容器已經(jīng)跑起來了,dockeer給mysql的的的的容器分配了一個(gè)容器的編號(hào),便于我們管理,還顯示我們?cè)O(shè)置的端口映射情況
這個(gè)時(shí)候有的老哥可能會(huì)想,雖然MySQL的的的的容器歡快的跑起來了,但是你丫只告訴我們端口,我們?cè)趺粗浪腎P呢,我信你個(gè)鬼你的老頭子壞得很。
不不不。我們可以使用docker inspect -f ='{{。NetworkSettings.IPAddress}}'5fef288f221f命令查看容器的ip,注意最后直接寫要查看的容器的id即可,網(wǎng)上那些人壞得很,還給你加一個(gè)<>,導(dǎo)致你很郁悶,就照我這樣準(zhǔn)沒錯(cuò)
還有一點(diǎn)需要注意的是:要是想在外部連接我們的Mysql容器,進(jìn)行遠(yuǎn)程管理的話,需要配置容器里mysql的root賬戶的主機(jī),把它改成一個(gè)通配符%,就可以讓任意主機(jī)連接我們的MySQL的了,具體方法如下:
進(jìn)入MySQl容器:使用的docker exec命令,-it是參數(shù),bash表示創(chuàng)建一個(gè)交互界面

登錄mysql服務(wù)器:使用的root用戶登錄mysql,在輸入密碼之后,我們可以看到已經(jīng)進(jìn)去了mysql

使用show數(shù)據(jù)庫; 命令查看數(shù)據(jù)庫(注意不要忘了最后的分號(hào)中,MySQL的命令都要有分號(hào))

可以看到,我們的數(shù)據(jù)庫都列了出來,然后使用mysql; 命令進(jìn)入MySQL的這個(gè)數(shù)據(jù)庫(是不是很繞口,哈哈哈,這里的MySQL的數(shù)據(jù)庫是指的這一個(gè)數(shù)據(jù)庫,好吧我可能還是沒說明白)
然后使用show tables; 命令列出所有的表

可以看到,有好多個(gè)表,這都是MySQL的的配置,不用去關(guān)注,我們只需要修改一個(gè)用戶表即可
使用sql命令:update user set host ='%'where user ='root';
這個(gè)命令有的同學(xué)可能會(huì)報(bào)錯(cuò),原因是你的MySQL的可能有多個(gè)根用戶,所以要用下面的命令
update user set host ='%'其中user ='root'和host ='localhost';
配置完上面的步驟可以測試一下連接,如果能夠連接上,恭喜你,你很幸運(yùn)。
如果連不上,也要恭喜你,因?yàn)槟阆碌膍ysql鏡像是mysql8的,
你可能會(huì)遇見下面這個(gè)錯(cuò)誤
至此,配置完成,使用退出; 命令退出即可。
測試遠(yuǎn)程連接

第四步:向我們的MySQL的容器導(dǎo)入數(shù)據(jù)
雖然我們的Mysql的的的的容器跑起來了,但是這里面沒數(shù)據(jù)啊,可以通過以下方法向docker中的MySQL導(dǎo)入數(shù)據(jù)庫
先將文件導(dǎo)入到容器,cp后面是你準(zhǔn)備導(dǎo)入的sql文件路徑
#docker cp **.sql mysql:/root/ 進(jìn)入容器 #docker exec -it mysql bash 將文件導(dǎo)入數(shù)據(jù)庫 # mysql -uroot -p 【數(shù)據(jù)庫名】 < ***.sql mysql -h localhost -u root -p(進(jìn)入mysql下面) create database abc;(創(chuàng)建數(shù)據(jù)庫) show databases;(就可看到所有已經(jīng)存在的數(shù)據(jù)庫,以及剛剛創(chuàng)建的數(shù)據(jù)庫abc) use abc;(進(jìn)入abc數(shù)據(jù)庫下面) show tables;(產(chǎn)看abc數(shù)據(jù)庫下面的所有表,空的) source /var/test.sql(導(dǎo)入數(shù)據(jù)庫表) show tables;(查看abc數(shù)據(jù)庫下面的所有表,就可以看到表了) desc pollution;(查看表結(jié)構(gòu)設(shè)計(jì)) select * from pollution; exit(或者ctrl + c)退出mysql
總結(jié)
以上所述是小編給大家介紹的Docker中部署mysql服務(wù)的方法,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
docker啟動(dòng)MySQL容器失敗原因分析以及排查記錄
在使用Docker啟動(dòng)MySQL容器時(shí),遇到了配置文件路徑錯(cuò)誤的問題,通過查看容器日志發(fā)現(xiàn),容器讀取的配置文件路徑與指定的不一致,解決方法是修改啟動(dòng)命令中的配置文件路徑,將其指向正確的目錄,最終,容器成功啟動(dòng)并進(jìn)入U(xiǎn)p狀態(tài)2025-02-02
如何Docker化Python Django應(yīng)用程序
今天小編就為大家分享一篇關(guān)于如何Docker化Python Django應(yīng)用程序的文章,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧2018-09-09
Docker Compose快速部署多容器服務(wù)實(shí)戰(zhàn)的實(shí)例詳解
使用 Docker Compose 可以輕松、高效的管理容器,它是一個(gè)用于定義和運(yùn)行多容器 Docker 的應(yīng)用程序工具,本文給大家介紹Docker Compose快速部署多容器服務(wù)實(shí)戰(zhàn),感興趣的朋友一起看看吧2022-02-02
使用Docker鏡像構(gòu)建Go應(yīng)用的實(shí)現(xiàn)方法
本文主要介紹了使用Docker鏡像構(gòu)建Go應(yīng)用的實(shí)現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03
解決Docker錯(cuò)誤“docker?build“?requires?exactly?1?argument(s)
這篇文章主要介紹了解決Docker錯(cuò)誤“docker?build“?requires?exactly?1?argument(s)問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-08-08
完美解決docker安裝mysql后Navicat連接不上的問題
這篇文章主要介紹了完美解決docker安裝mysql后Navicat連接不上的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2021-03-03

