Use ansible instead of awscli

Not all parts of the script has been switched from awscli to ansible yet,
because the ansible aws modules do not support importing s3 object as snapshots.
(https://github.com/ansible/ansible/issues/53453)
Workaround using the image_location parameter of the ec2_ami ansible module
would mean adding extra code for generating AMI manifest with pre-signed
URLs.
This commit is contained in:
Jan Stodola 2019-05-10 17:06:48 +02:00 committed by Alexander Todorov
parent f24877b06e
commit ed8a21a627
3 changed files with 78 additions and 41 deletions

View File

@ -0,0 +1,32 @@
- hosts: localhost
tasks:
- name: Import SSH key pair
ec2_key:
name: "{{ key_name }}"
key_material: "{{ lookup('file', ssh_key_dir + '/id_rsa.pub') }}"
- name: Create instance
ec2_instance:
name: "{{ ami_id }}"
image_id: "{{ ami_id }}"
key_name: "{{ key_name }}"
instance_type: t2.small
security_group: allow-ssh
instance_initiated_shutdown_behavior: terminate
state: present
register: ec2
- name: Wait for SSH to come up
wait_for:
host: "{{ item.public_ip_address }}"
port: 22
state: started
with_items: "{{ ec2.instances }}"
- name: Save instance ID
local_action: copy content={{ item.instance_id }} dest={{ tmp_dir }}/instance_id
with_items: "{{ ec2.instances }}"
- name: Save public IP
local_action: copy content={{ item.public_ip_address }} dest={{ tmp_dir }}/public_ip
with_items: "{{ ec2.instances }}"

View File

@ -0,0 +1,14 @@
- hosts: localhost
tasks:
- name: Make sure bucket exists
aws_s3:
bucket: "{{ aws_bucket }}"
mode: create
- name: Make sure vmimport role exists
iam_role_facts:
name: vmimport
register: role_facts
- fail:
msg: "Role vmimport doesn't exist"
when: role_facts.iam_roles | length < 1

View File

@ -33,12 +33,14 @@ rlJournalStart
rlLogInfo "AWS_BUCKET=$AWS_BUCKET" rlLogInfo "AWS_BUCKET=$AWS_BUCKET"
rlLogInfo "AWS_REGION=$AWS_REGION" rlLogInfo "AWS_REGION=$AWS_REGION"
if ! rlCheckRpm "python3-pip"; then for package in python3-pip python3-boto3; do
rlRun -t -c "dnf -y install python3-pip" if ! rlCheckRpm "$package"; then
rlAssertRpm python3-pip rlRun -t -c "dnf -y install $package"
rlAssertRpm "$package"
fi fi
done
rlRun -t -c "pip3 install awscli" rlRun -t -c "pip3 install awscli ansible[aws]"
# aws configure # aws configure
[ -d ~/.aws/ ] || mkdir ~/.aws/ [ -d ~/.aws/ ] || mkdir ~/.aws/
@ -64,11 +66,11 @@ aws_secret_access_key = $AWS_SECRET_ACCESS_KEY
__EOF__ __EOF__
fi fi
# make sure bucket exists TMP_DIR=$(mktemp -d)
rlRun -t -c "aws s3 mb s3://$AWS_BUCKET" PLAYBOOKS_DIR=$(dirname "$0")/playbooks/aws
# make sure vmimport role exists # make sure bucket and vmimport role exist
rlRun -t -c "aws iam get-role --role-name vmimport" rlRun -t -c "ansible-playbook --extra-vars 'aws_bucket=$AWS_BUCKET' $PLAYBOOKS_DIR/setup.yml"
rlPhaseEnd rlPhaseEnd
rlPhaseStartTest "compose start" rlPhaseStartTest "compose start"
@ -96,7 +98,11 @@ __EOF__
AMI="$UUID-disk.ami" AMI="$UUID-disk.ami"
# upload to S3 # upload to S3
rlRun -t -c "aws s3 cp $AMI s3://$AWS_BUCKET" rlRun -t -c "ansible localhost -m aws_s3 -a \
'bucket=$AWS_BUCKET \
src=$AMI \
object=$AMI \
mode=put'"
# import image as snapshot into EC2 # import image as snapshot into EC2
cat > containers.json << __EOF__ cat > containers.json << __EOF__
@ -145,37 +151,23 @@ __EOF__
rlPhaseEnd rlPhaseEnd
rlPhaseStartTest "Start EC2 instance" rlPhaseStartTest "Start EC2 instance"
# generate new ssh key and import it into EC2 # generate new ssh key
KEY_NAME=composer-$UUID KEY_NAME=composer-$UUID
SSH_KEY_DIR=`mktemp -d /tmp/composer-ssh-keys.XXXXXX` SSH_KEY_DIR=`mktemp -d /tmp/composer-ssh-keys.XXXXXX`
rlRun -t -c "ssh-keygen -t rsa -N '' -f $SSH_KEY_DIR/id_rsa" rlRun -t -c "ssh-keygen -t rsa -N '' -f $SSH_KEY_DIR/id_rsa"
rlRun -t -c "aws ec2 import-key-pair --key-name $KEY_NAME --public-key-material file://$SSH_KEY_DIR/id_rsa.pub"
# start a new instance with selected ssh key, enable ssh rlRun -t -c "ansible-playbook --extra-vars \
INSTANCE_ID=`aws ec2 run-instances --image-id $AMI_ID --instance-type t2.small --key-name $KEY_NAME \ 'key_name=$KEY_NAME \
--security-groups allow-ssh --instance-initiated-shutdown-behavior terminate --enable-api-termination \ ssh_key_dir=$SSH_KEY_DIR \
--count 1| grep InstanceId | cut -f4 -d'"'` ami_id=$AMI_ID \
key_name=$KEY_NAME \
tmp_dir=$TMP_DIR' \
$PLAYBOOKS_DIR/instance.yml"
if [ -z "$INSTANCE_ID" ]; then INSTANCE_ID=$(cat $TMP_DIR/instance_id)
rlFail "INSTANCE_ID is empty!" IP_ADDRESS=$(cat $TMP_DIR/public_ip)
else
rlLogInfo "INSTANCE_ID=$INSTANCE_ID"
fi
# wait for instance to become running and had assigned a public IP rlLogInfo "Running INSTANCE_ID=$INSTANCE_ID with IP_ADDRESS=$IP_ADDRESS"
IP_ADDRESS=""
while [ -z "$IP_ADDRESS" ]; do
rlLogInfo "IP_ADDRESS is not assigned yet ..."
sleep 10
IP_ADDRESS=`aws ec2 describe-instances --instance-ids $INSTANCE_ID --filters=Name=instance-state-name,Values=running | grep PublicIpAddress | cut -f4 -d'"'`
done
rlLogInfo "Running instance IP_ADDRESS=$IP_ADDRESS"
until aws ec2 describe-instance-status --instance-ids $INSTANCE_ID --filter Name=instance-status.status,Values=ok | grep ok; do
rlLogInfo "Waiting for instance to initialize ..."
sleep 60
done
rlPhaseEnd rlPhaseEnd
rlPhaseStartTest "Verify EC2 instance" rlPhaseStartTest "Verify EC2 instance"
@ -191,13 +183,12 @@ __EOF__
rlPhaseEnd rlPhaseEnd
rlPhaseStartCleanup rlPhaseStartCleanup
rlRun -t -c "aws ec2 terminate-instances --instance-ids $INSTANCE_ID" rlRun -t -c "ansible localhost -m ec2_instance -a 'state=terminated instance_ids=$INSTANCE_ID'"
rlRun -t -c "aws ec2 delete-key-pair --key-name $KEY_NAME" rlRun -t -c "ansible localhost -m ec2_key -a 'state=absent name=$KEY_NAME'"
rlRun -t -c "aws ec2 deregister-image --image-id $AMI_ID" rlRun -t -c "ansible localhost -m ec2_ami -a 'state=absent image_id=$AMI_ID delete_snapshot=True'"
rlRun -t -c "aws ec2 delete-snapshot --snapshot-id $SNAPSHOT_ID" rlRun -t -c "ansible localhost -m aws_s3 -a 'mode=delobj bucket=$AWS_BUCKET object=$AMI'"
rlRun -t -c "aws s3 rm s3://$AWS_BUCKET/$AMI"
rlRun -t -c "$CLI compose delete $UUID" rlRun -t -c "$CLI compose delete $UUID"
rlRun -t -c "rm -rf $AMI $SSH_KEY_DIR containers.json" rlRun -t -c "rm -rf $AMI $SSH_KEY_DIR containers.json $TMP_DIR"
rlPhaseEnd rlPhaseEnd
rlJournalEnd rlJournalEnd