Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

Used tools

  • AWS and Kubernetes services

  • Docker

  • Terraform

Deployment process

The backend server is an application running on JVM written in Kotlin a built by Gradle.

The server uses the PostgreSQL as a data storage.

We deploy a new version of the Loono Backend on commit in this way:

  1. Docker image creation with Dockerfile

    1. Building the application by Gradle build to create a bootable JAR file

    2. Creation a final docker image with the application JAR

  2. Upload the Docker image to the Docker repository (ECR)

  3. Deployment of the new server version to the AWS

    1. Startup of the new version

    2. If the startup succeeds then the new version replaces the old one

Pod parameters

Hardware configuration:

  • Memory: 512 (0.5 GB)

  • CPU: 256 (.25 vCPU)

Application configuration:

  • Instances: 1

DB configuration:

  • Allocated space: 20 GB

  • Maximum space: 100 GB

  • Type and engine: PostgreSQL 12.5

  • Backup retention period: 7 days

Testing and CI/CD

There is several testing levels to cover the quality.

  1. The build - we cover main functionality by unit tests (code coverage is available by jacoco plugin in the project)

    1. We have the CI pipeline in the Github Actions executing the project build on each commit.

    2. The tests are part of docker image building, too.

  2. The deployment

    1. The deployment succeeds if the health check passed 3-times.

    2. We have post-deploy tests which validate health check and the API documentation after the deployment itself.