如何将多行文字 join 到一行

发表时间 2020-03-27
阅读1分钟

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

挑选出想要的列

有两种方式定位所需的镜像, 一种是按照 名字+tag,另一种是根据镜像 id

按 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 授权。
欢迎转载,惟请保留原文链接:/tech/join-multiple-lines/