Skip to content

Latest commit

 

History

History
171 lines (142 loc) · 6.52 KB

README.md

File metadata and controls

171 lines (142 loc) · 6.52 KB

Serverless template

About the template

This template provides you with the code needed to deploy a simple NodeJS CRUD api built on top the serverless framework: https://serverless.com You will get a fully functional API that can manage information for a sample entity, storing the data on a DynamoDB table. The entity structure consist of two fields: code and name. The code should be unique since it is the primary (partition) key for the table. Sample data would look like

code name
H37J John
UM28 Matt

How to deploy your project

Pre-requisites

In order to run the project you will need to have:

Troubleshooting

  • If you installed npm as and administrator you may need to change the owner for you node packages folder.
  • You will need to use an AWS profile with enough permissions to create the resources for the project. You will get a permissions error if the profile does not have the required permissions.

Deploying the project

The serverless framework provides a wrapper around AWS CloudFormation so it will deploy a CloudFormation stack behind the scenes. In order to perform the stack deployment run: serverless deploy --aws-profile <profile> --stage <stage>

You will need to replace <profile> with your aws profile. If you are using your default profile you can use: serverless deploy --stage <stage>

You will also need to replace the <stage> with the name of the stage you are deploying to. The stage parameter can be used to isolate your resources in development, production, etc.

Real example: serverless deploy --aws-profile experiments --stage dev

For more information refer to the serverless cli documentation: https://serverless.com/framework/docs/providers/aws/cli-reference/deploy/

IMPORTANT: If you decide to deploy more than one copy of the template in the same AWS account, please ensure you rename the name of the service linked to the project. You can find the name of the service in the serverless.yml file:

service: serverless-template

ie:

service: my-custom-project-name

Deploy the static website

If you need a front end for this project you can deploy a static website by running: serverless --aws-profile <profile> client deploy

This will take the content of the ./client/dist folder and push it to an S3 bucket configured for static website hosting. You can use the tool of your choice as long as you can compile your assets into ./client/dist If you need to point to a specific folder instead, please change the configuration in the serverless.yml file to be:

custom:
  client:
    ...
    distributionFolder: path/to/files
    ...

Destroying the environment

You can destroy the environment by running: serverless remove --aws-profile <profile> --stage <stage> This will delete the stack associated to the project.

Optionally you could login to the AWS Console and navigate to the CloudFormation section and manually delete the stack associated with the project.

If you deployed the static website, you can destroy the S3 resource associated with it by running: serverless --aws-profile <profile> client remove

Components of the template

Functions

The compute functionality of the API is provided by AWS Lambda function that can be found in: ./functions They are written in JavaScript, although you can use any of the languages supported by AWS Lambda: https://docs.aws.amazon.com/lambda/latest/dg/lambda-runtimes.html

You can register new functions by adding new entries to the serverless.yml file in the functions section.

Permissions

Your functions may need some permissions in order to interact with AWS resources, lets say that you need to support SQS queues. You will need to add the permissions to the role used by the Lambda functions, that can be found in the serverless.yml file under the name iamRoleStatements. As you can see, the role already has a policy that allows the Lambda functions to interact with the DynamoDB table provided in the example.

For more information on how to create IAM roles and Policies please refer to the AWS documentation: https://docs.aws.amazon.com/IAM/latest/UserGuide/id_roles.html

API Gateway

Although is is abstracted by the serverless frameworks the service in charge of exposing your Lambda function to HTTPS endpoints is called AWS API Gateway and it is a service that makes it easy for developers to create, publish, maintain, monitor, and secure APIs at any scale. If you want to learn more about how your functions are wired behind the scenes, visit the API Gateway section of the AWS console.

Testing the sample API

You can test the sample API using CURL or you REST client of choice. Here are some examples on how to communicate with the API using CURL:

Create a new record

curl -d '{"code":"code1", "name":"name1"}' -H "Content-Type: application/json" -X POST https://<API-URL>/v1/example

Update an existing record

curl -d '{"name":"name-changed"}' -H "Content-Type: application/json" -X PUT https://<API-URL>/v1/example/{code}

Delete an existing record

curl -H "Content-Type: application/json" -X DELETE https://<API-URL>/v1/example/{code}

List existing records

curl -H "Content-Type: application/json" -X GET https://<API-URL>/v1/example

Retrieve an existing record

curl -H "Content-Type: application/json" -X GET https://<API-URL>/v1/example/{code}

Controlling your costs

Please keep in mind that although AWS provides decent capacity on it free tier for most all of the services used in this template, there are costs associated to them.

In order to ensure that you stay inside the limits of the free tier, refer to:

All in all in order to stay in the free tier you would:

  • Keep your DynamoDB table data transference under 1GB.
  • Keen your calls and messages to API Gateway under 1M (one million)
  • Keep your data stored in S3 under 5GB and perform less than 20,000 GET Requests and 2,000 PUT, COPY, POST, or LIST Requests