我已经在5个不同的CentOS节点(例如,node1,node2,...,node5)上使用Rancher安装了Kubernetes集群。对于CI运行,我们需要在每次运行之前清理陈旧的docker镜像。我创建了一个在node1上运行的脚本,并启用了从node1到其余节点的无密码ssh。脚本的相关部分如下所示:

#!/bin/bash
helm ls --short --all | xargs -L1 helm delete --purge

echo "Deleting old data and docker images from Rancher host node."
rm -rf /var/lib/hadoop/* /opt/ci/*
docker images | grep localhost | awk '{print $3}' | xargs docker rmi -f

hosts=(node2 node3 node4 node5)
for host in ${hosts[*]}
do
  echo "Deleting old data and docker images from ${host}"
  ssh root@${host} docker images | grep localhost | awk '{print $3}' | xargs docker rmi -f
  ssh root@${host} rm -rf /var/lib/hadoop/* /opt/ci/*
done
echo "All deletions are complete! Proceeding with installation."

sleep 2m

问题是,虽然for循环内的docker rmi命令在所有其他4个节点上运行,但对于每个图像我都收到错误Error: No such image: <image-id>。但是,如果我在该节点上执行相同的命令,它将成功。我不确定这里是什么问题。任何帮助表示赞赏。

最佳答案

问题是ssh管道中唯一的第一个命令是远程执行的:

ssh root@${host} docker images | grep localhost | awk '{print $3}' | xargs docker rmi -f

壳牌明白这是
ssh ssh-arguments | grep grep-arguments | awk awk-arguments | xarg xarg-arguments

结果是唯一的docker images是远程执行的。然后,远程docker images的输出将传输到本地计算机,在此由grepawk过滤,然后在本地计算机上执行docker rmi

有必要添加引号来通知Shell命令行上的所有内容都是ssh参数:
ssh root@${host} "docker images | grep localhost | awk '{print $3}' | xargs docker rmi -f"

09-10 03:08
查看更多