Skip to content

alaninchika/aws-ec2

Repository files navigation

AWS EC2 Microservice

Build Status codecov

AWS Elastic Compute Cloud microservice deployed to AWS Lambda and API Gateway.

Pipeline

The pipeline is a full CI/CD serverless pipeline for building and deploying lambda function and api. In this application we are using CloudFormation to create the pipeline, all resources, and any permissions needed.

The following resources are created:

  • An S3 bucket to store deployment artifacts.
  • An AWS CodeBuild stage to build any changes checked into the repo.
  • The AWS CodePipeline that will watch for changes on your repo, and push these changes through to build and deployment steps.
  • All IAM roles and policies required.

The CloudFormation templates being used to create these resources can be found in pipeline directory.

To create the pipeline stack, click the launch stack button below.

API

The Serverless API we are building! The api section contains five files.

  1. beta.json: The CloudFormation staging file. This will be used by CloudFormation to pass parameters to our CloudFormation template.
  2. buildspec.yml: This is used by CodeBuild in the build step of our pipeline. We will get to that later.
  3. index.js: The Lambda function code!
  4. package.json: The package.json that defines what packages we need for our Lambda function.
  5. template.yaml: This is the template file that will be used to create our API gateway resource, Lambda function and hook them up together

Usage

The service requires the following GET query strings:

  • action - The required action
  • reference - The instance id

Request:

GET /ec2?action=start&reference=i-02fb9d486c6d282df HTTP/1.1
Content-Type: application/x-www-form-urlencoded
GET /ec2?action=stop&reference=i-02fb9d486c6d282df HTTP/1.1
Content-Type: application/x-www-form-urlencoded
GET /ec2?action=status&reference=i-02fb9d486c6d282df HTTP/1.1
Content-Type: application/x-www-form-urlencoded

Response:

HTTP/1.1 200 OK

{
  "id": "i-02fb9d486c6d282df",
  "CurrentState": "stopping",
  "PreviousState": "running",
}

{
  "CurrentState": "stopped",
}