博客
关于我
Azure Terraform(二)语法详解
阅读量:397 次
发布时间:2019-03-05

本文共 2145 字,大约阅读时间需要 7 分钟。

一,引言

  上篇文章开始,我们简单介绍了以下通过基础设施管理工具----- Terraform,通过它来统一管理复杂的云基础设施资源。作为入门演示,使用Terraform 部署Azure 资源组的方式直观的感受到iac 工具带来的强大便利。接下来,今天介绍 Terraform 语法详解,从代码的角度来理解Azure 各个资源模块更好的理解如果部署资源。

--------------------Azure Terraform 系列--------------------

二,正文

1,Azure Providers

Terraform 作为同一个可以可扩展的工具,是通过 Provider 来支持新的基础架构。Provider 是上游API的逻辑抽象。他们负责理解API交互并暴露资源。我们可以将 Provider 可以理解为各个云厂商提供的与云资源交互的后端驱动,不同的基础设施提供商都需要提供一个Provider来实现对自家基础设施的统一管理,例如我们熟知的 Azure,AWS,GCP,Kubernetes,Aliyun等等。根据官方罗列的 官方 Providers 和验证过的 Providers,超过了600多个。

大家可以点击此连接查看具体的 Terraform Providers :

那么我们想指定 Terraform Azure Provider 怎么写?

provider "azurerm" {  version = "~>2.0"  features {}}

version ="~>2.0" ,表示我们要使用 azure provider 的版本为 >2.0

features:表示自定义某些Azure提供程序资源的行为,我们目前使用的是 azure provider 的版本 2.x,如果使用的 azure provider 的版本为 1.x,则不需要 features

terraform init 来验证以上的解释

(1)provider version > 2.0

(2)provider version = 1.33

2,基本的Terraform 配置文件

resource "azurerm_resource_group" "example" {  name = "Web_Test_TF_RG"  location = "East Asia"}

resource:表示我们将创建类型为 “azurerm_resource_group” 新的资源组

example:表示我们为当前新创建的资源组的 terraform module 起的名称

当前新创建的资源组,我们为其定义了两个参数,分别为 “name” 和 “location”

name:表示为当前即将创建的资源组的名称为 “Web_Test_TF_RG

location:表示当前资源组所在的位置为 “East Asia

接下就是执行部署计划的过程了 (plan 生成执行计划过程我就不在演示了)

3,Terraform 状态管理

terraform apply

执行计划部署完成后,会在Terraform 项目文件夹中生成 “terraform.tfstate” 的文件和 “.terraform.tfstate.lock.info”的文件

 terraform.tfstate:当前文件中包含了因为它包含有关已部署到Azure的内容的所有状态信息

terraform.tfstate.lock.info:这个文件从名字上就可以看出来,部署过程中加锁。这时候就有人疑惑了,为什么要加锁 ?

原因很简单,就那操作数据库来说,对同一数据的修改,或者删除的时候,需要加锁处理。这里的terraform 的状态文件加锁也是同样的道理。

4,Terraform扩展知识点

其实我们都知道,Azure 有好几个版本,我们一般常用的就是 Azure Global,Azure China,如果我们在 Azure Provider 中不指定哪个Azure 环境,Terraform 会默认认为我们是将云资源部署在 Azure Global 上的。如果我们用的是Azure China(世纪互联版的Azure),那我就必须得在 Provider 中指定Azure 环境

environment 的值可能为:

  (1)public(默认)

  (2)usgovernment

  (3)german

  (4)china

注意:如果不想在Provider 中指定云环境,我们可以设置环境变量

setx ARM_ENVIRONMENT china

完整示例

provider "azurerm" {  version = "~>2.0"  environment = "china"  features {}}

ok,今天的分享就到此结束,今天也没有介绍新的内容,基本上就是对昨天代码的参数介绍,让我们能够更好的理解 Terraform 。

φ(゜▽゜*)♪是🐱‍🏍🐱‍🏍🐱‍🏍🐱‍🏍🐱‍🏍!

三,结尾

参考资料:,

作者: 

版权:转载请在文章明显位置注明作者及出处。如发现错误,欢迎批评指正。

你可能感兴趣的文章
mySQL 多个表求多个count
查看>>
mysql 多字段删除重复数据,保留最小id数据
查看>>
MySQL 多表联合查询:UNION 和 JOIN 分析
查看>>
MySQL 大数据量快速插入方法和语句优化
查看>>
mysql 如何给SQL添加索引
查看>>
mysql 字段区分大小写
查看>>
mysql 字段合并问题(group_concat)
查看>>
mysql 字段类型类型
查看>>
MySQL 字符串截取函数,字段截取,字符串截取
查看>>
MySQL 存储引擎
查看>>
mysql 存储过程 注入_mysql 视图 事务 存储过程 SQL注入
查看>>
MySQL 存储过程参数:in、out、inout
查看>>
mysql 存储过程每隔一段时间执行一次
查看>>
mysql 存在update不存在insert
查看>>
Mysql 学习总结(86)—— Mysql 的 JSON 数据类型正确使用姿势
查看>>
Mysql 学习总结(87)—— Mysql 执行计划(Explain)再总结
查看>>
Mysql 学习总结(88)—— Mysql 官方为什么不推荐用雪花 id 和 uuid 做 MySQL 主键
查看>>
Mysql 学习总结(89)—— Mysql 库表容量统计
查看>>
mysql 实现主从复制/主从同步
查看>>
mysql 审核_审核MySQL数据库上的登录
查看>>