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!
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 .
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 .
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.
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.)
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.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With