• dockerfile note


    dockerfile note
    reference

    summary

    1. defination
      docker can build images automatically by reading the instructions from a dockerfile. dockerfile is a text document that contains all the commands a user could call on the command line to assemble an image.

    2. usage
      the docker build command builds an image from a dockerfile and context. the build's context is the set of files at a specified location PATH or URL. warning: don't use PATH /, because it can transfer the entire contents of your hard drive to the docker daemon.
      docker build -f /home/vickey/dockerfile .

    3. format
      a. INSTRUCTION is not case-sensitive but convention is UPPERCASE. e.g: FROM nginx:1.13
      b. must start with FROM.
      c. docker treat lines begin with # as a comment.

    4. parser directive
      reference
      a. parser directive is not case-sentive but convention is lowercase and must at the first line of dockerfile e.g: # directive=value then the next line is FROM nginx:1.13
      b. can't repeat

    5. escape
      in linux default is , " ` " in windows

    6. variable replacement
      ${variable:-word} indicates that if variable is set then the result will be that value. If variable is not set then word will be the result.
      ${variable:+word} indicates that if variable is set then word will be the result, otherwise the result is the empty string.

    7. .dockerignore file
      Before the docker CLI sends the context to the docker daemon, it looks for a file named .dockerignore in the root directory of the context. If this file exists, the CLI modifies the context to exclude files and directories that match patterns in it

    8. FROM
      The tag or digest values are optional. If you omit either of them, the builder assumes a latest tag by default
      FROM buildpack-deps:jessie

    9. RUN

      echo $HOME'```
      equivalent to following
      `RUN /bin/bash -c 'source $HOME/.bashrc; echo $HOME'`
      
      
    10. CMD
      There can only be one CMD instruction in a Dockerfile. If you list more than one CMD then only the last CMD will take effect
      CMD echo "This is a test." | wc -

    11. LABEL
      A LABEL is a key-value pair.
      LABEL version="1.0"
      To view an image’s labels, use the docker inspect command
      docker inspect docker container name

    12. EXPOSE
      By default, EXPOSE assumes TCP. You can also specify UDP:
      EXPOSE 80/udp
      or publish port when run images
      docker run -p 80:80/tcp -p 80:80/udp image_name

    13. ENV
      The entire string after the first space will be treated as the - including whitespace characters. allows for multiple variables to be set at one time

      ENV myDog Rex The Dog```
      equivalent ti `ENV myName = John Doe`
      
      
    14. ADD
      The ADD instruction copies new files, directories or remote file URLs from and adds them to the filesystem of the image at the path

    15. COPY
      The COPY instruction copies new files or directories from <src> and adds them to the filesystem of the container at the path <dest>.
      COPY VS ADD

    16. VOLUME
      The VOLUME instruction creates a mount point with the specified name and marks it as holding externally mounted volumes from native host or other containers. The value can be a JSON array, VOLUME ["/var/log/"], or a plain string with multiple arguments, such as VOLUME /var/log or VOLUME /var/log/var/db

    17. WORKDIR
      The WORKDIR instruction sets the working directory for any RUN, CMD, ENTRYPOINT, COPY and ADD instructions that follow it in the Dockerfile

      RUN pwd```
  • 相关阅读:
    解析python数据后用html输出
    python 自动化测试HTTP接口
    python 自动化对比返回结果
    Java 基础知识 练习
    Java 菜鸟学习之 script脚本语句
    java语言的认识
    Script 语言的简单练习题 乘法口诀
    Script 简单语句的练习题
    Java菜鸟培训第二天
    36个号码随机摇奖编码
  • 原文地址:https://www.cnblogs.com/vickey-wu/p/8745953.html
Copyright © 2020-2023  润新知