-
-
Save outofcoffee/8f40732aefacfded14cce8a45f6e5eb1 to your computer and use it in GitHub Desktop.
#!/usr/bin/env bash | |
# Example: | |
# ./find-ecr-image.sh foo/bar mytag | |
if [[ $# -lt 2 ]]; then | |
echo "Usage: $( basename $0 ) <repository-name> <image-tag>" | |
exit 1 | |
fi | |
IMAGE_META="$( aws ecr describe-images --repository-name=$1 --image-ids=imageTag=$2 2> /dev/null )" | |
if [[ $? == 0 ]]; then | |
IMAGE_TAGS="$( echo ${IMAGE_META} | jq '.imageDetails[0].imageTags[0]' -r )" | |
echo "$1:$2 found" | |
else | |
echo "$1:$2 not found" | |
exit 1 | |
fi |
similar, don't fail if tag not present:
aws ecr list-images --repository-name $1 --query 'imageIds[?imageTag==
'$2'].imageTag' --output text
I used the first command, update the behavior to sent null if the tag is not present:
cmd="$(aws ecr describe-images --repository-name="NAME" --image-ids=imageTag="TAG" ||:)"
if [[ ! -z "$cmd" ]]; then
XX
else
XX
fi
Thanks you @sanchojaf yours is the best answer that will work for images that may have multiple tags
However your code had some quote issues, the working one is
aws ecr list-images \
--repository-name ${REPO_NAME} \
--query "imageIds[?imageTag=='${GIT_SHA1}'].imageTag" \
--output text
The following would push only if the image with the tag does not exist.
aws ecr list-images --repository-name ${REPO_NAME} --query "imageIds[?imageTag=='${GIT_SHA1}'].imageTag" --output text | docker push ${AWSACCOUNTID}.dkr.ecr.${AWS_REGION}.amazonaws.com/${REPO_NAME}:${GIT_SHA1}
Thanks for this script!
I've expanded it to include support for public repositories, using the
-p
or--public
flag and incorporated the usage block from @jeevanshu
aws ecr-public
commands only work in us-east-1
region, therefore the correct command should be
IMAGE_META="$( aws ecr-public --region=us-east-1 describe-images --repository-name=$1 --image-ids=imageTag=$2 2> /dev/null )"
IMAGE_META="$( aws ecr batch-get-image --repository-name=$REPOSITORY --image-ids=imageTag=$IMAGE_TAG --query 'images[].imageId.imageTag' --output text )"
if [[ $IMAGE_META == $IMAGE_TAG ]]; then
echo "$IMAGE_META found skipping build"
else
echo "$REPOSITORY:$IMAGE_TAG not found, building new image"
docker build -t $REGISTRY/$REPOSITORY:$IMAGE_TAG .
docker push $REGISTRY/$REPOSITORY:$IMAGE_TAG
fi
This way is working for me, thanks for the help
@jeremiahlukus, thanks this does work for me 👍
Thanks, AWS CLI goes out of it's way to make things less obvious -
👆 👆 👆
IMAGE_META="$( aws ecr batch-get-image --repository-name=$REPOSITORY --image-ids=imageTag=$IMAGE_TAG --query 'images[].imageId.imageTag' --output text )" if [[ $IMAGE_META == $IMAGE_TAG ]]; then echo "$IMAGE_META found skipping build" else echo "$REPOSITORY:$IMAGE_TAG not found, building new image" docker build -t $REGISTRY/$REPOSITORY:$IMAGE_TAG . docker push $REGISTRY/$REPOSITORY:$IMAGE_TAG fi
This way is working for me, thanks for the help
@jeremiahlukus thanks a lot! It works really well!
The following command worked out a bit better for me as it won't fail if tag not present, but will fail if repo not found or on aws cli error: