
文章目錄
- 一、Docker概述:
- 1.初識Docker:
- 2.Doker的優點:
- 3.Docker的作業流程:
- 二、Docker鏡像:
- 三、Docker容器:
- 四、Dockerfile:
- 五、Docker-Compose:
- 1.Docker-Compose是做什么的:
- 2.如何使用Compose:
- 六、Dokcer常用命令:
- 七、小名的Dokerfile實體練習(含原始碼)
- 八、小名的Docker-Compose實體練習(含原始碼)
一、Docker概述:
1.初識Docker:
此概念引自:菜鳥教程
Docker 是一個開源的應用容器引擎,基于 Go 語言 并遵從 Apache2.0 協議開源,Docker 可以讓開發者打包他們的應用以及依賴包到一個輕量級、可移植的容器中,然后發布到任何流行的 Linux 機器上,也可以實作虛擬化,容器是完全使用沙箱機制,相互之間不會有任何介面(類似 iPhone 的 app),更重要的是容器性能開銷極低,
情景:
在讀小名的這篇文章之前,小名想問大伙兒一個問題:你有沒有自己在服務器上部署過專案,不論是否是前后分離的專案,
部署過的小伙伴,有沒有遇到這樣一個問題:服務器到期了或是漲價了!要換成另外一個平臺的服務器?
小名最近就碰到了這個問題,小名的“學生價服務器”馬上就要到期了,到期意味著啥?漲價啊!所以小名需要把快到期服務器上的專案遷移到新的服務器上了,此時就遇到了一個問題:小名需要把所有用到的服務都在新服務器上重新部署一遍這就很痛苦了😭直到小名學習了Docker,這一切都簡單了起來,
2.Doker的優點:
一句話:build once, run everywhere 意思是:Docker可以屏蔽環境差異,進行快速部署,
是什么讓Doker可以屏蔽環境的差異呢?是一個叫容器的技術,后文小名會提到,
3.Docker的作業流程:
小名認為,如果想要深入了解Docker,首先你一定要:分清 鏡像 和 容器 的概念;之后你可以學習Dockerfile 和 Docker-Compose
小名提供了Dokerfile實體、Docker-Compose實體

如上圖所示,Docker的操作都圍繞著這個叫鏡像的東西,
一個普通的Doker作業流程是:Doker通過從遠程倉庫(DockerHub,類似AppStore下載app的程序)拉取鏡像 → 將鏡像運行到容器中 或者 通過Dockerfile將一個自己的專案構建成鏡像,然后再運行到容器中,
二、Docker鏡像:
docker的鏡像是由一層一層的檔案系統組成,這種層級的檔案系統 UnionFS (聯合檔案系統)
UnionFs(聯合檔案系統):
Union檔案系統( UnionFs)是一種分層、輕量級并且高性能的檔案系統,它支持對檔案系統的修改作為一次提交來一層層的最加,同時可以將不同目錄掛載到同一個虛擬檔案系統下 unite several directories into a single virtual filesystem)Unin檔案系統是 Docker鏡像的基礎,鏡像可以通過分層來進行繼承,基于基礎鏡像(沒有父鏡像),可以制作各種具體的應用鏡像,
持性:一次同時加載多個檔案系統,但從外面看起來,只能看到一個檔案系統,聯合加載會把各層檔案系統疊加起來,這樣最終的檔案系統會包合所有底層的檔案和目錄

看圖理解:
第一步:底下兩層是公用的(base image 和 bootfs)
第二步:公用 + 鏡像(image)
第三步:公用 + image + image
**總結:**所有的 Docker鏡像都起始于一個基礎鏡像層,當進行修改或增加新的內容時,就會在當前鏡像層之上,創建新的鏡像層,
由于這種機制的存在,更新某個鏡像的時候無需更新更換整個大的鏡像,而是覆寫其中某一層鏡像即可,這也體現了Docker的輕量級的特性,
三、Docker容器:
說到這里,不知道大伙有沒有注意到,Docker的Logo呢?一直鯨魚托著一堆小方塊?

