如果您已经对 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. 微软wsl2启用天父行程systemd

    默认情况下 微软wsl2的天父行程是init,没办法使用systemctl相关指令,所以想使用天父行程 systemd. 本文以Wsl2 Alma Linux为例,启用systemd 上帝与你同在,阿 ...

  2. java循环结构中局部变量和成员变量

    前言 在前两篇文章中,壹哥给大家讲解了Java里的条件分支,包括if和switch两种情况.我们知道,除了条件分支结构,还有循环结构,所以接下来的一个学习重点就是Java里的循环.但在学习循环之前,我 ...

  3. 深入理解 python 虚拟机:字节码灵魂——Code obejct

    深入理解 python 虚拟机:字节码灵魂--Code obejct 在本篇文章当中主要给大家深入介绍在 cpython 当中非常重要的一个数据结构 code object! 在上一篇文章 深入理解 ...

  4. [Linux]Xmanager+Xshell远程管理桌面版CentOS物理服务器的桌面版CentOS虚拟机

    1 需求/背景 在项目现场有这么一个情况,有1台Gnome版的CentOS的物理服务器,其内运行了2台通过vmware安装的Gnome桌面版的CentOS的虚拟服务器. 按照常规做法是: 将唯一的1台 ...

  5. Gartner最新报告,分析超大规模边缘解决方案

    当下,酝酿能量的超级边缘. 最近,我们在谈视频化狂飙.谈AIGC颠覆.谈算力动能不足,很少谈及边缘.但"边缘"恰恰与这一切相关,且越发密不可分,它是未来技术发展的极大影响因子. & ...

  6. 【Vue项目】尚品汇(四)Search组件开发

    Search模块开发 分析:1)编写静态页面 2)编写api 3)编写vuex三大件 4)组件获取仓库数据,并进行动态展示 1 SearchSelector 1 编写api export const ...

  7. ajax面试题总结

    转载请注明出处: 1.ajax异步和同步的区别 Ajax是一种基于JavaScript语言和XMLHttpRequest对象的异步数据传输技术,通过它可以使不用刷新整个页面的情况下,对页面进行部分更新 ...

  8. Go语言实现分布式对象存储系统

    实现一个可扩展的,简易的,分布式对象存储系统 存储系统介绍 先谈谈传统的网络存储,传统的网络存储主要分为两类: NAS,即Newtwork Attached Storage,是一个提供了存储功能和文件 ...

  9. Linux网络管理入门

    根据自己的需要来设置Linux的一些属性 网络状态查看 在终端输入ifconfig可以查看网络状态 # ifconfig eth0: flags=4163<UP,BROADCAST,RUNNIN ...

  10. 笔记:C++学习之旅---指针

    笔记:C++学习之旅---指针 为什么要使用指针 因为在操作大型数据和类时,由于指针可以通过内存地址直接访问数据,从而避免在程序中赋值大量的代码,因此指针的效率最高,一般来说,指针会有三大用途: 1: ...