docker学习02 - Dockerfile
此文为自学笔记,参考视频教程 - 狂神说docker教程 --> blibli-狂神说docker
Dockerfile
Docker基本组成
初识Dockerfile
Dockerfile就是用来构建docker镜像的构建文件!命令脚本!
通过这个脚本可以生成镜像,镜像是一层一层的,脚本一个个的命令,每个命令都是一层。
# 创建一个dockerfile文件,名字可以随意 建议 Dockerfile
# 文件中的内容 指令(大写) 参数
FROM 'centos'
VOLUME ["volume01","volume02"]
CMD echo "---end---"
CMD /bin/bash
# 这里的每个命令,就是镜像的一层。
# 生成镜像
docker build -f dockerfile1 -t seafyliang/centos .
# 启动生成的镜像
docker run -it 5daftwasfa34 /bin/bash
学习Dockerfile
构建步骤:
1、编写一个 dockerfile 文件
2、docker build 构建成为一个镜像
3、docker run 运行镜像
4、docker push 发布镜像(DockerHub、阿里云镜像仓库)
DockerFile构建过程
基础知识:
1、每个保留关键字(指令)都是必须是大写字母
2、执行从上到下顺序执行
3、#表示注释
4、每一个指令都会创建提交一个新的镜像层,并提交。
dockerfile是面向开发的,我们以后要发布项目,做镜像,就需要编写dockerfile文件,这个文件十分简单。
Docker镜像逐渐成为企业交付的标准,必须要掌握。
**步骤:**开发,部署,运维。。。缺一不可。
DockerFile:构建文件,定义了一切的步骤,源代码
DockerImages:通过 DockerFile 构建生成的镜像,最终要发布和运行的产品。
Docker容器:container 容器就是镜像运行起来提供服务的。
DockerFile的指令
FROM # 基础镜像,一切从这里开始构建 centos
MAINTAINER # 镜像是谁写的,作者信息,姓名+邮箱
RUN # 镜像构建的时候需要运行的命令
ADD # 步骤:tomcat镜像,这个tomcat压缩包,添加内容
WORKDIR # 镜像的工作目录
VOLUME # 挂载的目录
EXPOSE # 暴露端口配置
CMD # 指定这个容器启动的时候要运行的命令,只有最后一个会生效,可被替代
ENTRYPOINT # 指定这个容器启动的时候要运行的命令,可以追加命令
ONBUILD # 当构建一个被继承 DockerFile 这个时候就会运行 ONBUILD 的指令。触发指令。
COPY # 类似ADD,将我们的文件拷贝到镜像中
ENV # 构建的时候设置环境变量
实战测试
Docker Hub 中 99% 镜像都是从这个基础镜像过来的 FROM scratch,然后配置需要的软件和配置来进行构建
创建一个自己的centos
# 1、编写dockerfile文件
FROM centos
MAINTAINER seafyliang<seafyliang@icloud.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 mydockerfile-centos -t mycentos:0.1 .
# 返回
Successfully built e2bd75jaf080
Successfully tagged mycentos:0.1
# 3、测试运行
docker run -it mycentos:0.1
# 列出本地镜像的变更历史
docker history 镜像ID
CMD 和 ENTRYPOINT 区别
CMD # 指定这个容器启动的时候要运行的命令,只有最后一个会生效,可被替代
ENTRYPOINT # 指定这个容器启动的时候要运行的命令,可以追加命令
# 编写dockerfile
FROM centos
ENTRYPOINT ["ls","-a"]
# 打包生成docker镜像
docker build -f dockerfile-entrypoint -t docker-test
# 追加执行命令
docker run e2bd75jaf080 -l
# 追加命令,是直接拼接在 ENTRYPOINT后面执行的
实战:Tomcat镜像
1、准备镜像文件 tomcat压缩包,jdk的压缩包
2、编写dockerfile文件,使用官方命名Dockerfile,build会自动寻找这个文件,不需要 -f 指定了。
FROM centos
MAINTAINER seafyliang<seafyliang@icloud.com>
COPY readme.txt /usr/local/readme.txt
# ADD会自动解压
ADD jdk-8u11-linux-x64.tar.gz /usr/local
ADD apache-tomcat-9.0.22.tar.gz /usr/local
RUN yum -y install vim
ENV MYPATH /usr/local
WORKDIR $MYPATH
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_BASH /usr/local/apache-tomcat-9.0.22
ENV PATH $PATH:$JAVA_HOME:$CATALINA_HOME/lib:$CATALINA_HOME/bin
EXPOSE 8080
CMD /usr/local/apache-tomcat-9.0.22/bin/startup.sh && tail -F /usr/local/apache-tomcat-9.0.22/bin/logs/catalina.out
3、构建镜像( . 不要忘了)
docker build -t diytomcat .
4、运行自定义tomcat镜像
# 端口映射,挂载部署webapps、日志文件
docker run -d -p 9090:8080 —name mydiytomcat -v /seafyliang/dockerdata/tomcat:/usr/local/apache-tomcat-9.0.22/webapps/test -v /seafyliang/dockerdata/tomcat/logs:/usr/local/apache-tomcat-9.0.22/logs
5、访问测试
localhost:9090
6、发布项目(由于做了卷挂载,直接在本地编写项目就可以)
发布自己的镜像
DockerHub
1、地址 https://hub.docker.com/ 注册自己的账号
2、确定这个账号可以登录
3、服务器上提交自己的镜像
❯ docker login --help
Log in to a Docker registry or cloud backend.
If no registry server is specified, the default is defined by the daemon.
Usage:
docker login [OPTIONS] [SERVER] [flags]
docker login [command]
Available Commands:
azure Log in to azure
Flags:
-h, --help Help for login
-p, --password string password
--password-stdin Take the password from stdin
-u, --username string username
4、登录完毕后就可以提交景象了,就是一步 docker push
# 打标签
docker tag 镜像ID seafyliang/diytomcat:1.0
docker push 作者名字/镜像名称:Tag
发布到阿里云容器服务
阿里云镜像服务
- 参考官方地址
1、登录阿里云容器镜像服务
2、找到容器镜像服务
3、创建命名空间
4、创建容器镜像
5、浏览阿里云
Docker流程小结
打包给别人
# 保存镜像到本地
❯ docker save --help
Usage: docker save [OPTIONS] IMAGE [IMAGE...]
Save one or more images to a tar archive (streamed to STDOUT by default)
Options:
-o, --output string Write to a file, instead of STDOUT
# 加载本地镜像
❯ docker load --help
Usage: docker load [OPTIONS]
Load an image from a tar archive or STDIN
Options:
-i, --input string Read from tar archive file, instead of STDIN
-q, --quiet Suppress the load output