Skip to main content

2 posts tagged with "k3s"

k3s is a lightweight version of k8s (kubernetes) that is also used for container orchestration but uses fewer resources.

View All Tags

K3s Branch Sandboxing: Automating EC2 Infrastructure with GitHub Actions, Terraform, Helm & Cloudflare

· 17 min read
Kyrylo Doropii
DevOps Engineer of AdminForth

“Branch-based sandboxing” is a revolutionary approach to development that allows teams to create isolated environments—as close as possible to production—for each feature branch. This ensures that code changes are tested under realistic conditions before being merged into the main branch, which helps avoid issues like “it works on my machine” and ensures deployment stability. The implementation described in this post covers the automatic creation of an isolated development/testing environment using the resources of an existing EC2 instance, as well as the scaling of those resources in the event of a shortage.

This guide covers:

  • Automated EC2 infrastructure provisioning using Terraform
  • K3s cluster installation and setup on EC2
  • Cloudflare DNS management for custom domains
  • GitHub Actions workflows for automated deployments and cleanup
  • Monitoring and management practices

IaC Simplified: K3s on EC2 Deployments with Terraform, Helm, Ansible & Amazon ECR

· 14 min read
Kyrylo Doropii
DevOps Engineer of AdminForth

This guide shows how to deploy own Docker apps (with AdminForth as example) to Amazon EC2 instance with K3s and Terraform involving pushing images into Amazon ECR.

Needed resources:

  • AWS account where we will auto-spawn EC2 instance. We will use t3a.small instance (2 vCPUs, 2GB RAM) which costs ~14$ per month in us-west-2 region (cheapest region). Also it will take $2 per month for EBS gp2 storage (20GB) for EC2 instance.
  • Also AWS ECR will charge for $0.09 per GB of data egress traffic (from EC2 to the internet) - this needed to load docker build cache.

The setup shape:

  • Build is done using IaaC approach with HashiCorp Terraform, so almoast no manual actions are needed from you. Every resource including EC2 server instance is described in code which is commited to repo.
  • Docker images and build cache are stored on Amazon ECR
  • Total build time for average commit to AdminForth app (with Vite rebuilds) is around 3 minutes.