tencent cloud

边缘安全加速平台 EO

动态与公告
产品动态
安全公告
产品公告
产品简介
产品概述
产品优势
应用场景
EdgeOne 与 CDN 等产品功能对比
使用限制
购买指南
试用套餐体验权益说明
免费版套餐使用说明
计费概述
计费项目
购买指引
续费指引
欠费与退款说明
套餐选型对比
关于“干净流量”计费说明
DDoS 防护容量说明
快速入门
选择业务场景
快速接入网站安全加速
通过 Pages 快速部署网站
域名服务与源站配置
域名服务
HTTPS 证书
源站配置
站点加速
概述
访问控制
智能加速
缓存配置
文件优化
网络优化
URL 重写
修改头部
修改应答内容
规则引擎
图片与视频处理
单连接下载限速
DDoS 与 Web 防护
概述
DDoS 防护
Web 防护
Bot 管理
API 资产识别(Beta)
边缘函数
概述
快速指引
操作指引
Runtime APIs
示例函数
实践教程
Pages
四层代理
概述
新建四层代理实例
修改四层代理实例配置
停用/删除四层代理实例
批量配置转发规则
获取客户端真实IP
数据分析与日志服务
日志服务
数据分析
告警服务
站点与计费管理
计费管理
站点管理
版本管理
通用策略
通用参考
配置语法
请求与响应行为
国家/地区及对应代码枚举
Terraform
Terraform 简介
安装和配置 Terraform
实践教程
自动预热/清除缓存
防盗刷/盗链实践
HTTPS 相关实践
加速优化
流量调度
数据分析与告警
第三方日志平台集成实践
对象存储类源站(例如:COS)配置实践
跨域响应配置
API 文档
History
Introduction
API Category
Making API Requests
Site APIs
Acceleration Domain Management APIs
Site Acceleration Configuration APIs
Edge Function APIs
Alias Domain APIs
Security Configuration APIs
Layer 4 Application Proxy APIs
Content Management APIs
Data Analysis APIs
Log Service APIs
Billing APIs
Certificate APIs
Origin Protection APIs
Load Balancing APIs
Diagnostic Tool APIs
Custom Response Page APIs
API Security APIs
DNS Record APIs
Content Identifier APIs
Legacy APIs
Ownership APIs
Image and Video Processing APIs
Multi-Channel Security Gateway APIs
Version Management APIs
Data Types
Error Codes
常见问题
产品特性相关问题
DNS 记录相关问题
域名配置相关问题
站点加速相关问题
数据与日志相关问题
安全防护相关问题
源站配置相关问题
排障指南
异常状态码参考
EdgeOne 4XX/5XX 状态码排障指南
520/524状态码排障指南
521/522 状态码排障指南
工具指南
相关协议
Service Level Agreement
源站防护启用特别约定
TEO 政策
隐私协议
数据处理和安全协议
联系我们
词汇表

Terraform 简介

聚焦模式
字号
最后更新时间: 2024-01-25 11:20:13

Terraform 是什么?

Terraform 是一款使用 Go 编写、运行在客户端、开源的资源编排工具。基于 HashiCorp Plugin 的架构设计,赋予 Terraform 高度可扩展的特性。目前腾讯云也基于 Terraform Plugin 实现了 TencentCloud Provider,支持通过 Terraform 管理腾讯云上资源。示意图如下:

TencentCloud Provider 基于 tencentcloud-sdk-go 实现,目前已经提供了超过183个 Resource 和158个 Data Source,覆盖计算、存储、网络、容器服务、负载均衡、中间件、数据库、云监控等超过30款产品,已满足众多用户的基本上云需求。
您可通过 EdgeOne 提供的 Terraform 文档Terraform 编写样例,来快速了解并开始使用 Terraform。

Terraform 优势

多云编排

Terraform 适用于多云方案,您可将相类似的基础结构部署到腾讯云、其他云提供商或本地数据中心。开发人员能够使用相同的工具和相似的配置文件同时管理不同云提供商的资源。

基础设施及代码

基础设施可以使用高级配置语法 HCL 进行描述,使得基础设施能够被代码化和版本化,从而可以进行共享和重复使用。示例如下:
# 以 NS 接入方式创建站点 example.com
resource "tencentcloud_teo_zone" "zone" {
zone_name = "example.com"
# 通过 zone_available_plans 查询您可用的套餐信息
plan_type = "<your-plan-type>"
type = "full"
paused = false
cname_speed_up = "enabled"
}

# 创建 example.com 的 DNS 记录
resource "tencentcloud_teo_dns_record" "dns_record" {
zone_id = tencentcloud_teo_zone.zone.id
type = "A"
name = "example.com"
# 开启 CDN 加速服务
mode = "proxied"
content = "<your-backend-ip>"
ttl = 60
}

执行计划

Terraform 具备 “Planning” 步骤,执行 terraform plan 命令后 Terraform 会生成执行计划。执行计划会显示当调用 apply 时 Terraform 的状态,您可通过该能力在 Terraform 操作基础设施时避免任何意外。示例如下:
Terraform used the selected providers to generate the following execution plan. Resource actions are indicated with the following symbols:
+ create

Terraform will perform the following actions:

# tencentcloud_teo_dns_record.dns_record will be created
+ resource "tencentcloud_teo_dns_record" "dns_record" {
+ cname = (known after apply)
+ content = "<your-backend-ip>"
+ created_on = (known after apply)
+ domain_status = (known after apply)
+ id = (known after apply)
+ locked = (known after apply)
+ mode = "proxied"
+ modified_on = (known after apply)
+ name = "example.com"
+ priority = (known after apply)
+ type = "A"
+ status = (known after apply)
+ ttl = 60
+ zone_id = (known after apply)
}

# tencentcloud_teo_zone.zone will be created
+ resource "tencentcloud_teo_zone" "zone" {
+ area = (known after apply)
+ cname_speed_up = "enabled"
+ cname_status = (known after apply)
+ created_on = (known after apply)
+ id = (known after apply)
+ modified_on = (known after apply)
+ name = "example.com"
+ name_servers = (known after apply)
+ original_name_servers = (known after apply)
+ paused = false
+ plan_type = "sta"
+ status = (known after apply)
+ type = "full"
+ vanity_name_servers_ips = (known after apply)

+ vanity_name_servers {
+ servers = (known after apply)
+ switch = (known after apply)
}
}

Plan: 2 to add, 0 to change, 0 to destroy.

───────────────────────────────────────────────────────────────────────────────

Note: You didn't use the -out option to save this plan, so Terraform can't guarantee to take exactly these actions if you run "terraform apply" now.

自动变更

您可在基础设施上通过最少的人工干预工作,应用复杂的变更集。通过前文中的执行计划及资源拓扑,您可准确获取 Terraform 动态,避免可能的人为错误。

远程状态管理

Terraform 引入了远程状态存储机制 Backend,目前腾讯云可通过 对象存储 COS 来管理用户的 tfState 文件,避免将文件保存在本地,造成丢失。同时,远程存储使多人同时对 Terraform 资源进行管理成为可能。

帮助和支持

本页内容是否解决了您的问题?

填写满意度调查问卷,共创更好文档体验。

文档反馈