自定义docker镜像,ubuntu安装命令并导出

文章讲述了在使用极简镜像eclipse-temurin时,遇到ping命令缺失的问题。通过分析,作者介绍了如何使用dockercommit而非dockersave和dockerload来解决容器内的命令添加和镜像提交,以及dockerimport和dockerexport的区别和使用场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题现象

  • 我们的通讯服务,需要监测前端设备的在线情况(是否在线、丢包率、延迟等),使用ping命令去实现此功能
  • 前期开发测试没有问题,部署时发现该命令无法执行,报错,找不到这个命令bash: ping:command not found
  • 我们使用的是极简镜像eclipse-temurin:11-jre-focal,这个版本里的ubuntu没有安装不需要的命令

解决步骤

  • Docker是一种流行的容器化平台,它允许开发者将应用程序及其依赖项打包成可移植的容器

  • 一开始想使用docker save 与 docker load 命令,这两个命令配对使用

  • docker save,保存镜像,将已有镜像保存为文件

  • docker load,装载镜像,将已有镜像文件装载到服务器的docker里

  • 失败,这两个是对镜像的导出和使用,对容器里的修改根本没用,影响不到

  • 然后考虑使用 docker import 与 docker export 命令,这两个命令也是配对使用的

  • docker export,保存容器,将已有容器导出,算是一个备份

  • docker import,导入保存的容器,算是恢复

  • 还是失败,这个只是对容器的保存和恢复,没法作为镜像放到其他机器上使用

  • 注意:以上两对命令都是配对使用,不能混用

  • 最终解决方法:docker commit,提交容器修改到镜像,可以在其他机器使用,完美解决
    在这里插入图片描述

  • 具体步骤如下:

# docker load 导入 jib 打包好的 unit镜像
docker load -i unit.tar
# docker images查看下,此时可以看到本镜像188M
docker images
# 根据镜像创建容器
docker-compose up -d unit
# 以root用户(-u0)权限进入容器
docker exec -it -u0 unit /bin/bash
# apt-get update 更新源
apt-get update -y
# 安装ping命令
apt-get install -y iputils-ping
# 测试ping命令(成功)
ping -c 4 -w 2 10.1.1.104
# exit 退出,关闭容器(非必须)
docker stop unit
# 将此安装过ping命令的容器,提交为镜像
docker commit unit unit
# docker images查看下,此时可以看到本镜像427M
docker images
# docker save 将镜像保存成tar文件(供后续load使用,而且此时是413M)
docker save -o unit.tar unit 
  • 此时导出的镜像,可以拿到其他机器装载使用,ping命令也还在
    在这里插入图片描述
  • 此时还存在一个问题,每次打这个镜像都要把这个流程走一遍
  • 正确做法是把我们jib打包使用的eclipse-temurin:11-jre-focal镜像,装载并创建容器,再修改容器安装命令,最后导出供后续jib打包使用,但问题是无法启动创建的容器11-jre-focal,这个后面有时间再去探究

相关命令详细介绍

docker save 与 docker load

Docker提供了多种命令来管理镜像和容器,其中包括docker save和docker load。

docker save: 将一个或多个Docker镜像保存为tar文件。这个tar文件包含了镜像的所有层以及元数据信息,可以用于在其他机器上导入和部署。

使用docker save命令的一般语法为:

docker save <IMAGE> -o <OUTPUT.tar>

其中,<IMAGE>是要保存的镜像的名称或ID,<OUTPUT.tar>是保存的tar文件的输出路径。

示例:

docker save myimage:tag -o myimage.tar

docker load: 从一个tar文件中加载一个或多个Docker镜像,并将其导入本地Docker引擎。加载的镜像可以在本地机器上使用。

使用docker load命令的一般语法为:

docker load -i <INPUT.tar>

其中,<INPUT.tar>是要加载的tar文件的路径。

示例:

docker load -i myimage.tar

需要注意的是,保存的tar文件可以通过网络传输到其他机器上,并使用docker load命令进行加载。这在离线环境或网络带宽较低的情况下非常有用。

docker import 与 docker export

