在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
电子发烧友
开通电子发烧友VIP会员 尊享10大特权
海量资料免费下载
精品直播免费看
优质内容免费畅学
课程9折专享价
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

提升DevOps效率,從基礎到進階的Dockerfile編寫技巧

馬哥Linux運維 ? 來源:馬哥Linux運維 ? 2024-11-26 09:44 ? 次閱讀

目錄

Dockerfile

基本結構

指令

創建鏡像(centos版)

創建鏡像(alpine版)

基本結構

Dockerfile 是一個文本格式的配置文件,用戶可以使用 Dockerfile 快速創建自定義鏡像。

Dockerfile 由一行行命令語句組成,并且支持以 # 開頭的注釋行。

Docker分為四部分:

基礎鏡像信息
維護者信息
鏡像操作指令
容器啟動時默認要執行的指令
例如:

# 第一行必須指定基于的基礎鏡像
FROM centos
# 維護者信息
LABEL MANTAINER "lvnanhai66 1@36.com"
# 鏡像操作指令
RUN  useradd -r -M -s /sbin/nologin apache 
# 容器啟動時默認要執行的指令
CMD ["/usr/local/apache/bin/httpd","-D","FOREGROUND"]

其中,一開始必須指明所基于的鏡像名稱,接下來一般會說明維護者信息。
后面則是鏡像操作指令,例如RUN指令,RUN指令將對鏡像執行跟隨的命令。每運行一條RUN指令,鏡像添加新的一層,并提交。
最后是CMD指令來指定運行容器時的操作指令。

指令

指令的一般格式為INSTRUCTION arguments,指令包括:

FROM
LABEL MAINTAINER
RUN
CMD
EXPOSE
ENV
ADD
COPY
ENTRYPOINT
VOLUME
USER
WORKDIR
ONBUILD

4d497324-a333-11ef-93f3-92fbcf53809c.png


FROM
功能為指定基礎鏡像,并且必須是第一條指令。

如果不以任何鏡像為基礎,那么寫法為:FROM scratch。

同時意味著接下來所寫的指令將作為鏡像的第一層開始

FROM centos    //基于centos的鏡像
語法:
FROM 
FROM :
FROM :
三種選項,其中是可選項,如果沒有選擇那么默認就是latest

LABEL MAINTAINER
指定維護者信息

語法:LABEL MAINTAINER 
LABEL MANTAINER "lvnanhai66 1@36.com"

RUN
功能為運行指定的命令
RUN命令有兩種格式
1.RUN command
2.RUN ["executable", "param1", "param2"]
前者將在shell終端中運行命令,即/bin/sh -c;后者則使用exec執行。指定使用其他終端可以通過第二種方式實現,例如:RUN ["/bin/bash","-c","echo hello"]
每條RUN指令將在當前鏡像基礎上執行指定命令,并提交為新的鏡像。當命令較長時可以使用 來換行

[root@localhost ~]# cd httpd/
[root@localhost httpd]# ls
Dockerfile  files
[root@localhost httpd]# vim Dockerfile 
[root@localhost httpd]# cat Dockerfile 
FROM busybox

LABEL MANTAINER "lvnanhai66 1@36.com"

RUN echo "hello lnh" > /tmp/abc
[root@localhost httpd]#  podman build -t httpd:1.0 .
STEP 1/3: FROM busybox
STEP 2/3: LABEL MANTAINER "lvnanhai66 1@36.com"
--> d761206551e
STEP 3/3: RUN echo "hello lnh" > /tmp/abc
COMMIT httpd:1.0
--> 80125d342c8
Successfully tagged localhost/httpd:1.0
80125d342c8d86708b7c9a572ea46876a361a2c6a6b21c6b4ad66c4c00dd0b37
[root@localhost httpd]# podman run -it --rm httpd:1.0 /bin/sh
/ # cd /tmp/
/tmp # ls
abc

CMD

CMD支持三種格式:
1.CMD ["executable","param1","param2"]使用exec執行,推薦方式
2.CMD command param1 param2在/bin/sh中執行,提供給需要交互的應用
3.CMD ["param1","param2"]提供給ENTRYPOINT的默認參數
CMD用于指定啟動容器時默認要執行的命令,每個Dockerfile只能有一條CMD命令。如果指定了多條命令,只有最后一條會被執行。

如果用戶啟動容器時指定了運行的命令,則會覆蓋掉CMD指定的命令。

不要把RUN和CMD搞混了。

RUN是構件容器時就運行的命令以及提交運行結果

CMD是容器啟動時執行的命令,在構件時并不運行,構件時緊緊指定了這個命令到底是個什么樣子

CMD ["/usr/local/apache/bin/httpd","-D","FOREGROUND"]

