我已经在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
的输出将传输到本地计算机,在此由grep
和awk
过滤,然后在本地计算机上执行docker rmi
。有必要添加引号来通知Shell命令行上的所有内容都是ssh参数:
ssh root@${host} "docker images | grep localhost | awk '{print $3}' | xargs docker rmi -f"