docker import和docker export是Docker提供的两个命令,用于导入和导出容器镜像。

  1. docker export命令用于将容器的文件系统打包为一个tar文件,可以将容器的文件系统保存为一个镜像文件或备份文件,不包含容器的元数据和配置信息。
    使用方法如下:

    docker export [OPTIONS] CONTAINER_NAME > FILENAME.tar
    

    示例:

    docker export my_container > my_container.tar
    
  2. docker import命令用于将通过docker export导出的tar文件导入为一个镜像文件,可以使该镜像文件作为新的基础镜像进行容器创建。
    使用方法如下:

    docker import [OPTIONS] FILENAME.tar [REPOSITORY[:TAG]]
    

    示例:

    docker import my_container.tar my_image:tag
    

需要注意的是,使用docker import导入的镜像文件不包含容器的元数据和配置信息,只包含文件系统。因此,通过该方式导入的镜像不能保留容器的运行状态、端口映射等配置信息。

如果需要完整地备份和恢复容器,推荐使用docker commit和docker save命令。docker commit命令用于保存容器的状态为一个新镜像文件,docker save命令用于将镜像保存为tar文件,可以包含所有的信息和配置。

希望可以帮到你!有其他问题请继续提问。

docker commit

Docker commit是Docker提供的一种命令,用于将运行中的容器保存为一个新的镜像。通过该命令,可以将容器的当前状态打包保存为一个镜像,以供后续使用或分享。

使用Docker commit命令,可以在容器上进行一些操作,如修改配置文件、安装软件等。然后通过commit命令将容器的状态保存为一个新的镜像,以便后续创建新的容器时使用。

具体使用方法如下:

  1. 启动一个容器:首先需要使用docker run命令启动一个容器。

    docker run -it [容器名称] /bin/bash
    
  2. 在容器内进行操作:在容器内部,可以进行需要的配置和操作,如修改配置文件、安装软件等。

  3. 提交容器为镜像:操作完毕后,使用docker commit命令提交容器为镜像。该命令的基本格式如下:

    docker commit [容器ID] [新镜像名称]
    

    容器ID可以通过docker ps命令查看,新镜像名称是你给新镜像取的名称。

  4. 查看新镜像:使用docker images命令可以查看所有的镜像列表,包括刚刚提交的新镜像。

通过Docker commit命令,可以快速创建和管理自定义的镜像。然而,需要注意的是,Docker官方推荐使用Dockerfile来构建镜像,因为Dockerfile可以更好地管理镜像的构建过程和依赖关系。

### 如何在Ubuntu上进行Docker镜像的导入和导出 #### 导出Docker镜像 为了将正在运行中的容器状态保存下来转换成一个新的镜像文件,可以使用`docker export`命令。此方法适用于创建基础镜像的情况,例如,在一个Ubuntu镜像基础上启动了一个容器进行了软件安装和其他配置之后,可以通过下面的方式将其保存为基础镜像[^2]。 ```bash sudo docker ps -a # 列出所有的容器来找到想要导出的那个容器ID或名称 sudo docker export <container_id> -o exported_image.tar # 将指定容器导出为tar文件 ``` 对于整个镜像及其元数据(标签等),则应该采用`docker save`命令来进行打包操作。这对于那些由多部分组成的复杂应用程序特别有用,尤其是当目标机器无法访问互联网从而不能拉取远程仓库里的最新版本时。 ```bash sudo docker images # 查看当前系统中存在的所有本地镜像列表以确定要保存哪个镜像 sudo docker save -o saved_image.tar my_custom_image:tag_name # 把特定标记名下的镜像存档至saved_image.tar中 ``` #### 导入Docker镜像 一旦有了`.tar`格式的镜像档案文件,无论是通过上述哪种方式获得的,都可以利用相应的加载工具恢复这些资源: 如果是之前用`export`得到的基础层映像,则需先建立新的空白容器再从中读取内容;而经由`save`产生的完整备份可以直接被重新载入成为可用的状态。 针对前者情况可执行如下指令序列完成重建过程: ```bash cat exported_image.tar | sudo docker import - imported_image_name[:tag] # 或者更简洁的形式: sudo docker import exported_image.tar imported_image_name[:tag] ``` 而对于后者而言只需简单调用一次`load`动作即可实现快速还原: ```bash sudo docker load -i saved_image.tar ``` 以上就是在Ubuntu操作系统环境下关于怎样正确地实施Docker镜像进出口工作的指导说明。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

坚持是一种态度

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值