如果您已经对 Terraform 了如指掌,并期望自己的 IaC 技能有进一步提升的话,这篇文章很适合您!在本文中,我们将分享一些 Terraform 的高级使用技巧。从使用模块(module)、工作区(workspace)到管理远程状态存储、自定义 provider等技巧,帮助您轻松、高效地管理基础设施。无论您管理的是小型网站还是大规模的云基础设施,这些技巧都将让您对 Terraform 的掌控力再上一层楼。

太长不看版

  • Terraform 模块是可复用的 Terraform 代码包,其中封装了一组资源并且能在多个 Terraform 配置中使用。
  • 远程状态存储允许用户在共享位置存储状态,比如 S3 bucket 或者 Terraform 云工作区,这使得协作和管理基础设施更方便。
  • Terraform 工作区允许用户管理单个 Terraform 配置的多个实例,每个实例都有其状态。
  • 自定义 provider 可以让用户管理那些不被 Terraform 原生支持的资源,比如自定义 API 或某些自研的技术。
  • 在创建资源后,Terraform provisioner 可以在上面运行脚本或者命令。对于在新创建的资源上配置软件或运行测试,Provisioner十分有用。

Tips & Tricks:Terraform 进阶技能

Terraform 是管理 IaC 的强大工具,常用常新。在这一部分我们将探索 Terraform 的进阶技能,包括 Terraform 模块、远程状态存储、Terraform 工作区以及自定义 Provider。

1、Terraform 模块

Terraform 模块是可复用的 Terraform 代码包,其中封装了一组资源并且能在多个 Terraform 配置中使用。模块可以将基础设施的复杂度抽象出来,并且代码可以重复使用,进而允许用户以模块化和可组合的方式定义基础设施。

 

要创建一个 Terraform 模块,你需要在单独的目录中定义一组资源,并该目录有自己的main.tf文件。然后,您可以在主要的 Terraform 配置中使用模块块(module block)和传递任何必要的变量来调用模块。例如,这里有一个简单的Terraform模块,定义了一个AWS EC2实例:

# modules/ec2/main.tf
resource "aws_instance" "example" {
ami = var.ami
instance_type = var.instance_type
tags = var.tags
} # main.tf
module "ec2" {
source = "./modules/ec2"
ami = "ami-1234567890"
instance_type = "t2.micro"
tags = {
Name = "example-instance"
}
}

2、远程状态存储

默认情况下, Terraform 在磁盘上将状态存储到本地,但如果在团队环境中工作或有多个 Terraform 配置时,会导致一些问题出现。远程状态存储可以让用户将状态存储在一个共享的位置,比如 S3 bucket 或者 Terraform 云工作区,这使得协作和管理基础设施更方便。

要使用远程状态存储,您需要在 Terraform 配置中配置一个后端,以下是一个简单的示例,展示如何使用 S3 Bucket 来进行远程状态存储:

terraform {
backend "s3" {
bucket = "my-bucket"
key = "terraform.tfstate"
region = "us-west-2"
}
}

3、Terraform 工作区

Terraform 工作区允许用户管理单个 Terraform 配置的多个实例,每个实例都有其状态。当您需要在同个 Terraform 代码库中管理多个环境时(如 dev、staging、生产环境),这一功能十分有用。

使用terraform workspace new命令创建一个新工作区;要在工作区之间切换,使用terraform workspace select命令。以下示例是如何使用工作空间来管理一个开发和一个生产环境:

terraform workspace new dev
terraform apply terraform workspace new prod
terraform apply

4、自定义 Provider

自定义 provider 可以让用户管理那些不被 Terraform 原生支持的资源,比如自定义 API 或某些自研的技术。尽管 Terraform 内置大量 provider,但有时还是需要使用自定义的 provide。

首先,需要写一个 provider 插件,它是一个符合 Terraform插件协议的 Go 二进制文件。完成 Provider 插件构建之后,您可以在 Terraform 配置中使用 Provider 块对它进行配置。例如,以下配置是使用一个自定义的 provider 来管理专有云平台的资源:

