From 61fb1349dd56b3948a79cbb14b9d77c915efecfa Mon Sep 17 00:00:00 2001 From: adamkaygray Date: Thu, 17 Oct 2019 11:16:39 +0800 Subject: [PATCH] ami id, docker ports, instance type --- awsdeploy.yml | 70 ++++++++++++++++++++++++++++++++++++++++++++++++--- 1 file changed, 67 insertions(+), 3 deletions(-) diff --git a/awsdeploy.yml b/awsdeploy.yml index 401c2fb5..1e703f49 100644 --- a/awsdeploy.yml +++ b/awsdeploy.yml @@ -24,8 +24,8 @@ Resources: App: Type: 'AWS::EC2::Instance' Properties: - InstanceType: t2.micro - ImageId: ami-0ac019f4fcb7cb7e6 + InstanceType: !Ref InstanceType + ImageId: !Ref Ubuntu16Ami KeyName: !Ref KeyName SecurityGroups: - !Ref AppSG @@ -84,7 +84,7 @@ Resources: - | sudo docker pull chakkiworks/doccano:latest - > - sudo docker run -d --name doccano --env-file /env.list -p 80:80 + sudo docker run -d --name doccano --env-file /env.list -p 80:8000 chakkiworks/doccano:latest - > sudo docker exec doccano tools/create-admin.sh ${ADMIN} ${EMAIL} @@ -92,6 +92,67 @@ Resources: Metadata: 'AWS::CloudFormation::Designer': id: 3547c02e-5393-4b26-a9af-6f00dc2cbcdb + DescribeImagesRole: + Type: AWS::IAM::Role + Properties: + AssumeRolePolicyDocument: + Version: '2012-10-17' + Statement: + - Action: sts:AssumeRole + Effect: Allow + Principal: + Service: lambda.amazonaws.com + ManagedPolicyArns: + - arn:aws:iam::aws:policy/service-role/AWSLambdaBasicExecutionRole + Policies: + - PolicyName: DescribeImages + PolicyDocument: + Version: '2012-10-17' + Statement: + - Action: ec2:DescribeImages + Effect: Allow + Resource: "*" + GetLatestAMI: + Type: AWS::Lambda::Function + Properties: + Runtime: python3.6 + Handler: index.handler + Role: !Sub ${DescribeImagesRole.Arn} + Timeout: 60 + Code: + ZipFile: | + import boto3 + import cfnresponse + import json + import traceback + + def handler(event, context): + try: + response = boto3.client('ec2').describe_images( + Owners=[event['ResourceProperties']['Owner']], + Filters=[ + {'Name': 'name', 'Values': [event['ResourceProperties']['Name']]}, + {'Name': 'architecture', 'Values': [event['ResourceProperties']['Architecture']]}, + {'Name': 'root-device-type', 'Values': ['ebs']}, + ], + ) + + amis = sorted(response['Images'], + key=lambda x: x['CreationDate'], + reverse=True) + id = amis[0]['ImageId'] + + cfnresponse.send(event, context, cfnresponse.SUCCESS, {}, id) + except: + traceback.print_last() + cfnresponse.send(event, context, cfnresponse.FAIL, {}, "ok") + Ubuntu16Ami: + Type: Custom::FindAMI + Properties: + ServiceToken: !Sub ${GetLatestAMI.Arn} + Owner: "099720109477" + Name: "ubuntu/images/hvm-ssd/ubuntu-xenial-16.04-amd64-server-20190913" + Architecture: "x86_64" Metadata: 'AWS::CloudFormation::Designer': 116a7f7b-14c5-489a-a3c8-faf276be7ab0: @@ -124,6 +185,9 @@ Parameters: - t2.micro - t2.small - t2.medium + - t3.micro + - t3.small + - t3.medium ConstraintDescription: must be a valid EC2 instance type. KeyName: Description: Name of an EC2 KeyPair to enable SSH access to the instance.