经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 数据库/运维 » Oracle » 查看文章
关于docker构建镜像
来源:cnblogs  作者:prayzzZ  时间:2018/12/21 10:41:09  对本文有异议

今天正好看到这一块了,记录一下,希望可以帮助到大家。

构建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

--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

 

  1. FROM
    1. 格式为FROM<image>或者FROM<image>:<tag>
  2. MAINTAINER
    1. 格式为MAINTAINER<name>,指定维护者信息、
  3. RUN
    1. 格式为RUN<command>或者["executable","param1","param2"].
  4. CMD
    1. CMD["executable","param1","param2",]使用exec执行,推荐方式。
    2. 指定启动容器时执行的命令,每个Dockerfile只能有一条CMD指令,如果指定了多条指令,则最后一条执行。(会被启动时指定的命令覆盖)
  5. EXPOSE
    1.   

      格式:EXPOSE <port>  [ <port> ...]

      告诉Docker服务端暴露端口,在容器启动时需要通过 -p 做端口映射

  6. ENV
    1. 格式:ENV <key> <value>

      指定环境变量,会被RUN指令使用,并在容器运行时保存

  7. ADD
    1. 格式:ADD  <src>  <dest>

      复制指定的<src>到容器的<dest>中,<src>可以是Dockerfile所在的目录的一个相对路径;可以是URL,也可以是tar.gz(自动解压)

  8. COPY
    1. 格式:COPY <src>  <dest>

      复制本地主机的 <src> ( 为 Dockerfile 所在目录的相对路径)到容器中的 <dest> (当使用本地目录为源目录时,推荐使用 COPY)

  9. ENTRYPOINT
    1. 格式:ENTRYPOINT ["","",""]

      配置容器启动后执行的命令,并且不可被 docker run 提供的参数覆盖。(每个 Dockerfile 中只能有一个 ENTRYPOINT ,当指定多个时,只有最后一个起效)

  10. VOLUME
    1. 格式:VOLUME ["/mnt"] 

      创建一个可以从本地主机或其他容器挂载的挂载点,一般用来存放数据库和需要保持的数据等

  11. USER
    1. 格式:USER daemon

      指定运行容器时的用户名或 UID,后续的 RUN 也会使用指定用户。

  12. WORKDIR
    1. 格式:WORKDIR /path/to/workdir

      为后续的 RUN 、 CMD 、 ENTRYPOINT 指令配置工作目录。(可以使用多个 WORKDIR 指令,后续命令如果参数是相对路径, 则会基于之前命令指定的路径)

  13. ONBUILD
    1. 格式:ONBUILD [INSTRUCTION]

      配置当所创建的镜像作为其它新创建镜像的基础镜像时,所执行的操作指令

例如构建自己的镜像:

编写dockerfile如下:

 #基于centos7构建

  1. FROM centos7
    #维护者
    MAINTAINER pray
  1. #安装依赖
  2. RUN yum -y install tar cpp binutiles glibc-kernheaders glibc-common glibc-devel gcc make gcc-c++ libstdc++-devel tcl
  1. #创建安装目录
    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"]
    #设置对外的端口号
  2. EXPOSE 6379








    构建命令
    docker build -t registry.cn-hangzhou.aliyuncs.com/for-docker/redis

    因为centos很大,所以我也没有执行玩dockerfile ,不能保证一定正确;
    今天就先记录到这把

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号