provider "mycloud" {
api_key = "my-api-key"
endpoint = "https://api.mycloud.com"
} resource "mycloud_instance" "example" {
name = "example-instance"
image = "ubuntu-18.04"
size = "small"
}

5、Terraform Provisioners

在创建资源后,Terraform provisioner 可以在上面运行脚本或者命令。对于在新创建的资源上配置软件或运行测试,Provisioner十分有用。

在 Terraform 中有2种类型的 provisioner:local-exec 和 remote-exec。Local-exec 在运行Terraform的机器上本地运行命令,remote-exec 在资源上运行命令。下方示例配置使用了 local-exec provisioner 来在 AWS EC2 实例上运行脚本:

resource "aws_instance" "example" {
ami = "ami-1234567890"
instance_type = "t2.micro" provisioner "local-exec" {
command = "echo 'Hello, World!' > /tmp/hello.txt"
}
}

总结

Terraform 是一款管理 IaC 的强大工具,这些进阶技能可以进一步点亮您的 Terraform 技能树。通过使用上述提到的技巧,您能够以模块化、可扩展以及高效的方式来管理您的基础设施。无论您是在管理小型网站还是大规模的云基础设施,Terraform 所具备的灵活性以及功能都能满足您的需求。

原文链接:

https://faun.pub/the-ultimate-guide-to-advanced-terraform-techniques-for-devops-b202b6845170

终极指南!Terraform的进阶技巧的更多相关文章

  1. 软件测试进阶(一)A/B测试终极指南

    A/B测试终极指南 A/B测试不是一个时髦名词.现在很多有经验的营销和设计工作者用它来获得访客行为信息,来提高转换率.然而,A/B测试与SEO不同的是,人们都不太知道如何进行网站分析和可用性分析.他们 ...

  2. const extern static 终极指南

    const extern static 终极指南 不管是从事哪种语言的开发工作,const extern static 这三个关键字的用法和原理都是我们必须明白的.本文将对此做出非常详细的讲解. co ...

  3. 每周一书《Oracle 12 c PL(SQL)程序设计终极指南》

    本周为大家送出的书是<Oracle 12 c PL(SQL)程序设计终极指南>,此书由机械工业出版社出版, 孙风栋,王澜,郭晓惠 著. 内容简介: <Oracle 12c PL/SQ ...

  4. 【转】使用JMeter进行负载测试——终极指南

    使用JMeter进行负载测试——终极指南 这篇教程讨论的是JMeter,它是一款基于Java的.集合了几个应用程序.具有特定用途的负载和性能测试工具. 本篇主要涉及的内容: 解释一下JMeter的用途 ...

  5. 15个Linux Wget下载实例终极指南

    15个Linux Wget下载实例终极指南 Linux wget是一个下载文件的工具,它用在命令行下.对于Linux用户是必不可少的工具,尤其对于网络管理员,经常要下载一些软件或从远程服务器恢复备份到 ...

  6. [产品相关] A/B测试终极指南(翻译)

    转载地址: http://blog.sina.com.cn/s/blog_9149268d0100zrx7.html 还记得以前导师说看了英文的文章就把它翻译一下吧,这样会对文章更好地理解,也会有更深 ...

  7. Docker终极指南:为什么Docker能做这么多事

    Docker终极指南:为什么Docker能做这么多事 http://www.aboutyun.com/thread-11499-1-1.html

  8. 如何编写更好的SQL查询:终极指南-第二部分

    上一篇文章中,我们学习了 SQL 查询是如何执行的以及在编写 SQL 查询语句时需要注意的地方. 下面,我进一步学习查询方法以及查询优化. 基于集合和程序的方法进行查询 反向模型中隐含的事实是,建立查 ...

  9. 如何编写更好的SQL查询:终极指南-第三部分

    本次我们学习<如何编写更好的SQL查询>系列的最后一篇文章. 时间复杂度和大O符号 通过前两篇文章,我们已经对查询计划有了一定了解.接下来,我们还可以借助计算复杂度理论,来进一步深入地挖掘 ...

  10. 《前端之路》之 JavaScript 进阶技巧之高阶函数(下)

    目录 第二章 - 03: 前端 进阶技巧之高阶函数 一.防篡改对象 1-1:Configurable 和 Writable 1-2:Enumerable 1-3:get .set 2-1:不可扩展对象 ...

