Terraform - Technological watch
What is Terraform
HashiCorp Terraform is an infrastructure as code tool that lets you define both cloud and on-prem resources in human-readable configuration files that you can version, reuse, and share. You can then use a consistent workflow to provision and manage all of your infrastructure throughout its lifecycle. Terraform can manage low-level components like compute, storage, and networking resources, as well as high-level components like DNS entries and SaaS features. (https://developer.hashicorp.com/terraform/intro)
Terraform, an open-source Infrastructure-as-Code (IaC) tool developed by HashiCorp, allows users to define easily readable configuration files that support version control, automation, and collaboration. With compatibility across major environments such as AWS, Azure, Kubernetes, Docker, and Helm through providers available on the Terraform Registry. Terraform operates agentlessly. Users declare the desired state of their environment, and Terraform efficiently installs, updates, and tears down the infrastructure accordingly.
Benefits
- Multi-Cloud Deployment: Terraform’s multi-cloud support allows organizations to avoid vendor lock-in by seamlessly deploying and managing resources across different cloud providers like AWS or Azure.
- Stateful Infrastructure: Terraform maintains a state file that keeps track of the current state of the infrastructure. This ensures that Terraform knows what resources are deployed and allows for efficient updates and deletions.
- Version Control Integration: Integration with version control systems like Git enables teams to manage infrastructure changes effectively, roll back to previous states, and collaborate seamlessly.
- Declarative Configuration: Declarative syntax in Terraform configurations means specifying the desired end state without detailing the step-by-step procedure. This reduces the risk of errors and makes configurations more human-readable.
- Automation: Terraform enables automation of infrastructure setup and teardown processes, reducing manual intervention and potential human errors. This is especially crucial in the era of continuous integration and continuous deployment (CI/CD).
- Disaster Recovery: With Terraform, recovering from infrastructure failures or disasters becomes more manageable. The ability to redeploy infrastructure quickly ensures minimal downtime and efficient disaster recovery.
Installation
You can find the instructions here: https://developer.hashicorp.com/terraform/install.
”Hello World” example
Once Terraform is installed on the machine, run the following command to initialize the project:
Then, create a main.tf
file and add this code inside:
This script creates a variable “hello” and puts “Hello world !” inside. Then, run the following command to tell to Terraform that the current state changed:
A file terraform.tfstate
is created. It represents the database of our infrastructure.
When the infrastructure will evolve, we can update our main.tf
file. Terraform will compare the terraform.tfstate
file and the main.tf
to apply the modifications.
Small example with Kubernetes
Project initialization
Note: This part requires a functioning Kubernetes/K3S cluster.
To manipulate Kubernetes, we will need to have this provider: https://registry.terraform.io/providers/hashicorp/kubernetes/latest. To install it, click on the button USE PROVIDER on the website, and copy paste the code. The current version (today is the 8th january 2024) is 2.25.1. To use it, copy paste this code in your main.tf
file ;
You can see that we added config_path
and config_context
to connect to the cluster.
Our first namespace/pod
Documentation link: https://registry.terraform.io/providers/hashicorp/kubernetes/latest/docs/resources/pod
First, let’s create our first namespace:
And we can add our pod like this:
Our first service
We can continue with our first service, like this:
Finally, to test if our nginx application is online, we can print the ports with these lines:
Then, don’t forget to run the commands:
🎉 TADA, we created our first small infrastructure using Terraform !
To go further
Providers
Terraform comes with a lot of other providers. We can find the list here : https://registry.terraform.io/browse/providers.
- The Google provider is used to configure your Google Cloud Platform infrastructure: https://registry.terraform.io/providers/hashicorp/google/latest/docs#example-usage
Redis - Technological watch
Learn what is Redis in less than 5 minutes !
Falco - Technological watch
Learn how to protect your Kubernetes cluster in less than 5 minutes !
Atomic distribution - Fedora Silverblue - Technological watch
Learn what is an Atomic distribution in less than 5 minutes !
RabbitMQ - Technological watch
Learn what is RabbitMQ in less than 5 minutes !
OpenAPI / Swagger - Technological watch
Learn what is OpenAPI / Swagger in less than 5 minutes !
Svelte - Technological watch
Learn what is Svelte in less than 5 minutes !
PicoCSS - Technological watch
Learn what is PicoCSS in less than 5 minutes !
Jenkins - Technological watch
Learn what is Jenkins in less than 5 minutes !