Docker(三)Dokerfile,发布镜像

DockerFile

什么是DockerFile

dockerfile是用来构建Docker镜像的构建文件,是由一系列命令和参数构成的脚本。
构建步骤:

  1. 编写DockerFile文件
  2. docker build 构建镜像
  3. docker run
    地址
    在这里插入图片描述
    在这里插入图片描述
    基础知识:
    1、每条保留字指令都必须为大写字母且后面要跟随至少一个参数
    2、指令按照从上到下,顺序执行
    3、# 表示注释
    4、每条指令都会创建一个新的镜像层,并对镜像进行提交
    流程:
    1、docker从基础镜像运行一个容器
    2、执行一条指令并对容器做出修改
    3、执行类似 docker commit 的操作提交一个新的镜像层
    4、Docker再基于刚提交的镜像运行一个新容器
    5、执行dockerfile中的下一条指令直到所有指令都执行完成!
    说明:
    从应用软件的角度来看,DockerFile,docker镜像与docker容器分别代表软件的三个不同阶段。
    DockerFile 是软件的原材料 (代码)
    Docker镜像则是软件的交付品 (.apk)
    Docker容器则是软件的运行状态 (客户下载安装执行)
    DockerFile面向开发,Docker镜像成为交付标准,Docker容器则涉及部署与运维,三者缺一不可!
    DockerFile:需要定义一个DockerFile,DockerFile定义了进程需要的一切东西。DockerFile涉及的内容
    包括执行代码或者是文件、环境变量、依赖包、运行时环境、动态链接库、操作系统的发行版、服务进
    程和内核进程(当引用进行需要和系统服务和内核进程打交道,这时需要考虑如何设计 namespace的权
    限控制)等等。
    Docker镜像:在DockerFile 定义了一个文件之后,Docker build 时会产生一个Docker镜像,当运行
    Docker 镜像时,会真正开始提供服务;
    Docker容器:容器是直接提供服务的。

DockerFile指令

关键字

FROM # 基础镜像,当前新镜像是基于哪个镜像的
MAINTAINER # 镜像维护者的姓名混合邮箱地址
RUN # 容器构建时需要运行的命令
EXPOSE # 当前容器对外保留出的端口
WORKDIR # 指定在创建容器后,终端默认登录的进来工作目录,一个落脚点
ENV # 用来在构建镜像过程中设置环境变量
ADD # 将宿主机目录下的文件拷贝进镜像且ADD命令会自动处理URL和解压tar压缩包
COPY # 类似ADD,拷贝文件和目录到镜像中!
VOLUME # 容器数据卷,用于数据保存和持久化工作
CMD # 指定一个容器启动时要运行的命令,dockerFile中可以有多个CMD指令,但只有最
后一个生效!
ENTRYPOINT # 指定一个容器启动时要运行的命令!和CMD一样
ONBUILD # 当构建一个被继承的DockerFile时运行命令,父镜像在被子镜像继承后,父镜像的
ONBUILD被触发

在这里插入图片描述

自定义一个 centos

1、编写DockerFile
目的:使我们自己的镜像具备如下:登陆后的默认路径、vim编辑器、查看网络配置ifconfig支持
准备编写DockerFlie文件

[root@zhoukun home]# mkdir dockerfile-test
[root@zhoukun home]# ls
ceshi dockerfile-test docker-test-volume f1
[root@zhoukun home]#
[root@zhoukun home]# vim mydockerfile-centos # 编辑文件
[root@zhoukun home]# cat mydockerfile-centos
FROM centos
MAINTAINER zhoukun<86547462@qq.com>
ENV MYPATH /usr/local
WORKDIR $MYPATH
RUN yum -y install vim
RUN yum -y install net-tools
EXPOSE 80
CMD echo $MYPATH
CMD echo "----------end--------"
CMD /bin/bash

2、构建docker build -f dockerfile地址 -t 新镜像名字:TAG .

[root@zhoukun home]# docker build -f mydockerfile-centos -t mycentos:0.1

3.运行docker run -it 新镜像名字:TAG

[root@192 ~]# docker run -it mycentos:0.1

测试
在这里插入图片描述
4、列出镜像地的变更历史docker history 镜像名
在这里插入图片描述

CMD 和 ENTRYPOINT 的区别

