api

package module
v0.0.0-...-66ffae8 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Oct 29, 2021 License: Apache-2.0 Imports: 11 Imported by: 0

README ¶

API microservice

A REST API microservice orchestrated by Amazon ECS on AWS Fargate that writes and reads voting data from an Amazon Aurora PostgreSQL database.

architecture

How to create this service?

  1. Install the AWS Copilot CLI https://aws.github.io/copilot-cli/
  2. Run
    $ copilot init
    
  3. Enter "voting-app" for the name of your application.
  4. Select "Backend Service" for the service type.
  5. Enter "api" for the name of the service.
  6. Say "Y" to deploying to a "test" environment 🚀

Once deployed, your service will be accessible at http://api.voting-app.local:8080 within your VPC.

What does it do?

AWS Copilot uses AWS CloudFormation under the hood to provision your infrastructure resources. You should see two different stacks created for you:

  1. voting-app-test-api: Holds your ECS Service.
  2. voting-app-test-api-AddonsStack-<RandomString>: Holds the Aurora database.

Take a look at the resources in the stacks to see all that's generated for you.

How does it work?

Copilot stores the infrastructure-as-code for your service under the copilot/ directory.

copilot
└── api
    ├── addons
    │   └── db.template.yaml
    └── manifest.yml

The manifest.yml file under api/ holds the common configuration for a "backend service" pattern. For example, in this manifest we demo how you can set up autoscaling for your service as well as container healthchecks.

The Aurora database is defined under the api/addons/ directory which can hold any arbitrary CloudFormation template.
The "addons" features allows you to integrate with any AWS services that are not provided by default with the Copilot manifest.

You can find out in more details how Copilot works from our documentation.

Deleting the service

If you'd like to delete only the service from the "voting-app" application.

$ copilot svc delete

If you'd like to delete the entire application including other services and deployment environments:

$ copilot app delete

Documentation ¶

Overview ¶

Package api starts the api server.

Index ¶

Constants ¶

This section is empty.

Variables ¶

This section is empty.

Functions ¶

func Run ¶

func Run() error

Run starts the server.

Types ¶

This section is empty.

Directories ¶

Path Synopsis
cmd
api
Package postgres provides functionality to connect to a postgres database.
Package postgres provides functionality to connect to a postgres database.
Package server provides functionality to store and retrieve votes.
Package server provides functionality to store and retrieve votes.
Package vote provides functionality around reading and writing votes.
Package vote provides functionality around reading and writing votes.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL