如何将多行文字 join 到一行

发表时间

docker 镜像保存为离线文件时,多个镜像保存在同一个 tar 中会减少体积,那么如何将多个镜像名称方便的合并在一行内?本文介绍一种方法。

目录

目标

比如,我们有N个镜像,使用 docker images 查看如下:

$ docker images

REPOSITORY                TAG                 IMAGE ID            CREATED             SIZE
committ                   latest              b6fa739cedf5        19 hours ago        1.089 GB
java                      8                   30557a29d5ab        20 hours ago        1.089 GB
postgres                  9                   746b819f315e        4 days ago          213.4 MB
postgres                  9.3                 ce4c5a5c43d6        4 days ago          213.4 MB
postgres                  9.3.5               a073d45ec971        4 days ago          213.4 MB
postgres                  latest              12d51ffa2b22        4 days ago          213.4 MB

我们希望将所有 postgres 的镜像挑出来保存到一个 tar 中,下面看具体做法

挑选出想要的行

首先挑出符合条件的,使用 grep

得到下面的结果

$ docker images | grep postgres

postgres                  9                   746b819f315e        4 days ago          213.4 MB
postgres                  9.3                 ce4c5a5c43d6        4 days ago          213.4 MB
postgres                  9.3.5               a073d45ec971        4 days ago          213.4 MB
postgres                  latest              12d51ffa2b22        4 days ago          213.4 MB

挑选出想要的列

按 name:tag 格式

使用 awk 命令按列过滤并组合,得到新结果:

$ docker images | grep postgres | awk '{print $1":"$2}'

postgres:9
postgres:9.3
postgres:9.3.5
postgres:latest
按镜像 id

或者只拿 id

$ docker images | grep postgres | awk '{print $3}'

746b819f315e
ce4c5a5c43d6
a073d45ec971
12d51ffa2b22

拼接

paste 命令用来合并多行:

$ docker images | grep postgres | awk '{print $1":"$2}' | paste -s -d" "

postgres:9 postgres:9.3 postgres:9.3.5 postgres:latest

-d 后面紧跟的空格表示使用空格作为分隔符。

完整命令

上一步 的结果传递给 docker save 就可以了,这正是 docker save 子命令所需要的格式。

$ docker images | grep postgres | awk '{print $1":"$2}' | paste -s -d" " | xargs docker save -o savedimages.tar

相关文章
除非特别说明,本站文章均系原创,并采用 署名协议 CC-BY 授权。
欢迎转载,惟请保留原文链接:https://lfhacks.com/tech/join-multiple-lines