标签:bin root CMD 指令 镜像 docker Dockerfile
基础知识
1 每个保留关键字(指令)都是必须是⼤写字⺟
2 执⾏从上到下顺序执⾏
3 # 表示注释
4 每⼀个指令都会创建⼀个新的镜像层,并提交
步骤
docker从基础镜像运⾏⼀个容器,执⾏⼀条指令并对容器做出修改。
执⾏类似 docker commit 的操作提交⼀个新的镜像层。
Docker再基于刚提交的镜像运⾏⼀个新容器。
执⾏dockerfile中的下⼀条指令直到所有指令都执⾏完成!
具体说明
dockerfile是⾯向开发的,以后要发布项⽬,做镜像,就需要编写dockerfile⽂件。
DockerFile: 构建⽂件,定义了⼀切步骤,源代码!!!
DockerImages:在DockerFile 定义了⼀个⽂件之后,Docker build 时会产⽣⼀个Docker镜像,当运⾏
Docker 镜像时,会真正开始提供服务。
Docker容器:容器就是镜像运⾏起来的提供服务器!!
Dockerfile 的指令
FROM #基础镜像,⼀切从这⾥开始构建
MAINTAINER #镜像是谁写的,名字+邮箱
RUN #镜像构建的时候被需要运⾏的命令
ADD #步骤,tomcat镜像,这个tomcat压缩包,添加内容
WORKDIR #镜像的挂载⽬录
VOLUME #挂载的⽬录
EXPOST #保留端⼝配置
CMD #指定这个容器启动的时候要运⾏的命令,只有之后⼀个会⽣效,可被替代
ENTRYPOINT #指定这个容器启动的时候要运⾏的命令,可以追加命令
COPY #类似ADD,将我们⽂件拷⻉到镜像中
ENV #构建的时候设置环境变量
指令:FROM
功能描述:设置基础镜像
语法:FROM < image>[:< tag> | @< digest>]
提示:镜像都是从⼀个基础镜像(操作系统或其他镜像)⽣成,可以在⼀个Dockerfile中添加多
条FROM指令,⼀次⽣成多个镜像
注意:如果忽略tag选项,会使⽤latest镜像
指令:MAINTAINER
功能描述:设置镜像作者
语法:MAINTAINER < name>
指令:RUN
语法:RUN < command>
RUN [“executable”,”param1”,”param2”]
提示:RUN指令会⽣成容器,在容器中执⾏脚本,容器使⽤当前镜像,脚本指令完成后,Docker
Daemon会将该容器提交为⼀个中间镜像,供后⾯的指令使⽤
补充:RUN指令第⼀种⽅式为shell⽅式,使⽤/bin/sh -c < command>运⾏脚本,可以在其中
使⽤\将脚本分为多⾏
RUN指令第⼆种⽅式为exec⽅式,镜像中没有/bin/sh或者要使⽤其他shell时使⽤
该⽅式,其不会调⽤shell命令
例⼦:RUN source $HOME/.bashrc;\
echo $HOME
RUN [“/bin/bash”,”-c”,”echo hello”]
RUN [“sh”,”-c”,”echo”,”$HOME”] 使⽤第⼆种⽅式调⽤shell读取环境变量
指令:CMD
功能描述:设置容器的启动命令
语法:CMD [“executable”,”param1”,”param2”]
CMD [“param1”,”param2”]
CMD < command>
提示:CMD第⼀种、第三种⽅式和RUN类似,第⼆种⽅式为ENTRYPOINT参数⽅式,为entrypoint
提供参数列表
注意:Dockerfile中只能有⼀条CMD命令,如果写了多条则最后⼀条⽣效
指令:LABEL
功能描述:设置镜像的标签
延伸:镜像标签可以通过docker inspect查看
格式:LABEL < key>=< value> < key>=< value> …
提示:不同标签之间通过空格隔开
注意:每条指令都会⽣成⼀个镜像层,Docker中镜像最多只能有127层,如果超出Docker
Daemon就会报错,如LABEL ..=.. <假装这⾥有个换⾏> LABEL ..=..合在⼀起⽤空格分隔就
可以减少镜像层数量,同样,可以使⽤连接符\将脚本分为多⾏镜像会继承基础镜像中的标签,如果
存在同名标签则会覆盖
指令:EXPOSE
功能描述:设置镜像暴露端⼝,记录容器启动时监听哪些端⼝
语法:EXPOSE < port> < port> …
延伸:镜像暴露端⼝可以通过docker inspect查看
提示:容器启动时,Docker Daemon会扫描镜像中暴露的端⼝,如果加⼊-P参数,Docker
Daemon会把镜像中所有暴露端⼝导出,并为每个暴露端⼝分配⼀个随机的主机端⼝(暴露端⼝是容
器监听端⼝,主机端⼝为外部访问容器的端⼝)
注意:EXPOSE只设置暴露端⼝并不导出端⼝,只有启动容器时使⽤-P/-p才导出端⼝,这个时候才
能通过外部访问容器提供的服务
指令:ENV
功能描述:设置镜像中的环境变量
语法:ENV < key>=< value>…|< key> < value>
注意:环境变量在整个编译周期都有效,第⼀种⽅式可设置多个环境变量,第⼆种⽅式只设置⼀个
环境变量
提示:通过${变量名}或者 $变量名使⽤变量,使⽤⽅式${变量名}时可以⽤${变量名:-
default} ${变量名:+cover}设定默认值或者覆盖值ENV设置的变量值在整个编译过程中总是保
持不变的
指令:ADD
功能描述:复制⽂件到镜像中
语法:ADD < src>… < dest>|[“< src>”,… “< dest>”]
注意:当路径中有空格时,需要使⽤第⼆种⽅式
当src为⽂件或⽬录时,Docker Daemon会从编译⽬录寻找这些⽂件或⽬录,⽽
dest为镜像中的绝对路径或者相对于WORKDIR的路径
提示:src为⽬录时,复制⽬录中所有内容,包括⽂件系统的元数据,但不包括⽬录本身
src为压缩⽂件,并且压缩⽅式为gzip,bzip2或xz时,指令会将其解压为⽬录
如果src为⽂件,则复制⽂件和元数据
如果dest不存在,指令会⾃动创建dest和缺失的上级⽬录
指令:COPY
功能描述:复制⽂件到镜像中
语法:COPY < src>… < dest>|[“< src>”,… “< dest>”]
提示:指令逻辑和ADD⼗分相似,同样Docker Daemon会从编译⽬录寻找⽂件或⽬录,dest为镜
像中的绝对路径或者相对于WORKDIR的路径
指令:ENTRYPOINT
功能描述:设置容器的⼊⼝程序
语法:ENTRYPOINT [“executable”,”param1”,”param2”]
ENTRYPOINT command param1 param2(shell⽅式)
提示:⼊⼝程序是容器启动时执⾏的程序,docker run中最后的命令将作为参数传递给⼊⼝程序
⼊⼝程序有两种格式:exec、shell,其中shell使⽤/bin/sh -c运⾏⼊⼝程序,
此时⼊⼝程序不能接收信号量
当Dockerfile有多条ENTRYPOINT时只有最后的ENTRYPOINT指令⽣效
如果使⽤脚本作为⼊⼝程序,需要保证脚本的最后⼀个程序能够接收信号量,可以在
脚本最后使⽤exec或gosu启动传⼊脚本的命令
注意:通过shell⽅式启动⼊⼝程序时,会忽略CMD指令和docker run中的参数
为了保证容器能够接受docker stop发送的信号量,需要通过exec启动程序;如果
没有加⼊exec命令,则在启动容器时容器会出现两个进程,并且使⽤docker stop命令容器⽆法
正常退出(⽆法接受SIGTERM信号),超时后docker stop发送SIGKILL,强制停⽌容器
例⼦:FROM ubuntu <换⾏> ENTRYPOINT exec top -b
指令:VOLUME
功能描述:设置容器的挂载点
语法:VOLUME [“/data”]
VOLUME /data1 /data2
提示:启动容器时,Docker Daemon会新建挂载点,并⽤镜像中的数据初始化挂载点,可以将主
机⽬录或数据卷容器挂载到这些挂载点
指令:USER
功能描述:设置RUN CMD ENTRYPOINT的⽤户名或UID
语法:USER < name>
指令:WORKDIR
功能描述:设置RUN CMD ENTRYPOINT ADD COPY指令的⼯作⽬录
语法:WORKDIR < Path>
提示:如果⼯作⽬录不存在,则Docker Daemon会⾃动创建Dockerfile中多个地⽅都可以调⽤
WORKDIR,如果后⾯跟的是相对位置,则会跟在上条WORKDIR指定路径后(如WORKDIR /A
WORKDIR B WORKDIR C,最终路径为/A/B/C)
指令:ARG
功能描述:设置编译变量
语法:ARG < name>[=< defaultValue>]
注意:ARG从定义它的地⽅开始⽣效⽽不是调⽤的地⽅,在ARG之前调⽤编译变量总为空,在编译镜
像时,可以通过docker build –build-arg < var>=< value>设置变量,如果var没有通过
ARG定义则Daemon会报错
可以使⽤ENV或ARG设置RUN使⽤的变量,如果同名则ENV定义的值会覆盖ARG定义的
值,与ENV不同,ARG的变量值在编译过程中是可变的,会对⽐使⽤编译缓存造成影响(ARG值不同
则编译过程也不同)
例⼦:ARG CONT_IMAG_VER <换⾏> RUN echo $CONT_IMG_VER
ARG CONT_IMAG_VER <换⾏> RUN echo hello
当编译时给ARG变量赋值hello,则两个Dockerfile可以使⽤相同的中间镜像,如
果不为hello,则不能使⽤同⼀个中间镜像
指令:ONBUILD
功能描述:设置⾃径想的编译钩⼦指令
语法:ONBUILD [INSTRUCTION]
提示:从该镜像⽣成⼦镜像,在⼦镜像的编译过程中,⾸先会执⾏⽗镜像中的ONBUILD指令,所有
编译指令都可以成为钩⼦指令
指令:STOPSIGNAL
功能描述:设置容器退出时,Docker Daemon向容器发送的信号量
语法:STOPSIGNAL signal
提示:信号量可以是数字或者信号量的名字,如9或者SIGKILL,信号量的数字说明在Linux系统
管理中有简单介绍
ONBUILD流程
编译时,读取所有ONBUILD镜像并记录下来,在当前编译过程中不执⾏指令;
⽣成镜像时将所有ONBUILD指令记录在镜像的配置⽂件OnBuild关键字中;
⼦镜像在执⾏FROM指令时会读取基础镜像中的ONBUILD指令并顺序执⾏,如果执⾏过程中失败则编
译中断;当所有ONBUILD执⾏成功后开始执⾏⼦镜像中的指令;
⼦镜像不会继承基础镜像中的ONBUILD指令;
CMD ENTRYPOINT和RUN的区别
RUN指令是设置编译镜像时执⾏的脚本和程序,镜像编译完成后,RUN指令的⽣命周期结束
容器启动时,可以通过CMD和ENTRYPOINT设置启动项,其中CMD叫做容器默认启动命令,如果在
docker run命令末尾添加command,则会替换镜像中CMD设置的启动程序;ENRTYPOINT叫做⼊⼝程
序,不能被docker run命令末尾的command替换,⽽是将command当作字符串,传递给ENTRYPOINT
作为参数
在docker run中,可以通过–entrypoint替换镜像中的⼊⼝程序,在Dockerfile中,应该⾄少有⼀条CMD
或者ENTRYPOINT指令,如果同时定义了CMD和ENTRYPOINT则CMD会作为参数传递给ENTRYPOINT
一 测试
编写 Dockerfile 的文件
[root@node143 dockerfile]# vim mydockerfile FROM centos MAINTAINER xiaoshimei<12345645@qq.com> ENV MYPATH /usr/locat WORKDIR $MYPATH RUN yum -y install vim RUN yum -y install net-tools EXPOSE 80 CMD echo $MYPATH CMD echo"----end----" CMD /bin/bash
通过这个文件构建镜像
#命令 docker build -f dockerfile⽂件路径 -t 镜像名:[tag]版本号
docker build -f mydockerfile -t mydockerfile:0.1 .
构建成功最底部会显示这两⾏
Successfully built 29f50f45bc0b
Successfully tagged mydockerfile:0.1
测试运⾏ [root@node143 dockerfile]# docker run -it mydockerfile:0.1 [root@5115d212f2c2 locat]# pwd /usr/locat
列出本地镜像的变更历史
查看现有的镜像
[root@node143 dockerfile]# docker images REPOSITORY TAG IMAGE ID CREATED SIZE mydockerfile 0.1 29f50f45bc0b 26 minutes ago 291MB nginx latest f6d0b4767a6c 2 months ago 133MB foxiswho/rocketmq 4.8.0 ccdf2960021a 2 months ago 505MB styletang/rocketmq-console-ng latest 7df83bb6e638 3 years ago 702MB
通过 docker history +镜像ID 可以查看当前镜像构成历史
[root@node143 dockerfile]# docker history 29f50f45bc0b IMAGE CREATED CREATED BY SIZE COMMENT 29f50f45bc0b 26 minutes ago /bin/sh -c #(nop) CMD ["/bin/sh" "-c" "/bin… 0B ad88d26c0c57 26 minutes ago /bin/sh -c #(nop) CMD ["/bin/sh" "-c" "echo… 0B 025d57b9faec 26 minutes ago /bin/sh -c #(nop) CMD ["/bin/sh" "-c" "echo… 0B e224252e8c18 26 minutes ago /bin/sh -c #(nop) EXPOSE 80 0B eb920921d222 26 minutes ago /bin/sh -c yum -y install net-tools 23.4MB 3c70319360e9 31 minutes ago /bin/sh -c yum -y install vim 58.1MB ba3d8a11d96e 31 minutes ago /bin/sh -c #(nop) WORKDIR /usr/locat 0B 87e3e7c84495 31 minutes ago /bin/sh -c #(nop) ENV MYPATH=/usr/locat 0B 140dd8dc67e8 31 minutes ago /bin/sh -c #(nop) MAINTAINER xiaoshimei<123… 0B 300e315adb2f 3 months ago /bin/sh -c #(nop) CMD ["/bin/bash"] 0B <missing> 3 months ago /bin/sh -c #(nop) LABEL org.label- schema.sc… 0B <missing> 3 months ago /bin/sh -c #(nop) ADD file:bd7a2aed6ede423b7… 209MB
CMD 和ENTRYPOINT 区别
CMD #指定这个容器启动的时候要运⾏的命令,只有最后⼀个会⽣效,可被替代
ENTRYPOINT #指定这个容器启动的时候要运⾏的命令,可以追加命令
测试 cdm
编写 dockerfile 文件
[root@node143 dockerfile]# vim dockerfile-cmd-test FROM centos CMD ["ls","-a"],
构建文件
[root@node143 dockerfile]# docker build -f dockerfile-cmd-test -t cmdtset . Sending build context to Docker daemon 217.6MB Step 1/2 : FROM centos ---> 300e315adb2f Step 2/2 : CMD ["ls","-a"], ---> Running in 4dd090d39ebf Removing intermediate container 4dd090d39ebf ---> b31e0a3e81b4 Successfully built b31e0a3e81b4 Successfully tagged cmdtset:latest
run 运行,返回的结果就是脚本里写的需要执行 ls -a 的结果
[root@node143 dockerfile]# docker run b31e0a3e81b4 . .. .dockerenv bin dev etc home lib lib64 lost+found media mnt opt
想追加⼀个命令 -l ls -al 返回结果报错了
[root@node143 dockerfile]# docker run b31e0a3e81b4 -l docker: Error response from daemon: OCI runtime create failed: container_linux.go:370: starting container process caused: exec: "-l": executable file not found in $PATH: unknown. ERRO[0000] error waiting for container: context canceled
cmd 的情况下 -l 替换了 [“ls”,"-a"] 这个命令,所以执⾏不成功 ,因为 l 并不是命令
测试ENTRYPOINT
同样也是编写dockerfile⽂件,内容与之前的⼀样
[root@node143 dockerfile]# vim dockerfile-cmd-test FROM centos CMD ["ls","-a"],
构建文件
[root@node143 dockerfile]# docker build -f dockerfile-cmd-entrypoint -t entoryonit-test . Sending build context to Docker daemon 217.6MB Step 1/2 : FROM centos ---> 300e315adb2f Step 2/2 : ENTRYPOINT ["ls","-a"] ---> Running in 52fd4e3fc7f5 Removing intermediate container 52fd4e3fc7f5 ---> 77d940efb3ad Successfully built 77d940efb3ad Successfully tagged entoryonit-test:latest
运行
[root@node143 dockerfile]# docker run 77d940efb3ad . .. .dockerenv bin dev etc home lib lib64 lost+found
我们的追加命令,是直接拼接在我们的 ENTRYPOINT 命令后⾯的 !
[root@node143 dockerfile]# docker run 77d940efb3ad -l total 0 drwxr-xr-x 1 root root 6 Mar 16 14:38 . drwxr-xr-x 1 root root 6 Mar 16 14:38 .. -rwxr-xr-x 1 root root 0 Mar 16 14:38 .dockerenv lrwxrwxrwx 1 root root 7 Nov 3 15:22 bin -> usr/bin drwxr-xr-x 5 root root 340 Mar 16 14:38 dev drwxr-xr-x 1 root root 66 Mar 16 14:38 etc drwxr-xr-x 2 root root 6 Nov 3 15:22 home lrwxrwxrwx 1 root root 7 Nov 3 15:22 lib -> usr/lib lrwxrwxrwx 1 root root 9 Nov 3 15:22 lib64 -> usr/lib64 drwx------ 2 root root 6 Dec 4 17:37 lost+found
案例说明
编写DockerFlie⽂件
查看官⽅默认的CentOS镜像的情况
p15页 图
需求实现
登陆后的默认路径/home、安装vim编辑器、安装查看⽹络配置ifconfig
[root@Linux home]# mkdir dockerfile-test [root@Linux home]# cd dockerfile-test/ [root@Linux dockerfile-test]# vim mydockerfile-centos # 编辑⽂件 [root@Linux dockerfile-test]# ls mydockerfile-centos [root@Linux dockerfile-test]# cat mydockerfile-centos FROM centos MAINTAINER guardwhy<hxy1625309592@aliyun.com> ENV MYPATH /home WORKDIR $MYPATH RUN yum -y install vim RUN yum -y install net-tools RUN yum -y install gcc EXPOSE 80 CMD echo $MYPATH CMD echo "----------end--------" CMD /bin/bash [root@Linux dockerfile-test]#
构建镜像
docker build -f mydockerfile-centos -t centos:7 .
p16 页 图
运行新镜像
docker run -it centos:7
图
列出镜像地的变更历史
docker history 70aba9c80bd4
定义镜像 tomcat
创建文件夹
1、执⾏以下命令: mkdir -p guardwhy/tomcat
2、在上述⽬录下创建新⽂件:touch readme.txt。
3、将 jdk 和 tomcat 安装的压缩包拷⻉进上⼀步⽬录。
4、在guardwhy/tomcat⽬录下新建⼀个Dockerfile⽂件
p16 图
注意: 官⽅命名为Dockerfile,build会⾃动寻找这个⽂件,就不需要-f指定了!!!
# vim Dockerfile FROM centos MAINTAINER guardwhy<hxy1625309592@aliyun.com> #把宿主机当前上下⽂的readme.txt拷⻉到容器/usr/local/路径下 COPY readme.txt /usr/local/readme.txt #把java与tomcat添加到容器中 ADD jdk-8u261-linux-x64.tar.gz /usr/local/ ADD apache-tomcat-9.0.46.tar.gz /usr/local/ #安装vim编辑器 RUN yum -y install vim #设置⼯作访问时候的WORKDIR路径,登录落脚点 ENV MYPATH /usr/local WORKDIR $MYPATH #配置java与tomcat环境变量 ENV JAVA_HOME /usr/local/jdk1.8.0_261 ENV CLASSPATH $JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar ENV CATALINA_HOME /usr/local/apache-tomcat-9.0.46 ENV CATALINA_BASE /usr/local/apache-tomcat-9.0.46 ENV PATH $PATH:$JAVA_HOME/bin:$CATALINA_HOME/lib:$CATALINA_HOME/bin #容器运⾏时监听的端⼝ EXPOSE 8080 #启动时运⾏tomcat CMD /usr/local/apache-tomcat-9.0.46/bin/startup.sh && tail -F /usr/local/apache-tomcat-9.0.46/bin/logs/catalina.out
构建镜像
[root@Linux tomcat]# docker build -t diytomcat . Sending build context to Docker daemon 154.6MB Step 1/15 : FROM centos ---> 300e315adb2f Step 2/15 : MAINTAINER guardwhy<hxy1625309592@aliyun.com> ---> Using cache ---> 2d8a3df8c6fb Dependencies resolved. ========================================================================= ======= Package Arch Version Repository Size ========================================================================= ======= Installing: vim-enhanced x86_64 2:8.0.1763-15.el8 appstream 1.4 M Installing dependencies: gpm-libs x86_64 1.20.7-17.el8 appstream 39 k vim-common x86_64 2:8.0.1763-15.el8 appstream 6.3 M vim-filesystem noarch 2:8.0.1763-15.el8 appstream 48 k which x86_64 2.21-12.el8 baseos 49 k Transaction Summary ========================================================================= ======= Install 5 Packages Total download size: 7.8 M Installed size: 30 M Downloading Packages: (1/5): gpm-libs-1.20.7-17.el8.x86_64.rpm 132 kB/s | 39 kB 00:00 (2/5): vim-enhanced-8.0.1763-15.el8.x86_64.rpm 2.9 MB/s | 1.4 MB 00:00 (3/5): vim-filesystem-8.0.1763-15.el8.noarch.rp 233 kB/s | 48 kB 00:00 (4/5): vim-common-8.0.1763-15.el8.x86_64.rpm 9.0 MB/s | 6.3 MB 00:00 (5/5): which-2.21-12.el8.x86_64.rpm 205 kB/s | 49 kB 00:00
------------------------------------------------------------------------- ------- Total 4.7 MB/s | 7.8 MB 00:01 warning: /var/cache/dnf/appstream-02e86d1c976ab532/packages/gpm-libs- 1.20.7-17.el8.x86_64.rpm: Header V3 RSA/SHA256 Signature, key ID 8483c65d: NOKEY CentOS Linux 8 - AppStream 1.6 MB/s | 1.6 kB 00:00 Importing GPG key 0x8483C65D: Userid : "CentOS (CentOS Official Signing Key) <security@centos.org>" Fingerprint: 99DB 70FA E1D7 CE22 7FB6 4882 05B5 55B3 8483 C65D From : /etc/pki/rpm-gpg/RPM-GPG-KEY-centosofficial Complete! Successfully built ecc82f059377 Successfully tagged diytomcat:latest [root@Linux tomcat]# docker images REPOSITORY TAG IMAGE ID CREATED SIZE diytomcat latest ecc82f059377 4 minutes ago 638MB centos 7 70aba9c80bd4 18 hours ago 451MB centos latest 300e315adb2f 6 months ago 209MB [root@Linux tomcat]#
运行启动自定义镜像
docker run \ -d -p 9090:8080 --name mydiytomcat \ -v /home/guardwhy/tomcat/test:/usr/local/apache-tomcat- 9.0.46/webapps/test \ -v /home/guardwhy/tomcat/tomcat9logs/:/usr/local/apache-tomcat- 9.0.46/logs \ --privileged=true diytomcat
p22 图
开启端口
开启8080:9000端⼝,打开防⽕墙。
firewall-cmd --zone=public --add-port=8080/tcp --permanent firewall-cmd --zone=public --add-port=9090/tcp --permanent firewall-cmd --reload
查看所有开启的端口
图
验证测试
链接访问: http://192.168.200.21:9090/
图
网页发布测试
图
web.xml
<?xml version="1.0" encoding="UTF-8"?> <web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd" version="4.0"> </web-app>
index.jsp
<%@ page contentType="text/html;charset=UTF-8" language="java" %> <html> <head> <title>docker</title> </head> <body> <h3>hello,docker</h3> <% System.out.println("hello, dockerlogs"); %> </body> </html>
执行结果
点击链接: http://192.168.200.21:9090/test/
图
查看日志
[root@Linux tomcat]# ls apache-tomcat-9.0.46.tar.gz Dockerfile jdk-8u261-linux-x64.tar.gz readme.txt test tomcat9logs [root@Linux tomcat]# cd tomcat9logs/ [root@Linux tomcat9logs]# ls -l 总⽤量 48 -rw-r-----. 1 root root 16650 6⽉ 11 16:51 catalina.2021-06-11.log -rw-r-----. 1 root root 16668 6⽉ 11 16:57 catalina.out -rw-r-----. 1 root root 0 6⽉ 11 16:18 host-manager.2021-06-11.log -rw-r-----. 1 root root 407 6⽉ 11 16:18 localhost.2021-06-11.log -rw-r-----. 1 root root 1763 6⽉ 11 16:57 localhost_access_log.2021-06- 11.txt -rw-r-----. 1 root root 0 6⽉ 11 16:18 manager.2021-06-11.log [root@Linux tomcat9logs]#
发布镜像到阿里云
1、注册阿⾥云,登录阿⾥云服务
2、找到容器镜像服务
图
操作指南
1. 登录阿⾥云Docker Registry
$ docker login --username=tb99****08_88 registry.cn-qingdao.aliyuncs.com
⽤于登录的⽤户名为阿⾥云账号全名,密码为开通服务时设置的密码。
您可以在访问凭证⻚⾯修改凭证密码。
2. 从Registry中拉取镜像
$ docker pull registry.cn-qingdao.aliyuncs.com/docker-guardwhy/java-test:
[镜像版本号]
3. 将镜像推送到Registry
$ docker login --username=tb99****08_88 registry.cn-qingdao.aliyuncs.com
$ docker tag [ImageId] registry.cn-qingdao.aliyuncs.com/docker-
guardwhy/java-test:[镜像版本号]
$ docker push registry.cn-qingdao.aliyuncs.com/docker-guardwhy/java-test:
[镜像版本号]
请根据实际镜像信息替换示例中的[ImageId]和[镜像版本号]参数。
4. 选择合适的镜像仓库地址
从ECS推送镜像时,可以选择使⽤镜像仓库内⽹地址。推送速度将得到提升并且将不会损耗您的公⽹
流量。
如果您使⽤的机器位于VPC⽹络,请使⽤ registry-vpc.cn-qingdao.aliyuncs.com 作为
Registry的域名登录。
5. 示例
使⽤"docker tag"命令重命名镜像,并将它通过专有⽹络地址推送⾄Registry。
$ docker images
REPOSITORY TAG
IMAGE ID CREATED VIRTUAL SIZE
registry.aliyuncs.com/acs/agent 0.7-
dfb6816 37bb9c63c8b2 7 days ago 37.89 MB
$ docker tag 37bb9c63c8b2 registry-vpc.cn-
qingdao.aliyuncs.com/acs/agent:0.7-dfb6816
使⽤ "docker push" 命令将该镜像推送⾄远程。
$ docker push registry-vpc.cn-qingdao.aliyuncs.com/acs/agent:0.7-dfb6816
测试推送发布
## 1、登录阿⾥云 [root@Linux tomcat]# docker login --username=13479615108 registry.cn- qingdao.aliyuncs.com Password: Error response from daemon: Get https://registry.cn- qingdao.aliyuncs.com/v2/: unauthorized: authentication required [root@Linux tomcat]# clear [root@Linux tomcat]# docker login --username=13479915208 registry.cn- qingdao.aliyuncs.com 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 ## 2、设置 tag [root@Linux tomcat]# docker tag ecc82f059377 registry.cn- qingdao.aliyuncs.com/docker-guardwhy/java-test:v1.0 ## 3、推送命令 [root@Linux tomcat]# docker push registry.cn-qingdao.aliyuncs.com/docker- guardwhy/java-test:v1.0 The push refers to repository [registry.cn-qingdao.aliyuncs.com/docker- guardwhy/java-test] c7510b7d4b11: Pushed d6d45250595e: Pushed 3a1d1e2371ce: Pushed 70d71810a13c: Pushed 2653d992f4ef: Pushed v1.0: digest: sha256:8baa27772f6fc09c79c5e9d986c397c243c49f601d287b9ee42781e931cae136 size: 1373 [root@Linux tomcat]#
标签:bin,root,CMD,指令,镜像,docker,Dockerfile 来源: https://www.cnblogs.com/nll0185/p/16257080.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。