站長資訊網(wǎng)
最全最豐富的資訊網(wǎng)站

Docker構(gòu)建鏡像的三種方式(Dockerfile初步)

前言

?上篇講述了有關(guān)docker網(wǎng)絡(luò)通信部分原理以及案例,本篇文章將講述有關(guān)docker構(gòu)建鏡像的具體操作。本文將從docker構(gòu)建鏡像的方式入手,逐一講述。

  • 揭開Docker的面紗 – 基礎(chǔ)理論梳理和安裝流程演示  http://www.hospitaldelafe.com/Linux/2020-04/163003.htm
  • Docker基礎(chǔ)命令詳解 – 鏡像及容器操作  http://www.hospitaldelafe.com/Linux/2020-04/163005.htm
  • 深入理解Docker的硬件資源控制與驗證  http://www.hospitaldelafe.com/Linux/2020-04/163006.htm
  • Docker網(wǎng)絡(luò)模式與配置Docker自定義網(wǎng)絡(luò)(bridge模式)  http://www.hospitaldelafe.com/Linux/2020-04/163007.htm

構(gòu)建鏡像的三種方式:

  • Dockerfile
  • 基于已有的鏡像容器進行創(chuàng)建
  • 基于本地模板創(chuàng)建

首先,我們?yōu)槭裁葱枰獦?gòu)建docker鏡像?只有明白了這個問題,我們才知道構(gòu)建docker鏡像的意義或者說價值是什么。

答案其實很簡單:docker鏡像是docker的三大核心之一,也是應(yīng)用發(fā)布的標(biāo)準(zhǔn)格式,一個完整的docker鏡像可以支持一個docker容器的運行。我們在容器進行相關(guān)的操作,例如安裝應(yīng)用服務(wù),假設(shè)某個業(yè)務(wù)的需求恰好需要方才安裝配置好的應(yīng)用服務(wù),我們就可以將環(huán)境以及搭建的服務(wù)生成新的鏡像提供出去。

下面我們來具體看看這三種方式的構(gòu)建手法。

基于Dockerfile構(gòu)建鏡像

什么是Dockerfile?

? Dockerfile構(gòu)建鏡像的方式就目前而言是使用最為廣泛的,這是一種可以自動化生成鏡像的一種方式,就類似shell腳本一樣,一個腳本執(zhí)行完就可以將一個服務(wù)安裝配置好,支持正常使用了。Dockerfile也是一樣,也是由一組指令組成的文件,其中每條指令對應(yīng)Linux中的一條命令,Docker程序?qū)⑼ㄟ^讀取Dockerfile中的指令最終生成鏡像。

? Dockerfile可以認(rèn)為是一個普通文件,其結(jié)構(gòu)大致分為四個部分:基礎(chǔ)鏡像信息、維護者信息、鏡像操作指令以及容器啟動時執(zhí)行指令。并且在Dockerfile中支持以“#”開頭的注釋。

Docker鏡像的分層

  1. Dockerfile中的每個指令都會創(chuàng)建一個新的鏡像層
  2. 鏡像層將被緩存和復(fù)用
  3. 當(dāng)Dockerfile的指令被修改了,復(fù)制的文件變化了,或者構(gòu)建鏡像時指定的變量不同了,對應(yīng)的鏡像層緩存就會失效
  4. 某一層的鏡像緩存失效后,其之后的鏡像層緩存都會隨之失效
  5. 鏡像層是不可變的,如果在某一層中添加一個文件,然后在下一層中刪除則鏡像中依然會包含該文件

Dockerfile編寫規(guī)則

Dockerfile中是基于其指令進行編寫的,其規(guī)則可以參考下面的表格,當(dāng)然,在編寫Dockerfile時,其格式是需要嚴(yán)格遵循的:

除注釋外,第一行必須使用FROM指令所基于的鏡像名稱;之后使用MAINTAINER指明維護信息;然后就是一系列鏡像操作指令,如RUN、 ADD等;最后便是CMD指令來指定啟動容器時要運行的命令操作。其中RUN指令可以使用多條,CMD只有最后一條可以生效!

Docker構(gòu)建鏡像的三種方式(Dockerfile初步)

? 本文主要是講述docker構(gòu)建鏡像的三種方式,Dockerfile的構(gòu)建具體過程筆者將在之后的文章中通過各種實際案例來講述演示,本文暫時給出一個Dockerfile文件的例子給大家參考。

[root@localhost ~]# cat Dockerfile  #務(wù)必先指明基于的基礎(chǔ)鏡像  FORM CentOS:7  #維護該鏡像的用戶信息(自定義)  MAINTAINER lokott@123.com  #鏡像操作命令  RUN yum -y update  RUN yum -y install openssh-server  RUN sed -i 's/UsePAM yes/UsePAM no/g' /etc/ssh/sshd_config  RUN ssh-keygen -t dsa -f /etc/ssh/ssh_host_dsa_key  RUN ssh-keygen -t rsa -f /etc/ssh/ssh_host_rsa_key  #開啟端口  EXPOSE 22  #啟動容器時執(zhí)行指令  CMD ["/usr/sbin/sshd","-D"]  