這些小方塊代表的就是容器(container)

container的中文意思不僅有容器的意思,而且還有集裝箱的意思,這就不免讓我們意識到:這些**容器中的內容(鏡像)**是相互隔離的,
大家都知道虛擬機(比如:VMware)吧?
其實Docker的容器技術也可以理解為是一種虛擬機,不過它比虛擬機速度快很多,可以看下這個對比的表格:
| 特性 | 虛擬機 | 容器 |
|---|---|---|
| 隔離級別 | 作業系統級 | 行程級 |
| 隔離策略 | Hypervisor(管理程式) | CGroups(限制、記錄任務組所使用的物理資源) |
| 系統資源 | 5~15% | 0~5% |
| 啟動時間 | 分鐘級 | 秒級 |
| 鏡像存盤 | GB~TB | KB~MB |
| 集群規模 | 上百 | 上萬 |
| 高可用策略 | 備份、容災、遷移 | 彈性、負載、動態 |
上面這個表格太枯燥了,再來看下小名畫這個圖吧~

通過這張圖我們不難看出,Docker將 OS 與 Hypervisor 兩層合并為一層容器了,這使得容器比虛擬機節約掉了很多的記憶體空間,使其節約了不少的資源,
四、Dockerfile:
概念:
Dockerfile是一個包含用于組合映像的命令的文本檔案,可以使用在命令列中呼叫任何命令, Docker通過讀取 Dockerfile中的指令自動生成映像,
我們可以通過Dokerfile把自己的專案構建成一個鏡像,部署到Docker的容器中,你可以通過后文小名的一個Demo跟著部署練習一下,
這里呢小名找了一張很形象的網圖,給大家看下Dockerfile的結構:

下面的樣例,是小名在后面實體練習里用到的Dockerfile檔案
FROM java:8
COPY *.jar /eamon.jar
#執行完 build 命令后執行的命令,但是可以被RUN命令覆寫
CMD ["--server.port=8080"]
EXPOSE 8080
ENTRYPOINT ["java","-jar","/eamon.jar"]
五、Docker-Compose:
此概念引自:菜鳥教程
Compose 是用于定義和運行多容器 Docker 應用程式的工具,通過 Compose,您可以使用 YML 檔案來配置應用程式需要的所有服務,然后,使用一個命令,就可以從 YML 檔案配置中創建并啟動所有服務,
1.Docker-Compose是做什么的:
通過上面的概念,我們不難理解Compose的作用了,它可以把我們自己專案通過Dokerfile檔案構建成鏡像 + 專案需要的環境“打包”運行在容器中,
2.如何使用Compose:
來到官網的幫助檔案我們可以看到,Compose對應的Docker版本,

想要應用Compose,就要撰寫一個yaml檔案,記住下面的3層結構,就可以撰寫了:
#【第一層】對應的版本號
version: "3.8"
#【第二層】所有服務
services:
#服務一:我們自己的Springboot專案
EamonTest:
#【第三層】服務配置(到下面的實體中,小名會詳細講解)
build: .
ports:
- "5000:5000"
volumes:
- .:/code
- logvolume01:/var/log
depends_on:
- redis
......
#服務二:redis服務
redis:
image: redis
volumes:
logvolume01:
我們通過執行docker-compose二進制檔案,就可以使用compose的功能了~具體的操作,可以到小名的實體練習中進行詳細的了解,
六、Dokcer常用命令:
七、小名的Dokerfile實體練習(含原始碼)
八、小名的Docker-Compose實體練習(含原始碼)
文章后期還會繼續優化,如果覺得小名的文章幫助到了您,請關注小名,支持一下小名😄,給小名的文章點贊👍、評論?、收藏🤞謝謝大家啦~???
小名在這里祝大家新年快樂!萬事如意!🎉🎉🎉
轉載請註明出處,本文鏈接:https://www.uj5u.com/ruanti/259522.html
標籤:其他
下一篇:子類為什么先死后生
