Skip to content
/ ops-template Public template

Modern production-ready kubernetes infrastructure template

Notifications You must be signed in to change notification settings

LeChatErrant/ops-template

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Ops-template

What is it ?

The purpose of this template is to provide a complete production-ready kubernetes infrastructure, focused on automation, scalability, and monitoring

It emphasizes on reproducibility by describing all the infrastructure as code, avoiding any manual intervention and reducing human errors

 

ops-template is fully integrated with

Don't hesitate to share your improvements or to give feedback on Discord (LeChatErrant#6074) 😉

 

Table of contents

 

Technologies

Infrastructure

Tools

  • Helm : Kubernetes objects templating
  • Kustomize : K8S application customization
  • Ansible : Setup automation
  • Lens : K8S visualization

Deployment

Monitoring

and soon alerting !

Monitoring (alternative)

...and more

 

Getting started

Digital Ocean

Digital Ocean is used as cloud provider. Of course, you can use any other one, such as GCP, Scaleway, AWS, or even your own infrastructure.

  1. Connect to Digital Ocean
  2. Create a Personal Access Token with read and write scopes (https://www.digitalocean.com/docs/apis-clis/api/create-personal-access-token/)

 

Terraform Cloud

Terraform is a tool enabling you to describe your infrastructure as code in the form of HashiCorp Configuration Language, or HCL (*.tf files)

With it, you don't need to do manual actions on a cloud provider dashboard, reducing human errors and making your infrastructure reproductible

Terraform cloud will hold your terraform state in the cloud, allowing multiple developers to work on it at the same time and using your repository as the unique source of truth for the infrastructure

  • Developers can still terraform plan when they are working, to see their change against the current infra
  • When merging on master, terraform cloud will calculate your new plan. Simple apply it in the UI when you want to update the infrastructure
  1. Connect to Terraform Cloud

  2. Once connected, create a workspace pointing to your ops git repository

Terraform workspace
Workspace creation on Terraform Cloud

   

  1. Add terraform variables to your workspace (including your Digital Ocean access token)
Terraform variables
Variables configuration on Terraform Cloud

   

  1. Add your organization and your workspace into the infra/terraform/cloud.tf to use terraform cloud as remote backend

  2. Start a new plan on terraform cloud UI

  3. Apply it and take a coffee

Congratulation, you just deployed a whole infrastructure on Digital Ocean, including

  • Digital ocean root project
  • K8S autoscaled cluster
  • Load balancer pointing on K8S nodes
  • DNS
  • DNS records pointing on the load balancer for subdomains :
    • traefik.example.com
    • argocd.example.com
    • kibana.example.com
    • studio.example.com
    • api.example.com

 

ArgoCD

We will use ArgoCD to synchronize the cluster state with our repository and to manage our K8S apps

The only thing we deploy by hand is argoCD, which will then deploy every apps present in the repository

Coming soon, work still in progress

Soon, the only thing to deploy on the cluster will be ArgoCD, which will manage all the other apps and deploy them directly from the repository

 

Documentation

Coming soon

 

How to contribute

  1. Fork it (https://github.com/LeChatErrant/ops-template/fork)
  2. Create your feature branch (git checkout -b my-new-feature)
  3. Commit your changes (git commit -am 'Add some feature')
  4. Push to the branch (git push origin my-new-feature)
  5. Create a new Pull Request

Issues and comments welcomed ! 😉

Contributors

GitHub Logo   LeChatErrant - creator and maintainer