EXPOSE

格式為EXPOSE port [port...]。
例如:

EXPOSE 22 80 8443
EXPOSE用于告訴Docker服務器容器暴露的端口號,供互聯系統使用。

在啟動容器時通過-P,Docker主機會自動分配一個端口轉發到指定的端口;
使用-p則可以具體指定哪個本地端口映射過來。

ENV
格式為ENV key value 。指定一個環境變量,會被后續RUN指令使用,并在容器運行時保持。

ENV PATH /usr/local/apache/bin:$PATH   //配置環境變量

ADD
格式為ADD src dest
該命令將復制指定的src到容器中的dest。其中src可以是Dockerfile所在目錄的一個相對路徑(文件或目錄);也可以是一個URL;還可以是一個tar文件(會自動解壓為目錄)。

[root@localhost httpd]# ls
Dockerfile  files
[root@localhost httpd]# ls files/
apr-1.7.0.tar.gz  apr-util-1.6.1.tar.gz  entrypoint.sh  httpd-2.4.54.tar.gz
[root@localhost httpd]# vim Dockerfile 
[root@localhost httpd]# cat Dockerfile 
FROM busybox

ADD files/apr-1.7.0.tar.gz /tmp/
[root@localhost httpd]#  podman build -t httpd:2.0 .
STEP 1/2: FROM busybox
STEP 2/2: ADD files/apr-1.7.0.tar.gz /tmp/
COMMIT httpd:2.0
--> 5a9f6d599dc
Successfully tagged localhost/httpd:2.0
5a9f6d599dc3245e3bfba5877bd84f155d9410e1fff6a679a8ebab954f530f1a
[root@localhost httpd]#  podman run -it --rm  httpd:2.0 /bin/sh
/ # cd tmp/
/tmp # ls
apr-1.7.0
/tmp #

COPY

格式為COPY  。

復制本地主機的(為Dockerfile所在目錄的相對路徑,文件或目錄)為容器中的。目標路徑不存在時會自動創建。
當使用本地目錄為源目錄時,推薦使用COPY。

ENTRYPOINT
ENTRYPOINT有兩種格式:

ENTRYPOINT ["executable","param1","param2"]
ENTRYPOINT command param1 param2(在shell中執行)
配置容器啟動后執行的命令,并且不可被docker run提供的參數覆蓋。而且,如果在docker run的后面提供了參數,這些命令行參數會被當作參數傳遞給ENTRYPOINT指定的程序。

每個Dockerfile中只能有一個ENTRYPOINT,當指定多個ENTRYPOINT時,只有最后一個生效。

例如:ENTRYPOINT ["/bin/bash","/entrypoint.sh"]

VOLUME

格式為VOLUME ["/data"]。

創建一個可以從本地主機或其他容器掛載的掛載點,一般用來存放數據庫和需要保持的數據等

USER
格式為USER daemon。

指定運行容器時的用戶名或UID,后續的RUN也會使用指定用戶。

當服務不需要管理員權限時,可以通過該命令指定運行用戶。并且可以在之前創建所需要的用戶,例如:

RUN groupadd -r postgres && useradd -r -g postgres postgres

要臨時獲取管理員權限可以使用gosu,而不推薦sudo。如果不指定,容器默認是root運行。

WORKDIR
語法:

WORKDIR /path/to/workdir

設置工作目錄,對RUN,CMD,ENTRYPOINT,COPY,ADD生效。如果不存在則會創建,也可以設置多次。
如:

WORKDIR /a
WORKDIR b
WORKDIR c
RUN pwd

pwd執行的結果是/a/b/c

WORKDIR也可以解析環境變量

如:

ENV DIRPATH /path
WORKDIR $DIRPATH/$DIRNAME
RUN pwd

pwd的執行結果是/path/$DIRNAME

ONBUILD
格式為ONBUILD [INSTRUCTION]。

配置當所創建的鏡像作為其他鏡像的基礎鏡像時,所執行的操作指令。

例如,Dockerfile使用如下的內容創建了鏡像image-A

[...]
ONBUILD ADD . /app/src
ONBUILD RUN /usr/local/bin/python-build --dir /app/src
[...]

此時,如果基于image-A創建新的鏡像時,新的Dockerfile中使用FROM image-A指定基礎鏡像時,會自動執行ONBUILD指令的內容,等價于在后面添加了兩條指令。

FROM image-A

# Automatically run the following
ADD . /app/src
RUN /usr/local/bin/python-build --dir /app/src

使用ONBUILD指令的鏡像,推薦在標簽中注明,例如ruby:1.9-onbuild。

創建鏡像(centos版)

用podman進行dockefile做一個httpd編譯安裝的鏡像,要求要控制版本號,要用到dockerfile中大部分指令及用腳本方式啟動程序,上傳到官方鏡像倉庫

