0

0

VSCode与Terraform/HCL:基础设施即代码

P粉986688829

P粉986688829

发布时间:2025-12-20 19:35:02

|

494人浏览过

|

来源于php中文网

原创

应安装 HashiCorp 官方 Terraform 扩展、配置 .tf/.tfvars 文件关联为 terraform 语言、设置 hashicorp.terraform 为默认格式化器、指定本地 terraform CLI 路径,并禁用冲突的第三方 HCL 扩展。

vscode与terraform/hcl:基础设施即代码

如果您在使用 VSCode 编辑 Terraform 配置文件(.tf 文件)时遇到语法高亮异常、自动补全失效或格式化错误,通常是因为 HCL 语言支持未正确配置或扩展冲突。以下是解决此问题的步骤:

本文运行环境:MacBook Pro,macOS Sequoia。

一、安装官方 HashiCorp 官方扩展

VSCode 默认不内置 HCL 语言支持,需通过官方扩展启用完整语法解析、资源类型提示及变量引用跳转功能。

1、打开 VSCode,点击左侧活动栏中的扩展图标(或按快捷键 Cmd+Shift+X)。

2、在搜索框中输入 HashiCorp Terraform

3、在搜索结果中找到由 HashiCorp 官方发布的扩展,确认发布者为 HashiCorp,点击“安装”按钮。

4、安装完成后,重启 VSCode 或重新打开一个 .tf 文件以激活语言服务器。

二、配置 HCL 语言关联与默认格式化器

VSCode 需明确将 .tf 和 .tfvars 文件识别为 HCL 语言,并指定 terraform fmt 作为默认格式化工具,否则保存时无法自动格式化。

1、按下 Cmd+, 打开设置界面,在右上角点击“打开设置(JSON)”图标。

2、在 settings.json 中添加以下配置项:

3、在 "files.associations" 下添加:"*.tf": "terraform", "*.tfvars": "terraform"

4、在 "editor.defaultFormatter" 下添加:"hashicorp.terraform": "hashicorp.terraform"

SUN2008 企业网站管理系统2.0 beta
SUN2008 企业网站管理系统2.0 beta

1、数据调用该功能使界面与程序分离实施变得更加容易,美工无需任何编程基础即可完成数据调用操作。2、交互设计该功能可以方便的为栏目提供个性化性息功能及交互功能,为产品栏目添加产品颜色尺寸等属性或简单的留言和订单功能无需另外开发模块。3、静态生成触发式静态生成。4、友好URL设置网页路径变得更加友好5、多语言设计1)UTF8国际编码; 2)理论上可以承担一个任意多语言的网站版本。6、缓存机制减轻服务器

下载

5、保存 settings.json 文件并关闭编辑器窗口。

三、启用本地 terraform CLI 路径绑定

VSCode 的 Terraform 扩展依赖本地 terraform 可执行文件提供语义验证与计划预览能力,若路径未指定,将无法显示资源依赖图或 plan 输出预览。

1、在终端中执行 which terraform,记录返回的完整路径(例如 /usr/local/bin/terraform)。

2、进入 VSCode 设置(Cmd+,),搜索 terraform.path

3、在“Terraform: Path”设置项中,粘贴上一步获取的路径。

4、确保该路径下 terraform 版本不低于 1.0.0,可通过终端运行 terraform version 验证。

四、禁用冲突的语言扩展

部分第三方 HCL 或 JSON 扩展会劫持 .tf 文件的语言模式,导致语法高亮错乱或 LSP 功能失效,需手动排除干扰。

1、在扩展面板中搜索关键词 HCLJSON

2、逐一检查已安装扩展的描述页,识别非 HashiCorp 官方发布的 HCL 支持扩展(如 “HCL Language Support”、“Better HCL” 等)。

3、对每个疑似冲突扩展,点击其右侧“禁用”按钮。

4、禁用后重新打开任意 .tf 文件,观察右下角语言模式是否显示为 Terraform(而非 HCL 或 Plain Text)。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

417

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

533

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

311

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

76

2025.09.10

vscode
vscode

VS Code(Visual Studio Code)是一款免费、开源的跨平台代码编辑器,由微软开发和维护。它被广泛用于软件开发和编程,支持多种编程语言和框架。VS Code 同时提供了丰富的功能和扩展性,使开发者可以高效地编写、编辑和调试代码。

591

2023.06.30

vscode怎么运行代码
vscode怎么运行代码

vscode是一个运行于MacOS X、Windows和Linux之上的,针对于编写现代Web和云应用的跨平台源代码编辑器;vscode免费而且功能强大,对JavaScript和NodeJS的支持非常好,自带很多功能,例如代码格式化,代码智能提示补全、Emmet插件等。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

221

2023.07.21

vscode使用的框架介绍
vscode使用的框架介绍

VSCode是一款跨平台代码编辑器,它基于Electron框架和Monaco Editor构建。想了解更多vscode的相关内容,可以阅读本专题下面的文章。

390

2024.03.14

vscode一般用来写什么语言
vscode一般用来写什么语言

VSCode是一款功能强大的代码编辑器,支持多种编程语言和文件格式。它内置对 JavaScript、Python、Java、C++、TypeScript、HTML/CSS、Go 等语言的支持。想了解更多vscode的相关内容,可以阅读本专题下面的文章。

376

2024.03.14

c++空格相关教程合集
c++空格相关教程合集

本专题整合了c++空格相关教程,阅读专题下面的文章了解更多详细内容。

0

2026.01.23

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
go语言零基础开发内容管理系统
go语言零基础开发内容管理系统

共34课时 | 2.6万人学习

第二十三期_前端开发
第二十三期_前端开发

共98课时 | 7.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号