-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathupload_ami.sh
executable file
·60 lines (47 loc) · 1.87 KB
/
upload_ami.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
#!/bin/bash
#
usage(){
cat << EOF
upload-ami.sh - Upload AMI raw file to AWS and convert it to AMI Image ready to use
Usage:
upload-ami.sh <local_raw_ami> <ami_name> <intermediate_s3_bucket_name>
Example
upload_ami.sh disk.raw javipolo-ilab-v023 javipolo
Important
Intermediate bucket must have custom iam policy attached
More information in
https://docs.redhat.com/es/documentation/red_hat_enterprise_linux/8/html/composing_a_customized_rhel_system_image/uploading-an-ami-image-to-aws_creating-cloud-images-with-composer
EOF
exit 1
}
if [[ $# -lt 3 ]]; then
usage
fi
LOCAL_AMI="$1"
AMI_NAME="$2"
BUCKET="$3"
RAW_AMI=ami_raw_tmp.ami
TMPFILE=$(mktemp)
set -e # Halt on error
aws s3 cp "$LOCAL_AMI" s3://$BUCKET/$RAW_AMI && \
printf '{ "Description": "my-image", "Format": "raw", "UserBucket": { "S3Bucket": "%s", "S3Key": "%s" } }' $BUCKET $RAW_AMI > $TMPFILE
echo Importing Snapshot
TASK_ID=$(aws ec2 import-snapshot --disk-container file://$TMPFILE | jq -r .ImportTaskId)
while aws ec2 describe-import-snapshot-tasks --filters Name=task-state,Values=active | jq -r '.ImportSnapshotTasks[].ImportTaskId' | grep -qx $TASK_ID; do
echo -n .; sleep 1
done; echo
SNAPSHOT_ID=$(aws ec2 describe-snapshots | jq -r '.Snapshots[] | select(.Description | contains("'${TASK_ID}'")) | .SnapshotId')
aws ec2 create-tags --resources $SNAPSHOT_ID --tags Key=Name,Value="$AMI_NAME"
echo Registering AMI
AMI_ID=$(aws ec2 register-image \
--name "$AMI_NAME" \
--description "$AMI_NAME" \
--architecture x86_64 \
--root-device-name /dev/sda1 \
--block-device-mappings "DeviceName=/dev/sda1,Ebs={SnapshotId=${SNAPSHOT_ID}}" \
--virtualization-type hvm \
| jq -r .ImageId)
aws ec2 create-tags --resources $AMI_ID --tags Key=Name,Value="$AMI_NAME"
aws s3 rm s3://$BUCKET/$RAW_AMI
rm -f "$TMPFILE"
echo "Created AMI $AMI_ID with name $AMI_NAME"