[root@localhost ~]# mkdir httpd   
[root@localhost ~]# cd httpd/
[root@localhost httpd]# touch Dockerfile
[root@localhost httpd]# mkdir files
[root@localhost httpd]# ls
Dockerfile  files
//創建一個目錄,在這個目錄下面創建一個Dockerfile文件和存放安裝包的目錄files
[root@localhost httpd]# cd files/
[root@localhost files]# wget https://downloads.apache.org/apr/apr-1.7.0.tar.gz https://downloads.apache.org/apr/apr-util-1.6.1.tar.gz https://downloads.apache.org/httpd/httpd-2.4.54.tar.gz
[root@localhost files]# ls
apr-1.7.0.tar.gz  apr-util-1.6.1.tar.gz  httpd-2.4.54.tar.gz
//下載安裝包
[root@localhost files]# vim entrypoint.sh
[root@localhost files]# cat entrypoint.sh
#!/bin/bash

sed -i '/^#ServerName/s/#//g' /usr/local/apache/conf/httpd.conf

exec "$@"
[root@localhost files]# chmod +x entrypoint.sh //賦予腳本執行權限
[root@localhost files]# ll
total 11136
-rw-r--r--. 1 root root 1093896 Apr  5  2019 apr-1.7.0.tar.gz
-rw-r--r--. 1 root root  554301 Oct 23  2017 apr-util-1.6.1.tar.gz
-rwxr-xr-x. 1 root root      88 Aug 30 16:43 entrypoint.sh
-rw-r--r--. 1 root root 9743277 Jun  8 16:42 httpd-2.4.54.tar.gz
//寫一個腳本作為啟動程序
[root@localhost files]# cd ..
[root@localhost httpd]# ls
Dockerfile  files
[root@localhost httpd]# vim Dockerfile 
[root@localhost httpd]# cat Dockerfile 
FROM centos

LABEL MANTAINER "lvnanhai66 1@36.com"
ENV apache_version 2.4.54     //apache版本號
ENV PATH /usr/local/apache/bin:$PATH   //配置環境變量

ADD files/apr-1.7.0.tar.gz /usr/src/
ADD files/apr-util-1.6.1.tar.gz /usr/src/
ADD files/httpd-${apache_version}.tar.gz /usr/src/   //這樣可以更換
ADD files/entrypoint.sh /     //將這個腳本放到根下面
 
