如果您已经对 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. 给宝宝的AC自动机启蒙指南(宝宝的第一本)

    AC自动机 根据已有经验,学完虚数会变虚,然后写出的代码就不是人能看的了 所以我们来学实树罢(喜) 以上为废话博客背景 有限状态自动机 首先我们来了解一下自动机是啥. 说的通俗一点,我们可以把自动机看 ...

  2. SpringBoot——自定义自动配置与起步依赖

    SpringBoot--自定义自动配置与起步依赖 SpringBoot为我们提供了灵活强大的自动配置与起步依赖功能,接下来我们参考其实现原理,实现专属于我们自己的自动配置与起步依赖. 不仅如此,我们对 ...

  3. Kotlin 与 JAVA 不同之处

    添加kotlin混编支持 要在Android项目中添加Kotlin混编支持,需要进行以下步骤: 在项目的 build.gradle 文件中添加以下代码: kotlin android { ... // ...

  4. vue之写发表评论思路

    后端接口 var express = require('express'); const sql = require('../sql') const Comment = require('../sql ...

  5. odoo 开发入门教程系列-模型之间的关系(Relations Between Models)

    模型之间的关系(Relations Between Models) 上一章介绍了为包含基本字段的模型创建自定义视图.然而,在任何真实的业务场景中,我们都需要不止一个模型.此外,模型之间的链接是必要的. ...

  6. Revit BIM模型在ArcGIS Pro中的数据组织及转换成SLPK后的图层结构解析

    ArcGIS Pro对Revit 数据有自己的一套分层方式. 在ArcGIS Pro中打开bim文件会发现都是按照相同的方式组织数据: 将rvt格式数据转换成SLPK格式后的数据结构(将slpk数据直 ...

  7. PVE开启硬件显卡直通功能

    首先编辑GRUB配置文件: root@pve:~# vim /etc/default/grub root@pve:~# root@pve:~# cat /etc/default/grub # If y ...

  8. python入门教程之二环境搭建

    环境搭建 1python解释器 当我们编写Python代码时,我们得到的是一个包含Python代码的以.py为扩展名的文本文件.要运行代码,就需要Python解释器去执行.py文件. 由于整个Pyth ...

  9. pysimplegui之元素简单介绍(元素值得获取修改,key的规范及特殊用法)

    重点 1获取元素的值 Input(key='mykey') values['mykey'] 2通过key查找元素 对象window['key'] 3更新元素的值 window['key'](要更新的值 ...

  10. FTP FileZilla 425 Can't open data connection for transfer of "/" 错误: 读取目录列表失败

    如图所示: 在谷歌百度搜了很多资料都没有解决,主动被动模式端口入站规则什么能设置的都设置了结果还是不行,尝试换了一个软件用了FTP Rush就直接可以连上了. 具体原因有空再查找吧,目前问题算是解决了 ...