Top Related Projects
Production-Grade Container Scheduling and Management
Terraform Helm provider
The Cloud Native Control Plane
Declarative Continuous Deployment for Kubernetes
Open and extensible continuous delivery solution for Kubernetes. Powered by GitOps Toolkit.
Quick Overview
The Terraform Provider for Kubernetes is an official HashiCorp-maintained provider that allows Terraform to manage resources in Kubernetes clusters. It enables users to define and manage Kubernetes resources using Terraform's declarative language, providing a consistent workflow for infrastructure management across multiple platforms.
Pros
- Seamless integration with Terraform's ecosystem and workflow
- Supports a wide range of Kubernetes resources and features
- Regularly updated to keep pace with Kubernetes API changes
- Allows for version-controlled, reproducible Kubernetes deployments
Cons
- Learning curve for users new to Terraform or Kubernetes
- May not support all cutting-edge Kubernetes features immediately
- Complex Kubernetes configurations can lead to verbose Terraform code
- Performance can be slower compared to native Kubernetes tools for large-scale deployments
Code Examples
- Creating a Kubernetes Namespace
resource "kubernetes_namespace" "example" {
metadata {
name = "my-namespace"
}
}
- Deploying a simple Kubernetes Deployment
resource "kubernetes_deployment" "example" {
metadata {
name = "nginx-deployment"
labels = {
app = "nginx"
}
}
spec {
replicas = 3
selector {
match_labels = {
app = "nginx"
}
}
template {
metadata {
labels = {
app = "nginx"
}
}
spec {
container {
image = "nginx:1.21.6"
name = "nginx"
port {
container_port = 80
}
}
}
}
}
}
- Creating a Kubernetes Service
resource "kubernetes_service" "example" {
metadata {
name = "nginx-service"
}
spec {
selector = {
app = kubernetes_deployment.example.metadata[0].labels.app
}
port {
port = 80
target_port = 80
}
type = "LoadBalancer"
}
}
Getting Started
- Install Terraform and configure your Kubernetes cluster.
- Add the Kubernetes provider to your Terraform configuration:
terraform {
required_providers {
kubernetes = {
source = "hashicorp/kubernetes"
version = "~> 2.11.0"
}
}
}
provider "kubernetes" {
config_path = "~/.kube/config"
config_context = "my-context"
}
- Define your Kubernetes resources using Terraform HCL.
- Run
terraform init
to initialize the provider. - Use
terraform plan
andterraform apply
to manage your Kubernetes resources.
Competitor Comparisons
Production-Grade Container Scheduling and Management
Pros of kubernetes
- Core Kubernetes project with full functionality and features
- Direct control over Kubernetes clusters and resources
- Extensive community support and regular updates
Cons of kubernetes
- Steeper learning curve for managing infrastructure
- Requires more manual configuration and management
- Less integration with other infrastructure-as-code tools
Code Comparison
terraform-provider-kubernetes:
resource "kubernetes_deployment" "example" {
metadata {
name = "example-deployment"
}
spec {
replicas = 3
selector {
match_labels = {
app = "example"
}
}
template {
metadata {
labels = {
app = "example"
}
}
spec {
container {
image = "nginx:1.7.8"
name = "example"
}
}
}
}
}
kubernetes:
apiVersion: apps/v1
kind: Deployment
metadata:
name: example-deployment
spec:
replicas: 3
selector:
matchLabels:
app: example
template:
metadata:
labels:
app: example
spec:
containers:
- name: example
image: nginx:1.7.8
The terraform-provider-kubernetes allows for managing Kubernetes resources using Terraform's HCL syntax, while kubernetes uses YAML manifests for resource definitions. The provider offers integration with Terraform's state management and other infrastructure resources, whereas kubernetes provides direct control over cluster resources using kubectl or API calls.
Terraform Helm provider
Pros of terraform-provider-helm
- Simplifies deployment of Helm charts through Terraform
- Allows version control and management of Helm releases
- Integrates well with existing Helm workflows and repositories
Cons of terraform-provider-helm
- Limited to Helm-specific resources, less flexible for raw Kubernetes objects
- May require additional setup and configuration compared to direct Kubernetes management
- Potential overhead when dealing with simple Kubernetes resources
Code Comparison
terraform-provider-helm:
resource "helm_release" "example" {
name = "my-redis-release"
repository = "https://charts.bitnami.com/bitnami"
chart = "redis"
version = "12.7.4"
}
terraform-provider-kubernetes:
resource "kubernetes_deployment" "example" {
metadata {
name = "redis-deployment"
}
spec {
replicas = 1
selector {
match_labels = {
app = "redis"
}
}
template {
metadata {
labels = {
app = "redis"
}
}
spec {
container {
image = "redis:6.0.5"
name = "redis"
}
}
}
}
}
The terraform-provider-helm example demonstrates deploying a Redis instance using a Helm chart, while the terraform-provider-kubernetes example shows creating a Redis deployment directly using Kubernetes resources. The Helm provider offers a more concise approach for complex applications, while the Kubernetes provider provides granular control over individual resources.
The Cloud Native Control Plane
Pros of Crossplane
- Provides a unified API for managing multiple cloud providers and services
- Supports GitOps-friendly, declarative infrastructure management
- Enables creation of custom resources and controllers for specific use cases
Cons of Crossplane
- Steeper learning curve due to its more complex architecture
- Less mature ecosystem compared to Terraform's extensive provider library
- May require more setup and configuration for simple use cases
Code Comparison
Terraform-provider-kubernetes:
resource "kubernetes_deployment" "example" {
metadata {
name = "example-deployment"
}
spec {
replicas = 3
selector {
match_labels = {
app = "example"
}
}
}
}
Crossplane:
apiVersion: apps/v1
kind: Deployment
metadata:
name: example-deployment
spec:
replicas: 3
selector:
matchLabels:
app: example
Both repositories aim to manage Kubernetes resources, but Crossplane offers a more cloud-native approach with its custom resource definitions and controllers. Terraform-provider-kubernetes is more straightforward for users familiar with Terraform, while Crossplane provides greater flexibility for complex, multi-cloud environments. The code examples show that Crossplane uses native Kubernetes YAML, while Terraform-provider-kubernetes uses HCL syntax within the Terraform ecosystem.
Declarative Continuous Deployment for Kubernetes
Pros of Argo CD
- Provides a declarative, GitOps-based approach to continuous delivery
- Offers a user-friendly web UI for visualizing and managing deployments
- Supports multi-cluster deployments and application synchronization
Cons of Argo CD
- Steeper learning curve for users not familiar with GitOps principles
- Limited infrastructure provisioning capabilities compared to Terraform
- May require additional tools for complete infrastructure management
Code Comparison
Argo CD Application manifest:
apiVersion: argoproj.io/v1alpha1
kind: Application
metadata:
name: myapp
spec:
destination:
namespace: default
server: https://kubernetes.default.svc
project: default
source:
path: k8s
repoURL: https://github.com/example/myapp.git
targetRevision: HEAD
Terraform Kubernetes Provider configuration:
provider "kubernetes" {
config_path = "~/.kube/config"
}
resource "kubernetes_deployment" "example" {
metadata {
name = "example-deployment"
}
spec {
replicas = 3
# ... additional configuration
}
}
The Argo CD approach focuses on declarative application definitions and GitOps workflows, while the Terraform Kubernetes Provider offers more granular control over Kubernetes resources within the broader Terraform ecosystem. Argo CD excels in continuous delivery and multi-cluster management, whereas Terraform provides comprehensive infrastructure provisioning capabilities beyond just Kubernetes.
Open and extensible continuous delivery solution for Kubernetes. Powered by GitOps Toolkit.
Pros of flux2
- Native GitOps approach for continuous delivery
- Supports multi-tenancy and cluster management
- Built-in support for Helm charts and Kustomize
Cons of flux2
- Steeper learning curve for those familiar with Terraform
- Less flexibility in managing non-Kubernetes resources
- May require additional tools for complete infrastructure management
Code Comparison
terraform-provider-kubernetes:
resource "kubernetes_deployment" "example" {
metadata {
name = "example-deployment"
}
spec {
replicas = 3
selector {
match_labels = {
app = "example"
}
}
template {
metadata {
labels = {
app = "example"
}
}
spec {
container {
image = "nginx:1.7.8"
name = "example"
}
}
}
}
}
flux2:
apiVersion: apps/v1
kind: Deployment
metadata:
name: example-deployment
spec:
replicas: 3
selector:
matchLabels:
app: example
template:
metadata:
labels:
app: example
spec:
containers:
- name: example
image: nginx:1.7.8
The terraform-provider-kubernetes uses HCL syntax and is integrated with Terraform's state management, while flux2 uses native Kubernetes YAML manifests and relies on Git for state management and versioning.
Convert designs to code with AI
Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.
Try Visual CopilotREADME
Kubernetes Provider for Terraform
- Getting Started
- Interactive Tutorial
- Usage
- Mailing list: Google Groups
- Chat: #terraform-providers in Kubernetes (Sign up here)
The Kubernetes provider for Terraform is a plugin that enables full lifecycle management of Kubernetes resources. This provider is maintained internally by HashiCorp.
Please note: We take Terraform's security and our users' trust very seriously. If you believe you have found a security issue in the Terraform Kubernetes Provider, please responsibly disclose by contacting us at security@hashicorp.com.
Requirements
Contributing to the provider
The Kubernetes Provider for Terraform is the work of many contributors. We appreciate your help!
To contribute, please read the contribution guidelines. You may also report an issue. Once you've filed an issue, it will follow the issue lifecycle.
Also available are some answers to Frequently Asked Questions.
Top Related Projects
Production-Grade Container Scheduling and Management
Terraform Helm provider
The Cloud Native Control Plane
Declarative Continuous Deployment for Kubernetes
Open and extensible continuous delivery solution for Kubernetes. Powered by GitOps Toolkit.
Convert designs to code with AI
Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.
Try Visual Copilot