RUN  useradd -r -M -s /sbin/nologin apache && 
     cd /etc/yum.repos.d && rm -r * && 
     curl -o /etc/yum.repos.d/CentOS-Base.repo https://mirrors.aliyun.com/repo/Centos-vault-8.5.2111.repo  && 
     sed -i -e '/mirrors.cloud.aliyuncs.com/d' -e '/mirrors.aliyuncs.com/d' /etc/yum.repos.d/CentOS-Base.repo  && 
     yum clean all  && yum makecache && 
     yum -y install gcc gcc-c++ make openssl-devel pcre-devel expat-devel libtool && 
     cd /usr/src/apr-1.7.0 && 
     sed -i '/$RM "$cfgfile"/d' configure && 
     ./configure --prefix=/usr/local/apr && 
     make && make install && 
     cd ../apr-util-1.6.1 && 
     ./configure --prefix=/usr/local/apr-util --with-apr=/usr/local/apr  && 
     make && make install && 
     cd ../httpd-${apache_version}  && 
     ./configure --prefix=/usr/local/apache 
        --enable-so 
        --enable-ssl 
        --enable-cgi 
        --enable-rewrite 
        --with-zlib 
        --with-pcre 
        --with-apr=/usr/local/apr 
        --with-apr-util=/usr/local/apr-util/ 
        --enable-modules=most 
        --enable-mpms-shared=all 
        --with-mpm=prefork  && 
     make  && make install  && 
     yum clean all &&        //清除緩存
     yum -y remove gcc gcc-c++ make &&     //這些編譯工具可以清除
     rm -rf /tmp/* /usr/src/*    //這個下面的文件可以清除
 
EXPOSE 80       //映射的端口號
WORKDIR /usr/local/apache    //相當于cd這個目錄
CMD ["/usr/local/apache/bin/httpd","-D","FOREGROUND"] //此處加了絕對路徑
ENTRYPOINT ["/bin/bash","/entrypoint.sh"]   //不知道有沒有權限,可以直接加bin/bash
[root@localhost httpd]# podman build -t httpd:v3.0 .
....
STEP 13/13: ENTRYPOINT ["/bin/bash","/entrypoint.sh"]
COMMIT httpd:v3.0
--> f65d0bb9ee1
Successfully tagged localhost/httpd:v3.0
f65d0bb9ee17efdffdb53dc52fb92188aaa5fa1ea90cc11e2939855ba71f8ec3
讓這個鏡像運行一個容器進行測試: 
[root@localhost httpd]# podman images
REPOSITORY               TAG         IMAGE ID      CREATED             SIZE
localhost/httpd          v3.0        f65d0bb9ee17  About a minute ago  405 MB
docker.io/library/httpd  latest      dabbfbe0c57b  8 months ago        148 MB
quay.io/centos/centos    latest      300e315adb2f  21 months ago       217 MB
[root@localhost httpd]# podman run -d httpd:v3.0 
fcf786713d9b55793b997cc98e3571535b1fd4c0553409f3bb18bfd9d51fd234
[root@localhost httpd]# podman ps
CONTAINER ID  IMAGE                 COMMAND               CREATED        STATUS            PORTS       NAMES
fcf786713d9b  localhost/httpd:v3.0  /usr/local/apache...  4 seconds ago  Up 4 seconds ago              xenodochial_morse
[root@localhost httpd]# podman inspect -l |grep -i ipaddr 
//過濾查看ip
            "IPAddress": "10.88.0.6",
                    "IPAddress": "10.88.0.6",
[root@localhost httpd]# curl 10.88.0.6    //訪問成功

It works!

上傳鏡像: [root@localhost httpd]# podman tag httpd:v3.0 docker.io/lvnanhai66/httpd:v3.0 [root@localhost httpd]# podman images REPOSITORY TAG IMAGE ID CREATED SIZE localhost/httpd v3.0 f65d0bb9ee17 8 minutes ago 405 MB docker.io/lvnanhai66/httpd v3.0 f65d0bb9ee17 8 minutes ago 405 MB docker.io/library/httpd latest dabbfbe0c57b 8 months ago 148 MB quay.io/centos/centos latest 300e315adb2f 21 months ago 217 MB [root@localhost httpd]# podman login docker.io Username: lvnanhai66 Password: Login Succeeded! [root@localhost httpd]# podman push docker.io/lvnanhai66/httpd:v3.0 Getting image source signatures Copying blob 3f49a2cae693 done Copying blob 90fc92241475 done Copying blob 8cfba8022d3f done Copying blob 34214738da46 done Copying blob bea1ef732da4 done Copying blob 2653d992f4ef done Copying config f65d0bb9ee done Writing manifest to image destination Storing signatures

4d53e016-a333-11ef-93f3-92fbcf53809c.png

拉取自己的鏡像運行容器:
[root@localhost ~]# podman run -d --name web -P docker.io/lvnanhai66/httpd:v3.0
Trying to pull docker.io/lvnanhai66/httpd:v3.0...
Getting image source signatures
Copying blob 929704506730 skipped: already exists  
Copying blob 26ad906b0de6 done  
Copying blob c63ffcca07e0 done  
Copying blob 45fdf32689c6 done  
Copying blob 0b040dd24d11 done  
Copying blob 841f6f1ffedd done  
Copying config f65d0bb9ee done  
Writing manifest to image destination
Storing signatures
4d770508e2552c6ab554079fccf9e72ed79ed43ffcad5d6564d2cac3a07527d6
[root@localhost ~]# podman ps -a
CONTAINER ID  IMAGE                            COMMAND               CREATED        STATUS            PORTS                  NAMES
4d770508e255  docker.io/lvnanhai66/httpd:v3.0  /usr/local/apache...  8 seconds ago  Up 8 seconds ago  0.0.0.0:40607->80/tcp  web
[root@localhost ~]# podman ps 
CONTAINER ID  IMAGE                            COMMAND               CREATED         STATUS             PORTS                  NAMES
4d770508e255  docker.io/lvnanhai66/httpd:v3.0  /usr/local/apache...  19 seconds ago  Up 19 seconds ago  0.0.0.0:40607->80/tcp  web
//如果發現拉取不下來可以加加速器進行注釋(cd /etc/containers/然后vim registries.conf)

創建鏡像(alpine版)

用podman進行dockefile做一個httpd編譯安裝的鏡像,要求要控制版本號,要用到dockerfile中大部分指令及用腳本方式啟動程序,上傳到官方鏡像倉庫,基于alpine鏡像進行dockerfile,使其大小在70M以內
Alpinel 編譯軟件注意事項

[root@localhost ~]# mkdir httpd   
[root@localhost ~]# cd httpd/
[root@localhost httpd]# touch Dockerfile
[root@localhost httpd]# mkdir files
[root@localhost httpd]# ls
Dockerfile  files
//創建一個目錄,在這個目錄下面創建一個Dockerfile文件和存放安裝包的目錄files
[root@localhost httpd]# cd files/
[root@localhost files]# wget https://downloads.apache.org/apr/apr-1.7.0.tar.gz https://downloads.apache.org/apr/apr-util-1.6.1.tar.gz https://downloads.apache.org/httpd/httpd-2.4.54.tar.gz
[root@localhost files]# ls
apr-1.7.0.tar.gz  apr-util-1.6.1.tar.gz  httpd-2.4.54.tar.gz
//下載安裝包
[root@localhost files]# vim entrypoint.sh
[root@localhost files]# cat entrypoint.sh
#!/bin/bash

sed -i '/^#ServerName/s/#//g' /usr/local/apache/conf/httpd.conf

exec "$@"
[root@localhost files]# chmod +x entrypoint.sh //賦予腳本執行權限
[root@localhost files]# ll
total 11136
-rw-r--r--. 1 root root 1093896 Apr  5  2019 apr-1.7.0.tar.gz
-rw-r--r--. 1 root root  554301 Oct 23  2017 apr-util-1.6.1.tar.gz
-rwxr-xr-x. 1 root root      88 Aug 31 22:38 entrypoint.sh
-rw-r--r--. 1 root root 9743277 Jun  8 16:42 httpd-2.4.54.tar.gz
//寫一個腳本作為啟動程序
[root@localhost files]# cd ..
[root@localhost httpd]# ls
Dockerfile  files
編寫dockerfile:
[root@localhost httpd]# vim Dockerfile 
[root@localhost httpd]# cat  Dockerfile 
FROM alpine

LABEL MANTAINER "lvnanhai66 1@36.com"

ENV apr_version=1.7.0 apr_util_version=1.6.1 httpd_version=2.4.54

ADD files/* /tmp/

RUN sed -i 's/dl-cdn.alpinelinux.org/mirrors.aliyun.com/g' /etc/apk/repositories && 
    apk update && 
    adduser -SHs /sbin/nologin apache && 
    apk add --no-cache -U gcc libc-dev make expat-dev pcre-dev openssl-dev libtool && 
    cd /tmp/apr-${apr_version} && 
    sed -i '/$RM "$cfgfile"/d' configure && 
    ./configure --prefix=/usr/local/apr && 
    make && make install && 
    cd /tmp/apr-util-${apr_util_version} && 
    ./configure --prefix=/usr/local/apr-util --with-apr=/usr/local/apr && 
    make && make install && 
    cd /tmp/httpd-${httpd_version} && 
    ./configure --prefix=/usr/local/apache 
    --enable-so 
    --enable-ssl 
    --enable-cgi 
    --enable-rewrite 
    --with-zlib 
    --with-pcre 
    --with-apr=/usr/local/apr 
    --with-apr-util=/usr/local/apr-util/ 
    --enable-modules=most 
    --enable-mpms-shared=all 
    --with-mpm=prefork && 
    make && make install && 
    mv /tmp/entrypoint.sh / && 
    apk del gcc make && 
    rm -rf /tmp/* /var/cache/*

EXPOSE 80
WORKDIR /usr/local/apache
CMD ["/usr/local/apache/bin/httpd","-D","FOREGROUND"]
ENTRYPOINT ["/bin/sh","/entrypoint.sh"]
[root@localhost httpd]# podman build -t httpd:v4.0 .
....
STEP 9/9: ENTRYPOINT ["/bin/sh","/entrypoint.sh"]
COMMIT httpd:v6.0
--> eb89d86d65e
Successfully tagged localhost/httpd:v6.0
eb89d86d65ef414d288a662331a44740015472d6539b25f95bc8abee8ce8addb
[root@localhost httpd]# podman images  //可以查看到鏡像已經比較小了
REPOSITORY                TAG         IMAGE ID      CREATED         SIZE
localhost/httpd           v6.0        eb89d86d65ef  8 seconds ago   120 MB
docker.io/library/alpine  latest      9c6f07244728  3 weeks ago         5.83 MB
[root@localhost httpd]# cd
[root@localhost ~]# mkdir -p /srv/web
[root@localhost ~]# cd /srv/web/
[root@localhost web]# ls
[root@localhost web]# echo "hello lnh" >index.html
[root@localhost web]# cat index.html 
hello lnh
[root@localhost web]# cd
[root@localhost ~]# cd httpd/
[root@localhost httpd]# podman images
REPOSITORY                TAG         IMAGE ID      CREATED         SIZE
localhost/httpd           v6.0        eb89d86d65ef  8 seconds ago   120 MB
docker.io/library/alpine  latest      9c6f07244728  3 weeks ago    5.83 MB
[root@localhost httpd]# podman run -d --name web -p 80:80 -v /srv/web/:/usr/local/apache/htdocs/:Z httpd:v6.0   //用制作的鏡像運行一個容器
a7d9d8c071e80360e3ad40ff7933337c8d9ecf24ef0fa81c72a2a85e7dec86af
[root@localhost httpd]# podman ps     //查看進程狀態
CONTAINER ID  IMAGE                 COMMAND               CREATED        STATUS            PORTS               NAMES
a7d9d8c071e8  localhost/httpd:v6.0  /usr/local/apache...  4 seconds ago  Up 4 seconds ago  0.0.0.0:80->80/tcp  web
[root@localhost httpd]# podman inspect -l |grep -i ipaddr  //查看ip地址
            "IPAddress": "10.88.0.10",
                    "IPAddress": "10.88.0.10",
[root@localhost httpd]# curl 10.88.0.10      //訪問成功
hello lnh 

進行訪問:

4d704d28-a333-11ef-93f3-92fbcf53809c.png

上傳鏡像:
[root@localhost httpd]# podman images
REPOSITORY                TAG         IMAGE ID      CREATED        SIZE
localhost/httpd           v6.0        eb89d86d65ef  9 minutes ago  120 MB
docker.io/library/alpine  latest      9c6f07244728  3 weeks ago    5.83 MB
[root@localhost httpd]# podman tag httpd:v6.0 docker.io/lvnanhai66/httpd:v6.0    //做標簽使其和官方網站上面的一致(建議使用自己的用戶名)
[root@localhost httpd]# podman images
REPOSITORY                  TAG         IMAGE ID      CREATED         SIZE
localhost/httpd             v6.0        eb89d86d65ef  11 minutes ago  120 MB
docker.io/lvnanhai66/httpd  v6.0        eb89d86d65ef  11 minutes ago  120 MB
docker.io/library/alpine    latest      9c6f07244728  3 weeks ago     5.83 MB
[root@localhost ~]# podman save docker.io/lvnanhai66/httpd:v6.0 -o myhttpd.tar     //將其打包成為文件
Getting image source signatures
Copying blob 994393dc58e7 done  
Copying blob ff52d230cd11 done  
Copying blob 7395d1756e8f done  
Copying config eb89d86d65 done  
Writing manifest to image destination
Storing signatures
[root@localhost ~]# ls
anaconda-ks.cfg  httpd  myhttpd.tar
[root@localhost ~]# scp  myhttpd.tar 192.168.222.251:/root
The authenticity of host '192.168.222.251 (192.168.222.251)' can't be established.
ECDSA key fingerprint is SHA256:y11UDaNXs3AnvVUnZQfAim2VHAplF09YOvQp2NemHyk.
Are you sure you want to continue connecting (yes/no/[fingerprint])? yes
Warning: Permanently added '192.168.222.251' (ECDSA) to the list of known hosts.
root@192.168.222.251's password: 
myhttpd.tar                                                          100%  114MB  92.2MB/s   00:01   
//傳給安裝docker的虛擬主機上面 

docker的安裝方法
在安裝了docker的虛擬主機上面進行上傳鏡像

[root@localhost ~]# ls
anaconda-ks.cfg  myhttpd.tar
[root@localhost ~]# docker load -i myhttpd.tar    //將鏡像導入
994393dc58e7: Loading layer  5.827MB/5.827MB
ff52d230cd11: Loading layer  53.77MB/53.77MB
7395d1756e8f: Loading layer  60.25MB/60.25MB
Loaded image: lvnanhai66/httpd:v6.0
[root@localhost ~]# docker images
REPOSITORY         TAG       IMAGE ID       CREATED          SIZE
lvnanhai66/httpd   v6.0      eb89d86d65ef   26 minutes ago   115MB
[root@localhost ~]# docker login 
Login with your Docker ID to push and pull images from Docker Hub. If you don't have a Docker ID, head over to https://hub.docker.com to create one.
Username: lvnanhai66
Password: 
WARNING! Your password will be stored unencrypted in /root/.docker/config.json.
Configure a credential helper to remove this warning. See
https://docs.docker.com/engine/reference/commandline/login/#credentials-store

Login Succeeded
[root@localhost ~]# docker push lvnanhai66/httpd:v6.0 
The push refers to repository [docker.io/lvnanhai66/httpd]
7395d1756e8f: Pushed 
ff52d230cd11: Pushed 
994393dc58e7: Pushed 
v6.0: digest: sha256:b01a151e9b89e7cd994c1a6acb207183c9097bd140098bee0b63f0da35a05c02 size: 952

可以查看到上傳成功,并且只有31M左右,比較小

4d89e6b6-a333-11ef-93f3-92fbcf53809c.png

測試:

[root@localhost ~]# docker pull lvnanhai66/httpd:v6.0
//拉取自己制作的鏡像
v6.0: Pulling from lvnanhai66/httpd
213ec9aee27d: Pull complete 
c220467fa6e0: Pull complete 
f3a6cb94f126: Pull complete 
Digest: sha256:b01a151e9b89e7cd994c1a6acb207183c9097bd140098bee0b63f0da35a05c02
Status: Downloaded newer image for lvnanhai66/httpd:v6.0
docker.io/lvnanhai66/httpd:v6.0
[root@localhost ~]# docker images
REPOSITORY         TAG       IMAGE ID       CREATED          SIZE
lvnanhai66/httpd   v6.0      eb89d86d65ef   54 minutes ago   115MB
[root@localhost ~]# docker run -d lvnanhai66/httpd:v6.0 
b7f7f743e574f1054afb559fada840361d4ca046e9698b8e4ccb9c2124949416
[root@localhost ~]# docker ps
CONTAINER ID   IMAGE                   COMMAND                  CREATED         STATUS         PORTS     NAMES
b7f7f743e574   lvnanhai66/httpd:v6.0   "/bin/sh /entrypoint…"   5 seconds ago   Up 4 seconds   80/tcp    strange_hofstadter
//利用自己制作鏡像成功運行一個容器

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 指令
    +關注

    關注

    1

    文章

    614

    瀏覽量

    36114
  • 鏡像
    +關注

    關注

    0

    文章

    177

    瀏覽量

    11043
  • devops
    +關注

    關注

    0

    文章

    119

    瀏覽量

    12318

原文標題:提升 DevOps 效率!從基礎到進階的 Dockerfile 編寫技巧

文章出處:【微信號:magedu-Linux,微信公眾號:馬哥Linux運維】歡迎添加關注!文章轉載請注明出處。

收藏 0人收藏

    評論

    相關推薦

    DevEco Studio AI輔助開發工具兩大升級功能 鴻蒙應用開發效率提升

    隨著搭載HarmonyOS 5的Pura X發布,鴻蒙生態進入快車道,各應用正在加速適配開發,越來越多開發者加入鴻蒙應用開發浪潮中。為提升鴻蒙應用開發效率,華為前不久上線了首款開發
    發表于 04-18 14:43

    鴻蒙原生繪圖API:基礎高階的繪制之旅(進階版)

    theme: hydrogen 家人們,還記得上次一起探索的鴻蒙繪圖API基礎用法嗎?上手是不是特別容易!今天,咱們就接著深入,開啟進階版的學習,解鎖更多復雜又炫酷的繪圖技能,讓你的鴻蒙應用界面直接
    的頭像 發表于 03-16 15:57 ?309次閱讀

    基于Docker鏡像逆向生成Dockerfile

    在本文中, 我們將通過理解Docker鏡像如何存儲數據, 以及如何使用工具查看鏡像方方面面的信息來逆向工程一個Docker鏡像; 以及如何使用Python的Docker API來構建一個類似Dedockify的工具來創建Dockerfile
    的頭像 發表于 03-10 09:45 ?330次閱讀
    基于Docker鏡像逆向生成<b class='flag-5'>Dockerfile</b>

    技術解析 | 適用于TeamCity的Unreal Engine支持插件,提升游戲構建效率

    TeamCity 是一款強大的持續集成和部署服務器,面向以 DevOps 為中心的團隊提供開箱即用的測試智能、構建問題的實時報告以及無與倫比的可擴展性。安裝和部署 TeamCity,幾分鐘之內即可開始構建您的 DevOps 管道。TeamCity 提供本地部署和基于云的版
    的頭像 發表于 02-19 16:12 ?440次閱讀
    技術解析 | 適用于TeamCity的Unreal Engine支持插件,<b class='flag-5'>提升</b>游戲構建<b class='flag-5'>效率</b>

    清華大學發布:DeepSeek入門精通

    特點、應用場景、使用方法以及如何通過提示語設計提升AI使用效率等方面展開,幫助用戶入門精通DeepSeek的使用
    的頭像 發表于 02-14 09:49 ?1.1w次閱讀
    清華大學發布:DeepSeek<b class='flag-5'>從</b>入門<b class='flag-5'>到</b>精通

    八個方面提升LED驅動電源效率

    關于提升LED驅動電源效率的技巧總結: 1.主電流回路PCB盡量短。LAYPCB的經驗,及布局,這個沒什么,快速的方法就是多看別人的作品。 2.優化變壓器參數設計,減少振鈴帶來的渦流損耗。這個比較
    發表于 01-17 10:07

    AN54-毫安安培的超高效率(高達95%)的功率轉換

    電子發燒友網站提供《AN54-毫安安培的超高效率(高達95%)的功率轉換.pdf》資料免費下載
    發表于 01-09 14:54 ?0次下載
    AN54-<b class='flag-5'>從</b>毫安<b class='flag-5'>到</b>安培的超高<b class='flag-5'>效率</b>(高達95%)的功率轉換

    Dockerfile鏡像制作與Docker-Compose容器編排

    Dockerfile鏡像制作 docker/podman中, 鏡像是容器的基礎,每次執行docker run的時候都會指定哪個基本鏡像作為容器運行的基礎。我們之前的docker的操作都是使用來
    的頭像 發表于 01-07 11:01 ?573次閱讀
    <b class='flag-5'>Dockerfile</b>鏡像制作與Docker-Compose容器編排

    devops使用最廣泛的集成工具盤點

    devops使用最廣泛的集成工具包括GitLab(全棧DevOps平臺)、Jenkins(CI/CD自動化服務器)、Docker(容器化技術)、Kubernetes(容器編排平臺)、Ansible
    的頭像 發表于 11-26 13:48 ?415次閱讀

    永磁同步電機效率提升方法

    提升永磁同步電機效率的方法可以多個方面進行,以下是一些有效的方法: 優化電機設計 : 增加磁場的強度:通過增加永磁體的磁通密度和提高永磁體及鐵心的磁導率,可以有效提升電機的磁場強度,
    的頭像 發表于 11-22 10:13 ?1102次閱讀

    如何提升EDA設計效率

    EDA(Electronic Design Automation,電子設計自動化)設計技術是現代電子工程領域的關鍵技術之一,提升EDA設計效率對于電子工程師和整個電子行業都至關重要。以下是一些提升
    的頭像 發表于 11-08 14:23 ?822次閱讀

    提升效率:RTC時鐘實用設置

    今天來給大家講解的是RTC時鐘實用性,提升絕對的效率
    的頭像 發表于 11-04 16:35 ?1148次閱讀
    <b class='flag-5'>提升</b><b class='flag-5'>效率</b>:RTC時鐘實用設置

    如何提升RFID手持終端的讀寫效率

    RFID(射頻識別)手持終端是一種便攜式設備,用于讀取和寫入RFID標簽。提升RFID手持終端的讀寫效率對于提高物流、庫存管理、零售等行業的工作效率至關重要。以下是一些提升RFID手持
    的頭像 發表于 10-29 09:41 ?523次閱讀

    Devops工具鏈集成的意義及基本原理

    Devops工具鏈集成的意義在于實現開發(Development)與運維(Operations)之間的緊密協作,通過自動化流程提高軟件交付的速度、質量和穩定性。其基本原理是通過一系列相互連接的工具,涵蓋代碼編寫到部署、監控的全
    的頭像 發表于 10-14 10:32 ?388次閱讀

    常用的devops工具集成方法

    常用的devops工具集成方法涵蓋了軟件開發和運維的各個方面,版本控制自動化構建、測試、部署和監控。這些工具的有效集成可以幫助團隊提高協作效率,減少溝通障礙,實現快速、高質量的軟件
    的頭像 發表于 10-09 11:21 ?407次閱讀
    主站蜘蛛池模板: 国产成人亚洲精品77 | 黄网站在线观看永久免费 | 大又大粗又爽又黄少妇毛片 | 高h污快穿文汁水四溅 | abc119影院成人免费看 | 日本护士69xx00| 日本有色视频 | 四虎影视4hu4虎成人 | 黄色网毛片 | 四虎影片国产精品8848 | 日本aaaaa特黄毛片 | 午夜国产精品久久影院 | 狠狠干天天爱 | 电影天堂bt | 欧美刺激午夜性久久久久久久 | 四虎国产精品免费入口 | 五月婷婷丁香六月 | 在线播放色 | 女人张开腿让男人桶免费网站 | 大又大粗又爽又黄少妇毛片 | 午夜高清 | 免费视频在线看 | 韩国三级观影久久 | 嫩草网 | 亚洲男人的性天堂 | 国产成人黄网址在线视频 | 成 人在线观看视频网站 | 狠狠88综合久久久久综合网 | 亚州1区2区3区4区产品乱码2021 | 性欧美护士18xxxxhd | 福利天堂| 亚洲乱码卡一卡二卡三永久 | 国产妇女在线 | 国产福利小视频在线观看 | 韩国三级理在线视频观看 | 欧美一区二区三区不卡视频 | 日韩啪啪网 | 免费看黄色的网站 | 女人牲交一级毛片 | 四虎三级 | 在线观看视频高清视频 |

    電子發燒友

    中國電子工程師最喜歡的網站

    • 2931785位工程師會員交流學習
    • 獲取您個性化的科技前沿技術信息
    • 參加活動獲取豐厚的禮品