docker镜像制作、压缩及镜像加载

简介:

docker镜像制作、压缩及镜像加载

  1. 系统环境
    #cat /etc/redhat-release
    CentOS Linux release 7.3.1611 (Core)
  2. 编写Dockerfile文件
    FROM centos:7.2.1511
    ##作者标签,联系方式
    LABEL maintainer "wtf@datagrand.com"
    ##环境变量硬编码及时区
    ENV ENVIRONMENT production
    RUN cd / && ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
    ##yum 基础工具,记住clean
    RUN yum clean all \
    && yum makecache \
    && yum install -y wget gcc gcc-c++ python-devel bzip2 \
    && yum clean all
    COPY docker-ce-17.09.0.ce-1.el7.centos.x86_64.rpm /usr/local/docker-ce-17.09.0.ce-1.el7.centos.x86_64.rpm
    ADD docker.txt  /tmp/docker.txt
    ##docker 基础工具及版本
    RUN cd /usr/local \
    && yum install -y docker-ce-17.09.0.ce-1.el7.centos.x86_64.rpm
    ##镜像启动命令 
    CMD ["systemctl","start","docker"]
  3. 文件目录路径

    #pwd    
    /root/dockerfile
    说明:上面是当前文件路径,目录内容如下:
    #ls
    docker-ce-17.09.0.ce-1.el7.centos.x86_64.rpm 
    docker.txt
    Dockerfile
    docker_shell.sh
    ##docker-ce-17.09.0.ce-1.el7.centos.x86_64.rpm、Dockerfile、docker_shell.sh,docker.txt在同一个目录下!
    docker.txt的内容:
    #cat docker.txt
    this is a test
  4. 编写脚本docker_shell.sh
    #cat docker_shell.sh
    TIMENOW=`date +%y.%m.%d.%H%M`
    ##-f 指定文件 , -t 指定生成镜像名称 , 冒号后为版本号 , 例子 : ##docker_image:17.08.01.1311
    docker build -f Dockerfile -t docker_image:${TIMENOW} .
  5. 执行docker_shell.sh
    #sh docker_shell.sh

    docker镜像制作、压缩及镜像加载

  6. 查看镜像
    #docker images
    REPOSITORY          TAG                 IMAGE ID            CREATED             SIZE
    docker_image        18.01.14.1702       d227774c2960        23 minutes ago      588MB
  7. 镜像压缩与打包
    #docker save d227774c2960 |gzip>docker_file.tgz
    #ls
    docker-ce-17.09.0.ce-1.el7.centos.x86_64.rpm 
    docker_file.tgz 
    docker.txt
    Dockerfile
    docker_shell.sh
    
  8. 镜像导入
    ##把docker里原有docker_image镜像删除,导入压缩打包后的镜像
    #docker rmi d227774c2960
    #docker images|grep docker_image
    #docker load < docker_file.tgz 
    #docker tag  d227774c296x docker_image:18.01.14.1702 
    说明:d227774c296x是docker load < docker_file.tgz 加载镜像生成的ID号!
  9. 启动镜像
    ##镜像名字是wtf_shiyan
  10. #docker run -itd --name=wtf_shiyan 34b5ef62c921#docker exec -it wtf_shiyan /bin/bash

     本文转自品鉴初心51CTO博客,原文链接:http://blog.51cto.com/wutengfei/2060800,如需转载请自行联系原作者




相关文章
|
1月前
|
存储 安全 持续交付
【Docker 专栏】Docker 镜像的版本控制与管理
【5月更文挑战第9天】本文探讨了Docker镜像版本控制与管理的重要性,包括可重复性、回滚能力、协作开发和持续集成。常用方法有标签、构建参数和版本控制系统。管理策略涉及定期清理、分层管理和镜像仓库。语义化标签、环境变量和配置文件在版本控制中有应用。版本系统与Docker结合能跟踪历史和促进协作。注意点包括优化镜像大小、确保安全性和兼容性。案例分析和未来趋势展示了持续发展的镜像管理技术,为Docker应用的稳定与进步保驾护航。
【Docker 专栏】Docker 镜像的版本控制与管理
|
23天前
|
关系型数据库 MySQL 应用服务中间件
Docker 镜像的创建(二)
Docker 镜像的创建(二)
|
23天前
|
缓存 Linux Apache
Docker 镜像的创建(一)
Docker 镜像的创建(一)
|
2天前
|
应用服务中间件 nginx 开发者
从 Docker Hub 拉取镜像受阻?这些解决方案帮你轻松应对
最近一段时间 Docker 镜像一直是 Pull 不下来的状态,感觉除了挂🪜,想直连 Docker Hub 是几乎不可能的。更糟糕的是,很多原本可靠的国内镜像站,例如一些大厂和高校运营的,也陆续关停了,这对我们这些个人开发者和中小企业来说是挺难受的。之前,通过这些镜像站,我们可以快速、方便地获取所需的 Docker 镜像,现在这条路也不行了。感觉这次动作不小,以后想直接访问 Docker Hub 是不可能了。所以我们得想办法搭建自己的私有镜像仓库。
从 Docker Hub 拉取镜像受阻?这些解决方案帮你轻松应对
|
3天前
|
Java Docker 容器
使用 Spring Boot 构建 Docker 镜像并进行多模式部署
使用 Spring Boot 构建 Docker 镜像并进行多模式部署
15 2
|
5天前
|
数据安全/隐私保护 开发者 Docker
国内docker公开镜像站的关闭!别急,docker_image_pusher 使用Github Action将国外的Docker镜像转存到阿里云私有仓库
通过使用 docker_image_pusher 这样的开源项目,我们能够轻松地解决国内访问 Docker 镜像拉取速度慢及拉去失败的问题,同时保证了镜像的稳定性和安全性。利用 Github Action 的自动化功能,使得这一过程更加简单和高效。
245 2
|
1月前
|
Java Maven Docker
Docker化Spring Boot3应用:从镜像构建到部署
本文介绍了如何在Linux上通过命令行构建和运行Spring Boot 3服务的Docker镜像。首先,基于Ubuntu创建包含JDK 21的基础镜像,然后使用Maven打包Spring Boot应用。接着,构建服务镜像,将应用和依赖添加到镜像中,并设置工作目录和暴露端口。最后,利用docker-compose部署服务,挂载宿主机目录以方便更新静态文件。Docker简化了应用部署,确保了不同环境的一致性。
115 2
Docker化Spring Boot3应用:从镜像构建到部署
|
16天前
|
存储 持续交付 数据安全/隐私保护
实现镜像管理轻松搞定:Docker 仓库管理详解
实现镜像管理轻松搞定:Docker 仓库管理详解
204 1
|
1月前
|
存储 安全 开发者
如何删除 Docker 镜像、容器和卷?
【5月更文挑战第11天】
93 2
如何删除 Docker 镜像、容器和卷?
|
1月前
|
运维 安全 Docker
【Docker 专栏】Docker 镜像安全扫描与漏洞修复
【5月更文挑战第9天】Docker技术在软件开发和部署中带来便利,但其镜像安全问题不容忽视。本文探讨了Docker镜像安全扫描与漏洞修复,强调了镜像安全对应用和系统的重要性。文中介绍了静态和动态扫描方法,列举了软件漏洞、配置漏洞和恶意软件等常见安全问题,并提到了Clair和Trivy等扫描工具。修复策略包括更新软件、调整配置和重建镜像。此外,加强安全意识、规范镜像制作流程和定期扫描是管理建议。未来,将持续面对新的安全挑战,需持续研究和完善安全技术。
【Docker 专栏】Docker 镜像安全扫描与漏洞修复