Docker(二)镜像管理
一、镜像仓库
镜像存储中的核心概念仓库(Repository)是镜像存储的位置。Docker 注册服务器(Registry)是仓库存储的位置。每个仓库包含不同的镜像。Docker Hub 是Docker官方提供公共仓库,提供大量的常用镜像,由于国内网络原因经常连接Docker Hub会比较慢,所以我们也可以选择一些国内提供类似Docker Hub镜像服务站点。
镜像搜索:
root@ryj:/home/wuh151# docker search mysql NAME DESCRIPTION STARS OFFICIAL AUTOMATED mysql MySQL is a widely used, open-source relation… 10247 [OK] mariadb MariaDB is a community-developed fork of MyS… 3785 [OK] mysql/mysql-server Optimized MySQL Server Docker images. Create… 749 [OK] percona Percona Server is a fork of the MySQL relati… 514 [OK] centos/mysql-57-centos7 MySQL 5.7 SQL database server 86
镜像拉取:
root@ryj:/home/wuh151# docker pull mysql Using default tag: latest latest: Pulling from library/mysql 6ec7b7d162b2: Pull complete fedd960d3481: Pull complete 7ab947313861: Pull complete
本地镜像展示:
root@ryj:/home/wuh151# docker image ls REPOSITORY TAG IMAGE ID CREATED SIZE mysql latest ab2f358b8612 2 days ago 545MB harbor.lingda.com/common/java 8-jre-alpine fdc893b19a14 3 years ago 108MB
二、Docker image 指令
root@ryj:/home/wuh151# docker image --help Usage: docker image COMMAND Manage images Commands: build Build an image from a Dockerfile history Show the history of an image import Import the contents from a tarball to create a filesystem image inspect Display detailed information on one or more images load Load an image from a tar archive or STDIN ls List images prune Remove unused images pull Pull an image or a repository from a registry push Push an image or a repository to a registry rm Remove one or more images save Save one or more images to a tar archive (streamed to STDOUT by default) tag Create a tag TARGET_IMAGE that refers to SOURCE_IMAGE
镜像构建:
docker build -t registry/server-name:1.0 .
(仓库) (名称) (tag)(路径)
三、Dockerfile 创建镜像
Dockfile是一种被Docker程序解释的脚本,Dockerfile由一条一条的指令组成,每条指令对应Linux下面的一条命令。Docker程序将这些Dockerfile指令翻译真正的Linux命令。Dockerfile的指令是忽略大小写的,建议使用大写,使用#作为注释,每一行只支持一条指令,每条指令可以携带多个参数。
Dockerfile的指令根据作用可以分为两种,构建指令和设置指令。构建指令用于构建image,其指定的操作不会在运行image的容器上执行;设置指令用于设置image的属性,其指定的操作将在运行image的容器中执行
Dockerfile文件示例:
FROM harbor.lingda.com/common/java:8-jre-alpine ARG version ARG RUN_USER=genius ARG RUN_GROUP=genius # 通常需要修改的参数instanceHost,zkStr # javaOpts,configRoot。可以根据运行情况修改。 # 构建带进来的参数version,appName。通常不需要修改。 # 服务运行的端口:instancePort。非特殊情况,不需要修改。 ENV MAIN_CLASS="uupm-service-user.jar" ENV JAVA_OPTS=" -server -Xms512M -Xmx1024M -XX:CompressedClassSpaceSize=512M -XX:MetaspaceSize=512M -XX:MaxMetaspaceSize=1024M" ENV NACOS_HOST="http://nacos.lingda.com" ENV NACOS_PORT="80" ENV NACOS_CONTEXT_PATH="nacos" ENV NACOS_USER="nacos" ENV NACOS_PASSWD="nacos" ENV NACOS_NAMESPACE_ID="dev-nacos" ENV VERSION="dev-nacos" ENV INSTANCE_HOST=192.168.101.39 ENV INSTANCE_PORT=11002 ENV TZ=Asia/Shanghai LABEL app=uupm-service-user WORKDIR /opt RUN set -eux; \ addgroup -g 1000 ${RUN_GROUP}; \ adduser -D -u 1000 -G ${RUN_GROUP} ${RUN_USER}; \ mkdir logs && chown ${RUN_USER}:${RUN_GROUP} logs USER ${RUN_USER} COPY *.jar application.properties logback.xml bootstrap.properties /opt/ VOLUME ["/opt/logs"] ENTRYPOINT java ${javaOpts} -jar *.jar --logging.config=logback.xml EXPOSE $INSTANCE_PORT
Dockerfile指令示例:
指令 | 语法 | 描述 |
FROM |
FROM < image>[:< tag> | @< digest>] 示例:FROM mysql:5.6 |
设置基础镜像。镜像都是从一个基础镜像(操作系统或其他镜像)生成, 可以在一个Dockerfile中添加多条FROM指令,一次生成多个镜像 。 注意:如果忽略tag选项,会使用latest镜像 |
MAINTAINER |
MAINTAINER < name> 示例:MAINTAINER yj Rao |
设置镜像作者 |
RUN |
RUN < command> 示例:RUN apk update RUN ["executable", "param1", "param2"] 示例:RUN ["./test.php", "dev", "offline"] |
RUN指令会生成容器,在容器中执行脚本。 脚本指令完成后,Docker Daemon会将该容器提交为一个中间镜像,供后面的指令使用。 Dockerfile 的指令每执行一次都会在docker上新建一层。所以过多无意义的层,会造成镜像膨胀过大。 RUN指令第一种方式为shell方式,使用/bin/sh -c < command>运行脚本,可以在其中使用\将脚本分为多行 RUN指令第二种方式为exec方式,镜像中没有/bin/sh或者要使用其他shell时使用该方式,其不会调用shell命令 等价于 RUN ./test.php dev offline |
CMD |
CMD < command> CMD ["executable", "param1", "param2"] |
设置容器的启动命令。如果 Dockerfile 中如果存在多个 CMD 指令,仅最后一个生效。 CMD不同于RUN,CMD用于指定在容器启动时所要执行的命令,而RUN用于指定镜像构建时所要执行的命令。 CMD ["<param1>","<param2>",...] # 该写法是为 ENTRYPOINT 指令指定的程序提供默认参数 |
LABEL | LABEL < key>=< value> < key>=< value> … | 设置镜像的标签,不同标签之间通过空格隔开。每条指令都会生成一个镜像层 示例:LABEL version="1.0" description="这是一个Web服务器" by="IT笔录" |
EXPOSE | EXPOSE < port> < port> … | EXPOSE 指令是声明运行时容器提供服务端口,在 Dockerfile 中写入这样的声明有两个好处: 一个是帮助镜像使用者理解这个镜像服务的守护端口,以方便配置映射; 另一个用处则是在运行时使用随机端口映射时,也就是 docker run -P 时,会自动随机映射 EXPOSE 的端口。 |
ENV |
ENV <key> <value> ENV <key1>=<value1> <key2>=<value2>... |
设置镜像中的环境变量。通过${变量名}或者 $变量名使用变量 |
COPY | COPY <src>... <dest> | 复制指令,从上下文目录中复制文件或者目录到容器里指定路径。 |
ADD | ADD <src>... <dest> | 与copy类似,但是src为压缩文件,并且压缩方式为gzip,bzip2或xz时,指令会将其解压为目录 |
ENTRYPOINT |
ENTRYPOINT [“executable”,”param1”,”param2”] ENTRYPOINT command param1 param2 |
设置容器的入口程序,入口程序是容器启动时执行的程序。 每个Dockerfile只能够包含一个entrypoint,多个entrypoint只有最后一个有效。 当定义了entrypoint以后,CMD只能够作为参数进行传递。 |
VOLUME | VOLUME ["/path/to/dir"] | 用来创建一个在image之外的mount point,用来在多个container之间实现数据共享 |
USER | USER < name> | 使用USER指定用户后,Dockerfile中其后的命令RUN、CMD、ENTRYPOINT都将使用该用户。 |
WORKDIR | WORKDIR < Path> | 设置RUN CMD ENTRYPOINT ADD COPY指令的工作目录 |
ONBUILD | ONBUILD [INSTRUCTION] | 用于延迟构建命令的执行。简单的说,就是 Dockerfile 里用 ONBUILD 指定的命令,在本次构建镜像的过程中不会执行(假设镜像为 test-build)。当有新的 Dockerfile 使用了之前构建的镜像FROM test-build ,这是执行新镜像的 Dockerfile 构建时候,会执行 test-build 的 Dockerfile 里的 ONBUILD 指定的命令。 |