本篇文章為大家展示了Docker和容器鏡像的區別是什么,內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。

很多剛剛接觸容器技術的朋友,不容易弄清楚容器,容器鏡像和Docker這幾個詞的區別和聯系。
我們首先來看容器和容器鏡像。舉個例子,執行命令行docker search nginx,搜索結果的一條條記錄就是一個個容器鏡像。
所謂鏡像,就是一個靜態概念,一個鏡像由若干只讀層(read-only layer)構成。
上圖左邊是Docker鏡像的內部實現細節,我們能看到多個只讀層疊加在一起,層與層之間通過指針關聯,這些層能夠在運行Docker的宿主機的文件系統上訪問到。
Linux的統一文件系統(union file system)技術將這些疊加的只讀層合并成一個文件系統,該系統為這些只讀層提供了一個統一的視角,從而為Docker的用戶隱藏了多層的存在。
從Docker用戶的視角出發,一個Docker鏡像只存在一個文件系統,即上圖右邊所示。
這些文件系統的設計是Docker實現細節,一般情況下我們不用去深究。但如果您足夠好奇,使用命令sudo tree瀏覽目錄 /var/lib/docker即可:
比如我用命令docker images瀏覽下載到本地的docker鏡像:
其中一個叫jerry-nginx的鏡像,是一個web應用,它的所有內容能在/var/lib/docker目錄下的這個目錄查到:
講完了容器鏡像,我們再來看容器。
容器和容器鏡像一樣,也是若干層的疊加,唯一區別是所有只讀層的最上面一層,是一層可讀可寫層,如上圖綠色圖例所示。
初學者可以記住這個簡單的公式:容器 = 容器鏡像 + 可讀可寫層
我們如果用命令docker ps --all查看本機所有容器列表,會發現有的容器處于運行狀態,有的處于退出狀態。
因此,一個處于運行狀態的容器(running container)包含一個可讀寫的文件系統加上隔離的進程空間。
容器里的進程可以對這個可讀寫文件系統內的文件進行修改、刪除、創建等操作。
鏡像里每一層其實都能在docker文件夾的containers子目錄下找到:
上圖每一個紅色文件夾代表鏡像里的一層,藍色文件包含了該層運行時的日志文件,或者網絡相關配置等。
做個實驗:
ubuntu這個容器執行結束后,使用find / -name i042416.txt文件,這說明docker運行時能對宿主機的文件系統進行寫操作。
下面分析幾個常用的易混淆的命令。
docker create <image-id>
先看它的幫助文檔:
試著執行以下:
產生一個輸出id:
7ee10851c3f1e53bbd35e5f196f34de560afa1a20d9bf1ced587630dbcda877b
create創建的容器,狀態變為created:
docker create命令給通過命令行傳入的容器鏡像創建了一個新的可讀可寫層,從而生成了一個新的容器實例:
然后再執行docker start,輸入docker create創建的容器實例ID,就可以啟動這個容器實例了。
而docker run其實就是docker create和docker start這兩個命令合二為一的版本。
上述內容就是Docker和容器鏡像的區別是什么,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注創新互聯-成都網站建設公司行業資訊頻道。
網頁題目:Docker和容器鏡像的區別是什么-創新互聯
標題路徑:http://www.js-pz168.com/article10/ddeggo.html
成都網站建設公司_創新互聯,為您提供小程序開發、軟件開發、網站維護、外貿網站建設、網站排名、電子商務
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