Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How to split a terraform file (main.tf) in several files (No Modules)?

I have a GCP infrastructure deployed through Terraform: buckets, service accounts, Compute Engines, VPC, cloud SQL, BigTable, BigQuery, Composer, etc.

Terraform v0.11.10 Provider "google" (2.15.0)

Recently the client asked me to split our only one terraform file (e.g. main.tf) in several files. E.g: One files for Buckets, other for Service Accounts, other for Database Services, etc.

I only have one terraform state file located in a GCP bucket.

How could I do it with the lowest impact ? What about with the terraform state ? (Will there also be also multiples state files ? Or Is the idea to keep only one TF file, even if we split the code out ?)

NOTE: This has nothing to do with Terraform modules, it's just about dividing a single terraform file (.tf) into several files (.tf)

Thanks in advance!

like image 889
José Enrique Hernández Avatar asked Sep 18 '19 23:09

José Enrique Hernández


People also ask

How does Terraform handle multiple TF files?

Terraform does not ascribe any special meaning to which filenames you use and how many files you have. Terraform instead reads all of the . tf files and considers their contents together. Therefore you can freely move the blocks from your main.tf file into as many separate .

What are the main files in Terraform?

Code in the Terraform language is stored in plain text files with the . tf file extension. There is also a JSON-based variant of the language that is named with the .

What is main TF file in Terraform?

main.tf will contain the main set of configuration for your module. You can also create other configuration files and organize them however makes sense for your project. variables.tf will contain the variable definitions for your module.


2 Answers

Terraform does not ascribe any special meaning to which filenames you use and how many files you have. Terraform instead reads all of the .tf files and considers their contents together.

Therefore you can freely move the blocks from your main.tf file into as many separate .tf files in the same directory as you like, and Terraform will consider the configuration to be exactly equivalent as long as you change nothing in the contents of those blocks while you do it.

(There is a special case for Override Files that makes the above not strictly true. As long as you avoid naming any of your files override.tf or with an _override.tf suffix that special case will not apply, but I'm mentioning it just for completeness.)

like image 76
Martin Atkins Avatar answered Sep 21 '22 09:09

Martin Atkins


The command terraform apply can be apply to a file or a directory, according with the documentation. Thus, put all your file in a directory and apply them.

The tfstate file is relative to a deployment. You will have only one.

About the lowest impact... Hard to say. All depends of your variables and your resource dependencies. If you have to search is several file to understand how a resource is created or where a variable is set, multiple file isn't a great idea... However, it's your customer requirement and do it the much simpler for readability.

like image 41
guillaume blaquiere Avatar answered Sep 18 '22 09:09

guillaume blaquiere