CMD:Dockerfile 中可以有多个CMD 指令,但只有最后一个生效,CMD 会被 docker run 之后的参数
替换!
ENTRYPOINT: docker run 之后的参数会被当做参数传递给 ENTRYPOINT,之后形成新的命令组合!

自定义镜像 tomcat

1.新建dockerfile文件

# vim Dockerfile
FROM centos
MAINTAINER zhoukun<86547462@qq.com>
#把宿主机当前上下文的read.txt拷贝到容器/usr/local/路径下
COPY read.txt /usr/local/cincontainer.txt
#把java与tomcat添加到容器中
ADD jdk-8u11-linux-x64.tar.gz /usr/local/
ADD apache-tomcat-9.0.22.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_11
ENV CLASSPATH $JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
ENV CATALINA_HOME /usr/local/apache-tomcat-9.0.22
ENV CATALINA_BASE /usr/local/apache-tomcat-9.0.22
ENV PATH $PATH:$JAVA_HOME/bin:$CATALINA_HOME/lib:$CATALINA_HOME/bin
#容器运行时监听的端口
EXPOSE 8080
#启动时运行tomcat
# ENTRYPOINT ["/usr/local/apache-tomcat-9.0.22/bin/startup.sh" ]
# CMD ["/usr/local/apache-tomcat-9.0.22/bin/catalina.sh","run"]
CMD /usr/local/apache-tomcat-9.0.22/bin/startup.sh && tail -F
/usr/local/apache-tomcat-9.0.22/bin/logs/catalina.out

2.创建镜像

docker build -t diytomcat .

3.运行启动 run

docker run -d -p 9090:8080 --name mydiytomcat -v
/home/zhoukun/build/tomcat/test:/usr/local/apache-tomcat9.0.22/webapps/test -v
/home/zhoukun/build/tomcat/tomcat9logs/:/usr/local/apache-tomcat9.0.22/logs --privileged=true diytomcat

发布镜像

DockerHub

注册dockerhub https://hub.docker.com/signup,需要有一个账号

# 1、查看登录命令
[root@zhoukun tomcat]# docker login --help
Usage: docker login [OPTIONS] [SERVER]
# 2、登录
[root@zhoukun tomcat]# docker login -u zhoukun
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/#credentialsstore
Login Succeeded
# 3、将镜像发布出去
[root@zhoukun tomcat]# docker push zhoukun/diytomcat:1.0
The push refers to repository [docker.io/library/diytomcat]
0f02399c6fdf: Preparing
e79ea0c3a34e: Preparing
09281fa8fe38: Preparing
b56a902b0aef: Preparing
0683de282177: Preparing
# 拒绝:请求的资源访问被拒绝
denied: requested access to the resource is denied
# 问题:本地镜像名无帐号信息,解决加 tag即可
docker tag 251ca4419332 zhoukun/diytomcat:1.0
# 再次 push, ok
[root@zhoukun tomcat]# docker push zhoukun/diytomcat:1.0
The push refers to repository [docker.io/zhoukun/diytomcat]
0f02399c6fdf: Pushing [========> ]
9.729MB/59.76MB
e79ea0c3a34e: Pushing [==========> ]
3.188MB/15.41MB
09281fa8fe38: Pushing [> ]
3.823MB/324MB
b56a902b0aef: Pushed
0683de282177: Pushing [=> ]

阿里云

1、登录阿里云
2、找到容器镜像服务
在这里插入图片描述
3、创建命名空间
在这里插入图片描述

4、创建镜像仓库
5、点击进入这个镜像仓库,可以看到所有的信息
在这里插入图片描述
6、测试推送发布

# 1、登录阿里云
[root@zhoukun tomcat]# docker login --username=18225148644 registry.cnbeijing.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/#credentialsstore
Login Succeeded
# 2、设置 tag
docker tag [ImageId] registry.cn-beijing.aliyuncs.com/bilibilizhoukun/zhoukun-test:[镜像版本号]
[root@zhoukun tomcat]# docker tag 251ca4419332 registry.cnbeijing.aliyuncs.com/bilibili-zhoukun/zhoukun-test:v1.0
# 3、推送命令
docker push registry.cn-beijing.aliyuncs.com/bilibili-zhoukun/zhoukuntest:[镜像版本号]
[root@zhoukun tomcat]# docker push registry.cnbeijing.aliyuncs.com/bilibili-zhoukun/zhoukun-test:v1.0

在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值