基于已有鏡像構(gòu)建鏡像

? 上述的Dockerfile的構(gòu)建鏡像的方式是自動化進行的,那么手動構(gòu)建的方式就是剩下的兩種了。

基于已有的鏡像構(gòu)建主要是通過docker commit 命令來構(gòu)建新的鏡像,其實質(zhì)就是將一個容器里面運行的程序以及該程序的運行環(huán)境打包起來生成新的鏡像

docker commit的語法規(guī)則及可選項介紹

Usage:  docker commit [OPTIONS] CONTAINER [REPOSITORY[:TAG]]    Create a new image from a container's changes    Options:    -a, --author string    Author (e.g., "John Hannibal Smith <hannibal@a-team.com>")#作者信息    -c, --change list      Apply Dockerfile instruction to the created image    -m, --message string   Commit message #說明信息    -p, --pause            Pause container during commit (default true) #生成過程中停止容器的運行  

案例:基于原有鏡像構(gòu)建新的鏡像(看實質(zhì)原理)

1.創(chuàng)建一個容器

[root@localhost ~]# docker create -it nginx /bin/bash  Unable to find image 'nginx:latest' locally  latest: Pulling from library/nginx  123275d6e508: Pull complete   6cd6a943ce27: Pull complete   a50b5ac4a7fb: Pull complete   Digest: sha256:d81f010955749350ef31a119fb94b180fde8b2f157da351ff5667ae037968b28  Status: Downloaded newer image for nginx:latest  fb9a4cdb1b79a5e4d82177afdbe8c1f1956888733979f15ae562e0013f4e0f29    [root@localhost ~]# docker ps -a  CONTAINER ID        IMAGE               COMMAND             CREATED             STATUS              PORTS               NAMES  fb9a4cdb1b79        nginx               "/bin/bash"         17 seconds ago      Created                                 vibrant_heisenberg  

2.基于該容器使用docker commit 命令創(chuàng)建新的鏡像

[root@localhost ~]# docker commit -m new_image -a lokott fb9a4cdb1b79 lokott:demo  sha256:bb848fe7eb3655a07e6577e05bc04ab6404549a24c49fa5d3161ceb767a048f2  [root@localhost ~]# docker images | grep lokott  lokott              demo                bb848fe7eb36        26 seconds ago           127MB  

基于本地模板構(gòu)建鏡像

該方式是通過導(dǎo)入操作系統(tǒng)模板文件生成鏡像,模板可以從OPENVZ開源項目下載,下載地址為:http://openvz.org/Download/template/precreated

下面直接給出例子——將debian模板壓縮包導(dǎo)入為本地鏡像

[root@localhost ~]# ls  anaconda-ks.cfg                docker.sh             公共  視頻  文檔  音樂  debian-7.0-x86-minimal.tar.gz  initial-setup-ks.cfg  模板  圖片  下載  桌面  [root@localhost ~]# cat debian-7.0-x86-minimal.tar.gz | docker import - lokott:new  sha256:df2ce16066413515db7db8a76243fcaebbd904d10304ab467fefde852dddd9a8  [root@localhost ~]# docker images | grep new  lokott              new                 df2ce1606641        14 seconds ago           215MB  

本文講述了docker構(gòu)建鏡像的三種方式,最重要的是上述的第一種方式使用的非常多。

贊(0)
分享到: 更多 (0)
網(wǎng)站地圖   滬ICP備18035694號-2    滬公網(wǎng)安備31011702889846號
国产成人精品免费视频大| 亚洲人成国产精品无码| 99re6这里有精品热视频| 国产精品9999久久久久| 日韩一二三区毛片| 国产乱码精品一区二区三区香蕉| 久久精品人妻中文系列| 99在线视频精品| 欧洲精品无码一区二区三区在线播放| 日韩尤物影院一二区| 国产精品亚洲专区在线播放| 99久久免费精品国产72精品九九| 91久久精品无码一区二区毛片| 婷婷五月深深久久精品| 惠民福利中文字幕人妻无码乱精品 | 精品无码成人片一区二区| 国产精品秘入口18禁麻豆免会员| 亚洲国产成人久久精品动漫 | 国产精品扒开做爽爽爽的视频 | 国产美女精品三级在线观看| 国产精品一久久香蕉国产线看 | 国产a不卡片精品免费观看| 成人国产精品视频频| 青青草国产精品视频| 在线播放国产精品| 国产精品久久免费| 国产精品久久久久久麻豆一区 | 日韩av无码成人无码免费| 无码日韩人妻精品久久| 国产精品线在线精品| 国产精品综合视频| 免费看国产精品麻豆| 久久精品国产亚洲av天美18| 亚洲精品一二三区| 18国产精品白浆在线观看免费| 国产福利视精品永久免费| 国产精品美女久久久久网| 久久精品久久久久观看99水蜜桃| 91精品全国免费观看含羞草| 亚洲精品电影天堂网| 国产夫妇精品自在线|