#!/usr/bin/env bash # This script shows how to build the Docker image and push it to ECR to be ready for use # by SageMaker. # The argument to this script is the image name. This will be used as the image on the local # machine and combined with the account and region to form the repository name for ECR. # set region region=$(aws configure get region) distro= if [ "$#" -eq 1 ]; then distro=$1 else echo "usage: $0 " exit 1 fi DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )" source $DIR/set_env.sh $distro image=$IMAGE_NAME tag=$IMAGE_TAG # Get the account number associated with the current IAM credentials account=$(aws sts get-caller-identity --query Account --output text) if [ $? -ne 0 ] then exit 255 fi fullname="${account}.dkr.ecr.${region}.amazonaws.com/${image}:${tag}" # If the repository doesn't exist in ECR, create it. aws ecr describe-repositories --region ${region} --repository-names "${image}" > /dev/null 2>&1 if [ $? -ne 0 ]; then aws ecr create-repository --region ${region} --repository-name "${image}" > /dev/null fi # Build the docker image locally with the image name and then push it to ECR # with the full name. # Get the login command from ECR and execute it directly aws ecr get-login-password --region us-west-2 \ | docker login --username AWS --password-stdin 763104351884.dkr.ecr.us-west-2.amazonaws.com docker build -t ${image} -f Dockerfile-$distro $DIR/.. docker tag ${image} ${fullname} # Get the login command from ECR and execute it directly aws ecr get-login-password --region ${region} \ | docker login --username AWS --password-stdin ${account}.dkr.ecr.${region}.amazonaws.com docker push ${fullname} if [ $? -eq 0 ]; then # write ECR URI to .ecr_uri file so it can be read later to configure Helm charts echo "${fullname}" > $DIR/../../.ecr_uri else echo "Error: Image build and push failed" exit 1 fi