zoukankan      html  css  js  c++  java
  • Dockerfile制作镜像

    Dockerfile简介

    dockerfile 是一个文本格式的配置文件, 用户可以使用 Dockerfile 来快速创建自定义的镜像,

       另外,使用Dockerfile去构建镜像好比使用pom去构建maven项目一样,有异曲同工之妙

    dockerfile基本结构
    Dockerfile 由一行行命令语句组成, 并且支持以#开头的注释行,一般而言, Dockerfile 主体内容分为四部分:
    基础镜像信息、 维护者信息、 镜像操作指令和容器启动时执行指令。

     部分                             命令
       基础镜像信息                     FROM
       维护者信息                       MAINTAINER
       镜像操作指令                     RUN、(COPY/ADD)、EXPOSE、WORKDIR、ONBUILD、USER、VOLUME等
       容器启动时执行指令               CMD、ENTRYPOINT

    3. docker使用Dockerfile创建jdk容器
    0.启动虚拟机,进入centos

    1.创建文件夹上传jdk的安装包,和在同级目录下编写Dockerfile文件
    #1.创建镜像目录
    mkdir –p /javaxl_docker/jdk
    #1.安装lrzsz命令
    yum install lrzsz -y
    #1.选择文件进行上传
    rz
    # 注意d是大写
    touch Dockerfile

      2.编写 Dockerfile 文件

    #1.指定基础镜像,并且必须是第一条指令
            RROM centos:7
    
            #2.指明该镜像的作者和其电子邮件
            MAINTAINER zs "jt@qq.com"
    
            #3.在构建镜像时,指定镜像的工作目录,之后的命令都是基于此工作目录,如果不存在,则会创建目录
            WORKDIR /jt_docker/jdk
    
            #4.一个复制命令,把jdk安装文件复制到镜像中,语法:ADD <src>... <dest>,注意:jdk*.tar.gz使用的是相对路径
            ADD jdk-8u221-linux-x64.tar.gz /jt_docker/jdk/
    
            #5.配置环境变量
            ENV JAVA_HOME=/jt_docker/jdk/jdk1.8.0_221
            ENV CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
            ENV PATH=$JAVA_HOME/bin:$PATH
    
            #容器启动时需要执行的命令
            #CMD ["java","-version"]

    3.执行Dockerfile文件,初次依赖镜像的时候会下载相应镜像

    docker build -t jdk8:v1.0 .

    注1:-t jdk8:v1.0 给新构建的镜像取名为 jdk8, 并设定版本为 v1.0
    注2:注意最后有个点,代表使用当前路径的 Dockerfile 进行构建

    4.查看镜像
    docker images

    5.创建并启动容器

          docker run -it --name myjdk01 b4d0072da9bd

     6.检查是否有问题

          java -version

     

    dockerfile实践经验
    1.精简镜像用途:尽量让每个镜像的用途都比较集中单一,避免构造大而复杂、多功能的镜像
    2. 选用合适的基础镜像:容器的核心是应用,选择过大的父镜像(如Ubuntu系统镜像)会造成最终生成应用镜像的膝肿,
    推荐选用瘦身过的应用镜像或者较为小巧的系统镜像(alpine)

  • 相关阅读:
    系统架构图
    数据分析学习一
    ASP.NET Web APIs 基于令牌TOKEN验证的实现(保存到DB的Token)
    Web API 令牌(秘钥是双方约定的,并不在网络连接上传输)
    【MVC】ASP.NET MVC Forms验证机制
    细说ASP.NET Forms身份认证
    MVC身份验证及权限管理
    [置顶] Web用户的身份验证及WebApi权限验证流程的设计和实现 (不是Token驗證!!!不是Token驗證!!!都是基於用户身份的票据信息驗證!!!)
    WebApi安全性 使用TOKEN+签名验证 (秘钥是GUID的,私有的,不是雙方的,并不在网络连接上传输)
    WebService 简单安全验证
  • 原文地址:https://www.cnblogs.com/ztbk/p/12047919.html
Copyright © 2011-2022 走看看