Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/magodo/tfmerge
A tool to merge Terraform state files
https://github.com/magodo/tfmerge
terraform tool
Last synced: 2 months ago
JSON representation
A tool to merge Terraform state files
- Host: GitHub
- URL: https://github.com/magodo/tfmerge
- Owner: magodo
- License: mpl-2.0
- Created: 2022-08-29T09:52:32.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2024-05-10T03:34:28.000Z (8 months ago)
- Last Synced: 2024-10-30T05:36:32.000Z (2 months ago)
- Topics: terraform, tool
- Language: Go
- Homepage:
- Size: 39.1 KB
- Stars: 20
- Watchers: 2
- Forks: 6
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# tfmerge
A tool to merge multiple Terrafrom state files into one.
## Usage
Given you have an initialized Terraform working directory (abbr. *wd*) (create one and run `terraform init` in it if not existed yet). The state file in *wd* will be used as the *base state file* (i.e. the `lineage` will be reserved, and the `serial` will be incremented). Meanwhile, you have other three state files to be merged: `state1`, `state2`, `state3`, where the module and resource addresses among these state files together with the *base state file* have no overlaps.
`tfmerge` helps you merging these state files into the *base state file* by simply running `tfmerge -o terraform.tfstate state1 state2 state3` within the *wd*.
If your *wd* is using [a non-local backend](https://www.terraform.io/language/settings/backends/configuration), you'll need to manually upload the merged state file via `terraform state push`.
## How
*The process is inspired by https://support.hashicorp.com/hc/en-us/articles/4418624552339-How-to-Merge-State-Files*
`tfmerge` will simply do followings:
- Run `terraform state pull` to retrieve the *base state file*, works for both local and non-local backends. Especially, the output can be an empty string if there is no state file in the working directory, in this case a new state file will be created with a new lineage.
- Run `terraform state list` on the *base state file* and the to-be-merged state files, to list all the items to be moved. Meanwhile, ensure there is no resource/module address overlap.
- Copy all the state files to a temporary directory, to avoid mutation on existing state files.
- Repeatedly run `terraform state mv -state-out= -state= `
- Return the merged base state file## Reference
- https://discuss.hashicorp.com/t/will-state-and-state-out-be-removed-for-terraform-state-mv-subcommand/44630
- https://support.hashicorp.com/hc/en-us/articles/4418624552339-How-to-Merge-State-Files