Terraform中DataSource的深度分析

本文涉及的产品
云服务器 ECS,每月免费额度280元 3个月
云服务器ECS,u1 2核4GB 1个月
简介: DataSource是Terraform官方提供的插件功能,各个Provider可以实现自己的DataSource能力,目的是通过DataSource中的定义过滤需要的数据,一是简化模板编写时数据过滤的复杂性,二是各个资源对Data源的引用保持一致,比如想要知道“华北2”的Region下都有哪些可用区,就可以用DataSource,如果想指定第一个可用区,就可以这样使用“${data.alicloud_zones.0.id}”。

一、DataSource功能介绍

DataSource是Terraform官方提供的插件功能,各个Provider可以实现自己的DataSource能力,目的是通过DataSource中的定义过滤需要的数据,一是简化模板编写时数据过滤的复杂性,二是各个资源对Data源的引用保持一致,比如想要知道“华北2”下CPU为1核,内存为1G的ECS实例类型是什么,就可以用DataSource,如果想引用这个数据源,就可以这样使用"${data.alicloud_instance_types.1c1g.instance_types.0.id}"。

二、阿里云DataSource的功能增强

阿里云的DataSource在Terraform原生的功能上做了增强:

  • 不仅可以作为资源引用过滤使用,还支持导出过滤结果;
  • 并且在"plan"时就可以看到文件(原生的功能只能在实"apply"时才可使用,很不方便);
  • 更强大的是在过滤ECS实例类型时如果入参没有可选的资源,会提示支持的类型都有哪些;

DataSource目前支持Region、可用区、镜像、ECS实例类型、VPC、keyPair,如果有用户想知道都有哪些镜像ID,就可以通过DataSource执行后查看导出的文件获取数据,即便是不用于Terraform中也可以做为一个小工具使用。源码详见 https://github.com/alibaba/terraform-provider/tree/master/alicloud 中以data_source开头的文件。

三、例子

下面以ECS实例类型为例,深度讲解如何使用:

需求场景:想要创建一台ECS,条件:Region是华北2,CPU为1核,内存1G,想要知道有哪些实例类型可用。

datasource的代码如下:

data "alicloud_instance_types" "1c1g" {
    cpu_core_count = 1
    memory_size = 1
    "output_file" = "instance_type.json"  //重点是这句,指明导出的文件名
}

执行“terraform plan”,即可看到输出的文件 instance_type.json的文件,我们查看文件内容如下:
image

返回字段说明如下:

  • 除了入参"cpu_core_count"和"memory_size"外,我们看到还有两个返回参数,一个是family,一个是id,family即是ECS实例类型家族,id即是具体的实例类型。

在创建ECS时可以如下引用
image

怎么样,是不是很简单?
如果你曾经被阿里云的ECS复杂约束而困扰,如果你不知道去哪里找实例类型、镜像、可用区,如果你输入的实例类型不符合要求,但又不知道怎么写是正确的,快快用起DataSource功能吧。

相关实践学习
一小时快速掌握 SQL 语法
本实验带您学习SQL的基础语法,快速入门SQL。
7天玩转云服务器
云服务器ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,可降低 IT 成本,提升运维效率。本课程手把手带你了解ECS、掌握基本操作、动手实操快照管理、镜像管理等。了解产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
6月前
|
XML Java 大数据
Spring Batch:处理大数据和批量任务的解决方案
Spring Batch:处理大数据和批量任务的解决方案
193 0
|
消息中间件 存储 运维
EventBridge 与 FC 一站式深度集成解析
本篇文章通过对 EventBridge 与 FC 一站式深度集成解析和集成场景的介绍,旨在帮助大家更好的了解面对丰富的事件时,如何使用 EventBridge 与 FC 的一站式集成方案,快速基于事件驱动(EDA)架构建云上业务系统。
291 0
EventBridge 与 FC  一站式深度集成解析
|
存储 缓存 druid
基于springboot+jpa 实现多租户动态切换多数据源 - 基于dynamic-datasource实现多租户动态切换数据源
基于springboot+jpa 实现多租户动态切换多数据源 - 基于dynamic-datasource实现多租户动态切换数据源
2761 0
基于springboot+jpa 实现多租户动态切换多数据源 - 基于dynamic-datasource实现多租户动态切换数据源
|
Cloud Native 安全 Serverless
EventBridge 与 FC 一站式深度集成解析(一)| 学习笔记
快速学习 EventBridge 与 FC 一站式深度集成解析。
263 0
EventBridge 与 FC 一站式深度集成解析(一)| 学习笔记
|
消息中间件 存储 弹性计算
EventBridge 与 FC 一站式深度集成解析(二)| 学习笔记
快速学习 EventBridge 与 FC 一站式深度集成解析。
310 0
EventBridge 与 FC 一站式深度集成解析(二)| 学习笔记
|
监控 Cloud Native API
带你读《云原生应用开发 Operator原理与实践》第三章 Kubebuilder 原理3.3 Controller-runtime 模块分析(六)
带你读《云原生应用开发 Operator原理与实践》第三章 Kubebuilder 原理3.3 Controller-runtime 模块分析
|
存储 缓存 Kubernetes
带你读《云原生应用开发 Operator原理与实践》第三章 Kubebuilder 原理3.3 Controller-runtime 模块分析(四)
带你读《云原生应用开发 Operator原理与实践》第三章 Kubebuilder 原理3.3 Controller-runtime 模块分析
|
存储 运维 自然语言处理
深度解析|基于 eBPF 的 Kubernetes 一站式可观测性系统
阿里云 Kubernetes 可观测性是一套针对 Kubernetes 集群开发的一站式可观测性产品。基于 Kubernetes 集群下的指标、应用链路、日志和事件,阿里云 Kubernetes 可观测性旨在为 IT 开发运维人员提供整体的可观测性方案。
深度解析|基于 eBPF 的 Kubernetes 一站式可观测性系统
|
Kubernetes Cloud Native API
带你读《云原生应用开发 Operator原理与实践》第三章 Kubebuilder 原理3.3 Controller-runtime 模块分析(十)
带你读《云原生应用开发 Operator原理与实践》第三章 Kubebuilder 原理3.3 Controller-runtime 模块分析
带你读《云原生应用开发 Operator原理与实践》第三章 Kubebuilder 原理3.3 Controller-runtime 模块分析(十)
|
Cloud Native Perl
带你读《云原生应用开发 Operator原理与实践》第三章 Kubebuilder 原理3.3 Controller-runtime 模块分析(三)
带你读《云原生应用开发 Operator原理与实践》第三章 Kubebuilder 原理3.3 Controller-runtime 模块分析
带你读《云原生应用开发 Operator原理与实践》第三章 Kubebuilder 原理3.3 Controller-runtime 模块分析(三)

热门文章

最新文章