docker是一個(gè)開源的應(yīng)用容器引擎,docker能做的事:1、快速搭建開發(fā)環(huán)境;2、模擬生產(chǎn)環(huán)境;3、自動(dòng)測(cè)試;4、進(jìn)行自我部署;5、進(jìn)行持續(xù)集成(持續(xù)部署);6、管理單個(gè)機(jī)器上的所有服務(wù);7、擴(kuò)容QPS等。
本教程操作環(huán)境:linux5.9.8系統(tǒng)、docker-1.13.1版、Dell G3電腦。
docker是什么?
Docker 是一個(gè)開源的應(yīng)用容器引擎,讓開發(fā)者可以打包他們的應(yīng)用以及依賴包到一個(gè)可移植的鏡像中,然后發(fā)布到任何流行的 Linux或Windows操作系統(tǒng)的機(jī)器上,也可以實(shí)現(xiàn)虛擬化。容器是完全使用沙箱機(jī)制,相互之間不會(huì)有任何接口。
docker能做什么?
1、快速搭建開發(fā)環(huán)境
你需要在本地系統(tǒng)快速嘗試 Magento,或者為一個(gè)項(xiàng)目使用 MySQL?還是希望嘗試大部分開源項(xiàng)目?那就使用 Docker 吧,它將幫你節(jié)省大量時(shí)間。Docker 能提升開發(fā)者的開發(fā)效率,讓我們快速搭建開發(fā)環(huán)境。
開發(fā)環(huán)境的機(jī)器通常內(nèi)存比較小,此前使用虛擬的時(shí)候,經(jīng)常需要為開發(fā)環(huán)境的機(jī)器加內(nèi)存,而通過(guò) Docker 可以輕易的讓幾十個(gè)服務(wù)在 Docker 中跑起來(lái)。
2、微服務(wù)(Microservices)
你在使用微服務(wù)嗎?微服務(wù)架構(gòu) —— 將一個(gè)整體式的應(yīng)用拆分成松耦合的單個(gè)服務(wù)。
那不妨考慮一下 Docker,你可以將每個(gè)服務(wù)打包為一個(gè) docker 鏡像并使用 docker-compose 來(lái)模擬生產(chǎn)環(huán)境(checkout docker networks)。最開始實(shí)踐的時(shí)候可能會(huì)比較費(fèi)時(shí)費(fèi)力,但長(zhǎng)遠(yuǎn)地來(lái)看,最終將產(chǎn)生巨大的生產(chǎn)力。
3、自動(dòng)測(cè)試(Automated testing)
試想這樣一個(gè)問(wèn)題,如何編寫自動(dòng)化的集成測(cè)試用例,這些測(cè)試用例無(wú)需花很長(zhǎng)時(shí)間來(lái)開始運(yùn)行,使用者也可輕松管理。
這里不是指在 Docker 中運(yùn)行測(cè)試用例,而是將測(cè)試用例與鏡像緊密運(yùn)行在一起。當(dāng)你針對(duì)一個(gè) docker 鏡像編寫測(cè)試用例時(shí)會(huì)有一個(gè)很大的優(yōu)勢(shì)。下面簡(jiǎn)單介紹一下我的測(cè)試流程:運(yùn)行兩個(gè) docker 鏡像(app + db),在 MySQL 啟動(dòng)時(shí)加載數(shù)據(jù),并在 app docker 上使用 API。
4、進(jìn)行自我部署
你可以使用 docker 鏡像進(jìn)行自我部署。許多主流的主機(jī)提供商都支持托管 docker,如果你擁有一個(gè)具有 shell 訪問(wèn)權(quán)限的專用節(jié)點(diǎn)/vm,那么事情將變得更容易。只需要設(shè)置好 docker,并在你想要的端口上運(yùn)行你的鏡像即可。
5、持續(xù)集成/持續(xù)部署(Continuous Deployment)
都說(shuō) Docker 天生適合持續(xù)集成/持續(xù)部署,在部署中使用 Docker,持續(xù)部署將變得非常簡(jiǎn)單,并會(huì)在進(jìn)入新的鏡像后重新開始。
關(guān)于這個(gè)部分的自動(dòng)化工作,現(xiàn)在已經(jīng)有許多方案以供選擇,Kubernetes 就是一個(gè)耳熟能詳?shù)拿?。Kubernetes是容器集群管理系統(tǒng),是一個(gè)開源的平臺(tái),可以實(shí)現(xiàn)容器集群的自動(dòng)化部署、自動(dòng)擴(kuò)縮容、維護(hù)等功能。
6、多租戶環(huán)境(Multi-tenancy)
Docker 有意思的一個(gè)使用場(chǎng)景是在多租戶的應(yīng)用中,它可以避免關(guān)鍵應(yīng)用的重寫。如果你將應(yīng)用程序服務(wù)公開給多個(gè)租戶(租戶指一組用戶,例如組織),使用單租戶方案設(shè)計(jì)的應(yīng)用程序如果用上了 sub-domain + docker 可以快速獲得提供多租戶的服務(wù)。
關(guān)于這個(gè)場(chǎng)景的一個(gè)例子是為物聯(lián)網(wǎng)的應(yīng)用開發(fā)一個(gè)快速、易用的多租戶環(huán)境。這種多租戶的基本代碼非常復(fù)雜,很難處理,重新規(guī)劃這樣一個(gè)應(yīng)用不但消耗時(shí)間,也浪費(fèi)金錢。使用 Docker,可以為每一個(gè)租戶的應(yīng)用層的多個(gè)實(shí)例創(chuàng)建隔離的環(huán)境,這不僅簡(jiǎn)單而且成本低廉,當(dāng)然這一切得益于 Docker 環(huán)境的啟動(dòng)速度和其高效的 diff 命令。
7、來(lái)自一臺(tái)機(jī)器的多個(gè) APP(Multiple apps from one machine)
這與上面提到的微服務(wù)有些聯(lián)系,但即使你沒有使用微服務(wù),只是提供服務(wù),Docker 仍可以很好地管理單個(gè)機(jī)器上的所有服務(wù)。你應(yīng)該使用文件夾掛載來(lái)為每個(gè)基于數(shù)據(jù)的 docker 鏡像保留數(shù)據(jù)。
8、擴(kuò)容 QPS(Scaling QPS)
Docker 通過(guò)創(chuàng)建另一個(gè)容器來(lái)幫助你輕松地進(jìn)行水平擴(kuò)展。如果遇到巨大的高峰流量,Docker 可以幫助你解決問(wèn)題 —— 只需添加