随机推荐

  1. 手撕Ford-Fulkerson algorithm 学一半的笔记

    目录 定义大概就这些 伪代码 自己做slide里的quiz 搬运别人的代码 我明白了, 余量网络 名如其名 比如你f/c=3/5 那么正边2,reverse edge3,加起来是5 在这个你建的新图上 ...

  2. 从零开始学习Java系列之Java运行机制与跨平台特性

    全文大约[4000]字,不说废话,只讲可以让你学到技术.明白原理的纯干货!并带有丰富的案例及配图,让你更好地理解和运用文中的技术概念,给你带来具有足够启迪的思考-- 在上一篇文章中,壹哥给大家介绍了J ...

  3. HashMap和ConcurrentHashMap扩容过程

    HashMap 存储结构 HashMap是数组+链表+红黑树(1.8)实现的. (1)Node[] table,即哈希桶数组.Node是内部类,实现了Map.Entry接口,本质是键值对. 下图链表中 ...

  4. Go语言:编写一个 WebsiteRacer 的函数,用来对比请求两个 URL 来「比赛」,并返回先响应的 URL。如果两个 URL 在 10 秒内都未返回结果,返回一个 error。

    问题: 你被要求编写一个叫做 WebsiteRacer 的函数,用来对比请求两个 URL 来「比赛」,并返回先响应的 URL.如果两个 URL 在 10 秒内都未返回结果,那么应该返回一个 error ...

  5. 超全 泛微 E9 Ecology 9开发资料大全 开源资源下载 泛微E9二次开发 泛微开发实战经验 泛微开发实战例子 泛微二次开发项目例子 泛微二次开发Demo 泛微二次开发完整例子 泛微二次开发入门

    由于工作需要,E9在泛微一推出来,以前所在的企业就第一时间上线了,经过四年多的运行,功能强大再加上在上面开发非常多的业务,一般的企业员工只需要打开泛微就可以处理完平时信息化的业务.后来又去外包公司专业 ...

  6. 势如破竹的雷霆两招,微服务进阶Serverless

    ​在应用开发中,服务器的开发一直是最重要的部分之一.在服务器开发不断演进过程中,我们可以将它简单分为5个阶段: 物理机阶段->虚拟机阶段->云计算阶段->容器阶段->当前的Se ...

  7. kubernetes 启用 PHP + Nginx 网页环境

    kubernetes 启用 PHP + Nginx 网页环境 传统安装方式进行安装步骤较多,使用kubernetes可以实现快速启用环境,在测试或者线上都可以做到快速 启用 编写 yaml 文件 [r ...

  8. [Java SE]Java方法的参数传递机制:值传递

    1 案例引入:实验源码 [案例结论] 若调用方client想通过修改方法updateMethod(oldObject)对调用方所在的引用对象(非基本数据类型)oldObject的属性值进行修改,则: ...

  9. 基于SqlSugar的开发框架循序渐进介绍(25)-- 基于SignalR实现多端的消息通讯

    基于ASP.NET Core SignalR 可以实现客户端和服务器之间进行即时通信.本篇随笔介绍一些SignalR的基础知识,以及结合对SqlSugar的开发框架的支持,实现SignalR的多端处理 ...

  10. EF Core 使用Azure App Service中的In-App MySQL服务

    Azure App Service 提供了一个应用内的MySQL,可以供测试.开发使用. 前提条件是需要使用Windows的操作系统. 创建完App Server 之后,只需要在设置下开启 MySQL ...