docker

关注公众号 jb51net

关闭
首页 > 网站技巧 > 服务器 > 云和虚拟化 > docker > docker打tar包

docker打tar包命令使用小结

作者:爱吃土豆的马铃薯ㅤㅤㅤㅤㅤㅤㅤㅤㅤ

本文主要介绍了docker打tar包命令使用小结,详细讲解了使用 docker ps`命令查看容器信息及镜像名称与容器名称的区别,具有一定的参考价值,感兴趣的可以了解一下

一、打印内容说明

docker ps默认输出的核心列是:容器ID(CONTAINER ID)镜像名称(IMAGE)命令(COMMAND)创建时间(CREATED)状态(STATUS)容器名称(NAMES)

对应到输出内容,每个服务的信息是:

容器ID镜像名称(IMAGE)容器名称(NAMES)
lb91183ebbc59(注:实际是1b9183ebbc59)artifacts.iflytek.com/znfw-docker-repo/znzt2024qyzskv10cpg hxm/ckb/spark-knowledge:V1.0_1111spark-knowledge
b7a640493d8eartifacts.iflytek.com/znfw-docker-repo/znzt2024qyzskv10cpg hxm/ckb/spark-ai-search:V1.0_1014spark-ai-search
3a63f64ae584artifacts.iflytek.com/znfw-docker-repo/znzt2024qyzskv10cpg hxm/ckb/spark-user:V1.0_1013spark-user
7815490ddc9dartifacts.iflytek.com/znfw-docker-repo/znzt2024qyzskv10cpg hxm/ckb/spark-ai-collect:V1.0_1036spark-ai-collect
a5d617d29284artifacts.iflytek.com/znfw-docker-repo/znzt2024qyzskv10cpg hxm/ckb/spark-elasticsearch:V1.0_2spark-elasticsearch
522c186756d1artifacts.iflytek.com/znfw-docker-repo/znzt2024qyzskv10cpg hxm/ckb/spark-gateway:V1.0_7spark-gateway

二、镜像名称 vs 容器名称:核心区别

可以类比成“安装包”和“正在运行的软件”:

一、命令是打包「镜像」,不是容器

docker save 是专门用于将Docker镜像打包成tar文件的命令,而容器是镜像的运行实例,打包容器需要用 docker export(但业务场景中一般优先打包镜像,因为镜像包含完整运行环境)。

你原命令里 spark-knowledge:backup_$(date +%Y%m%d) 是「镜像名称:标签」的格式,但这里有个小问题:你的镜像实际名称不是 spark-knowledgespark-knowledge 是容器名),直接用这个会提示找不到镜像,需要先修正镜像名称。

二、先理清:各服务的「镜像完整名称」(打包的核心前提)

先从你之前的 docker ps 输出里提取每个服务的完整镜像名(镜像名带仓库地址+版本标签),整理如下:

容器名称(NAMES)完整镜像名称(IMAGE,打包时必须用这个)
spark-knowledgeartifacts.iflytek.com/znfw-docker-repo/znzt2024qyzskv10cpg hxm/ckb/spark-knowledge:V1.0_1111
spark-ai-searchartifacts.iflytek.com/znfw-docker-repo/znzt2024qyzskv10cpg hxm/ckb/spark-ai-search:V1.0_1014
spark-userartifacts.iflytek.com/znfw-docker-repo/znzt2024qyzskv10cpg hxm/ckb/spark-user:V1.0_1013
spark-ai-collectartifacts.iflytek.com/znfw-docker-repo/znzt2024qyzskv10cpg hxm/ckb/spark-ai-collect:V1.0_1036
spark-elasticsearchartifacts.iflytek.com/znfw-docker-repo/znzt2024qyzskv10cpg hxm/ckb/spark-elasticsearch:V1.0_2
spark-gatewayartifacts.iflytek.com/znfw-docker-repo/znzt2024qyzskv10cpg hxm/ckb/spark-gateway:V1.0_7

三、各服务镜像打包成tar包的正确命令(逐个说明)

通用规则:

docker save -o 【输出的tar包路径/名称】 【完整镜像名称】

逐个服务的打包命令:

1. spark-knowledge 镜像打包
# 打包后tar包名:spark-knowledge_20251203.tar(日期自动取当天)
docker save -o ./spark-knowledge_$(date +%Y%m%d).tar artifacts.iflytek.com/znfw-docker-repo/znzt2024qyzskv10cpg hxm/ckb/spark-knowledge:V1.0_1111
2. spark-ai-search 镜像打包
docker save -o ./spark-ai-search_$(date +%Y%m%d).tar artifacts.iflytek.com/znfw-docker-repo/znzt2024qyzskv10cpg hxm/ckb/spark-ai-search:V1.0_1014
3. spark-user 镜像打包
docker save -o ./spark-user_$(date +%Y%m%d).tar artifacts.iflytek.com/znfw-docker-repo/znzt2024qyzskv10cpg hxm/ckb/spark-user:V1.0_1013
4. spark-ai-collect 镜像打包
docker save -o ./spark-ai-collect_$(date +%Y%m%d).tar artifacts.iflytek.com/znfw-docker-repo/znzt2024qyzskv10cpg hxm/ckb/spark-ai-collect:V1.0_1036
5. spark-elasticsearch 镜像打包
docker save -o ./spark-elasticsearch_$(date +%Y%m%d).tar artifacts.iflytek.com/znfw-docker-repo/znzt2024qyzskv10cpg hxm/ckb/spark-elasticsearch:V1.0_2
6. spark-gateway 镜像打包
docker save -o ./spark-gateway_$(date +%Y%m%d).tar artifacts.iflytek.com/znfw-docker-repo/znzt2024qyzskv10cpg hxm/ckb/spark-gateway:V1.0_7

四、补充说明

  1. 为什么不能用容器名打包?
    docker save 只认「镜像名」,不认「容器名」。比如你原命令里写 spark-knowledge:backup_xxx,但 spark-knowledge 是容器名,不是镜像名,执行会报错 no such image,必须替换成表格里的完整镜像名。

  2. 打包后验证:
    执行完打包命令后,用 ls -lh 查看当前目录,能看到对应tar包(比如 spark-knowledge_20251203.tar),说明打包成功。

  3. 如果想打包容器(极少用,仅作补充):
    若非要打包容器(容器是运行实例,打包后丢失镜像的分层、历史等信息),命令是:

    # 以spark-knowledge容器为例
    docker export -o ./spark-knowledge_container_$(date +%Y%m%d).tar spark-knowledge
    

    业务场景中优先用 docker save 打包镜像,因为镜像可直接重新创建容器,而容器打包的文件仅能导入为镜像(且不完整)。

  4. 批量打包(可选,简化操作):
    若想一次性打包所有服务,可写个简单脚本:

    #!/bin/bash
    # 定义所有服务的镜像名和对应输出文件名
    declare -A images=(
      ["spark-knowledge"]="artifacts.iflytek.com/znfw-docker-repo/znzt2024qyzskv10cpg hxm/ckb/spark-knowledge:V1.0_1111"
      ["spark-ai-search"]="artifacts.iflytek.com/znfw-docker-repo/znzt2024qyzskv10cpg hxm/ckb/spark-ai-search:V1.0_1014"
      ["spark-user"]="artifacts.iflytek.com/znfw-docker-repo/znzt2024qyzskv10cpg hxm/ckb/spark-user:V1.0_1013"
      ["spark-ai-collect"]="artifacts.iflytek.com/znfw-docker-repo/znzt2024qyzskv10cpg hxm/ckb/spark-ai-collect:V1.0_1036"
      ["spark-elasticsearch"]="artifacts.iflytek.com/znfw-docker-repo/znzt2024qyzskv10cpg hxm/ckb/spark-elasticsearch:V1.0_2"
      ["spark-gateway"]="artifacts.iflytek.com/znfw-docker-repo/znzt2024qyzskv10cpg hxm/ckb/spark-gateway:V1.0_7"
    )
    
    # 循环打包
    for name in "${!images[@]}"; do
      docker save -o ./${name}_$(date +%Y%m%d).tar ${images[$name]}
      echo "✅ 已打包 ${name} 镜像:./${name}_$(date +%Y%m%d).tar"
    done
    

    保存为 backup_spark_images.sh,执行 chmod +x backup_spark_images.sh && ./backup_spark_images.sh 即可批量打包。

一、打包耗时:没有固定值,核心看2个因素

Docker镜像打包(docker save)的耗时主要取决于镜像大小 + 服务器磁盘IO/网络(如果镜像有远程层)

你可以先执行 docker images --format "{{.Repository}}:{{.Tag}} {{.Size}}" | grep spark 查看每个镜像的大小,能大致判断耗时:

# 执行这个命令看镜像大小
docker images --format "{{.Repository}}:{{.Tag}} {{.Size}}" | grep spark

二、怎么看是否在打包?3种方法确认状态

docker save 命令执行时默认没有实时输出(属于“静默执行”),但可以通过以下方式判断是否在运行:

方法1:新开终端,查进程(最直接)

登录服务器新开一个终端,执行以下命令,能看到 docker save 进程就说明还在打包:

# 查找docker save相关进程
ps -ef | grep "docker save"
# 或更精准:只看正在运行的docker save进程(排除grep自身)
ps -ef | grep "docker save" | grep -v grep

方法2:看磁盘写入(判断是否在干活)

docker save 会往本地写tar文件,可通过 duls -lh 实时看文件大小变化:

  1. 先执行 ls -lh | grep .tar 看目标tar文件的大小(刚执行命令时,文件可能是0字节或很小);
  2. 隔几秒再执行一次,如果文件大小在持续增长,说明还在打包;
  3. 若大小长时间不变,且进程也消失了,说明打包完成/失败。

示例:

# 实时监控tar包大小(替换成你的包名)
watch -n 1 "ls -lh spark-knowledge_$(date +%Y%m%d).tar"

方法3:查Docker守护进程日志(可选)

如果怀疑命令卡住,可查看Docker日志(不同系统路径略有差异):

# CentOS/RHEL系统
journalctl -fu docker.service | grep save
# Ubuntu系统
tail -f /var/log/docker.log | grep save

三、关于“命令执行完没输出”:必须等打包完成!

docker save阻塞式命令——执行后会一直运行,直到打包完成(或报错)才会返回终端提示符(比如 [root@server ~]#):

四、打包完成/失败的判断

1. 打包成功

2. 打包失败

五、补充:避免打包卡住的小技巧

  1. 先检查磁盘空间:df -h 确保当前目录所在磁盘有足够空间(至少是镜像大小的1.5倍);
  2. 打包时别做高IO操作(比如拷贝大文件、跑其他任务),避免拖慢速度;
  3. 若单个镜像打包太久,可分批打包(比如先打1个,确认耗时后再批量)。

如果等了很久(比如超过10分钟)还没完成,先通过方法1查进程是否还在,再查磁盘IO(iostat -x 1)和Docker日志,大概率是磁盘慢或镜像太大导致的,耐心等即可。

到此这篇关于docker打tar包命令使用小结的文章就介绍到这了,更多相关docker打tar包内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文