关于docker构建镜像
今天正好看到这一块了,记录一下,希望可以帮助到大家。
构建Dockerfile
先来看一个示例:
-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
#第一行必须基于某个镜像
FROM java:8-jre
#维护者信息
MAINTAINER dtelec developer
#镜像的操作指令
ADD ./target/icmes-schedule-service.jar /app/
#容器启动时执行指令
CMD ["java", "-Xmx200m", "-jar", "/app/icmes-schedule-service.jar"]
#暴露出来对外的端口
EXPOSE 9800
--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
- FROM
- 格式为FROM<image>或者FROM<image>:<tag>
- MAINTAINER
- 格式为MAINTAINER<name>,指定维护者信息、
- RUN
- 格式为RUN<command>或者["executable","param1","param2"].
- CMD
- CMD["executable","param1","param2",]使用exec执行,推荐方式。
- 指定启动容器时执行的命令,每个Dockerfile只能有一条CMD指令,如果指定了多条指令,则最后一条执行。(会被启动时指定的命令覆盖)
- EXPOSE
-
格式:EXPOSE <port> [ <port> ...]
告诉Docker服务端暴露端口,在容器启动时需要通过 -p 做端口映射
-
- ENV
-
格式:ENV <key> <value>
指定环境变量,会被RUN指令使用,并在容器运行时保存
-
- ADD
-
格式:ADD <src> <dest>
复制指定的<src>到容器的<dest>中,<src>可以是Dockerfile所在的目录的一个相对路径;可以是URL,也可以是tar.gz(自动解压)
-
- COPY
-
格式:COPY <src> <dest>
复制本地主机的 <src> ( 为 Dockerfile 所在目录的相对路径)到容器中的 <dest> (当使用本地目录为源目录时,推荐使用 COPY)
-
- ENTRYPOINT
-
格式:ENTRYPOINT ["","",""]
配置容器启动后执行的命令,并且不可被 docker run 提供的参数覆盖。(每个 Dockerfile 中只能有一个 ENTRYPOINT ,当指定多个时,只有最后一个起效)
-
- VOLUME
-
格式:VOLUME ["/mnt"]
创建一个可以从本地主机或其他容器挂载的挂载点,一般用来存放数据库和需要保持的数据等
-
- USER
-
格式:USER daemon
指定运行容器时的用户名或 UID,后续的 RUN 也会使用指定用户。
-
- WORKDIR
-
格式:WORKDIR /path/to/workdir
为后续的 RUN 、 CMD 、 ENTRYPOINT 指令配置工作目录。(可以使用多个 WORKDIR 指令,后续命令如果参数是相对路径, 则会基于之前命令指定的路径)
-
- ONBUILD
-
格式:ONBUILD [INSTRUCTION]
配置当所创建的镜像作为其它新创建镜像的基础镜像时,所执行的操作指令
-
例如构建自己的镜像:
编写dockerfile如下:
#基于centos7构建
FROM centos7
#维护者
MAINTAINER pray
#安装依赖 RUN yum -y install tar cpp binutiles glibc-kernheaders glibc-common glibc-devel gcc make gcc-c++ libstdc++-devel tcl
#创建安装目录
RUN mkdir -p /redis/data && cd /redis
#拷贝redis的安装包
COPY ./redis-5.tar.gz /redis
#解压
RUN cd /redis && tar -xvf redis5.tar.gz && rm -rf redis5.tar.gz && cd redis5
#编译、安装
RUN cd /redis/redis5 && make && make install
#复制配置文件到/redis中,并且修改iredis为后台运行
RUN cp /redis/redis5/redis.conf /redis/ && echo "daemonize yes" >> redis.conf
#设置数据挂载目录以及工作目录
VOLUME /redis/data
WORKDIR /redis/data
#容器启动后执行该命令
ENTRYPOINT ["/user/local/bin/redis-server","/redis/redis.conf"]
#设置对外的端口号 EXPOSE 6379
构建命令
docker build -t registry.cn-hangzhou.aliyuncs.com/for-docker/redis
因为centos很大,所以我也没有执行玩dockerfile ,不能保证一定正确;
今天就先记录到这把