Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Code suggestion: limit recreation scenarios of bigip vm #56

Open
wants to merge 3 commits into
base: main
Choose a base branch
from

Conversation

JelleBroekhuijsen
Copy link
Contributor

I am suggesting these changes to the module to stop redeployment of the VM because of 'known after apply' behavior in terraform.

We observed frequent destructive changes to the infra when rerunning identical code. We suspect this being due to certain values not being predictable by terraform forcing recreation of the VM.

Values that were marked as 'known after apply' include resource_group_name and location, both of which were derived from the data source azurerm_resource_group.bigiprg. This data source seemed to serve no purpose other than provide access to these mostly static values.

Furthermore admin_password and custom_data also have similar behavior because they are 'sensitive values'. To prevent these properties from causing a redeployment of the VM I added these as lifecycle properties with ignore_changes

I do see some merit to having custom_data changes trigger a redeploy as the data in this block is not as static however it might be better to force a user to consciously remove the resource via terraform destroy or deletion of the VM; an update in place is not supported either way and there are more downsides to the unneeded redeployment that these fixes remediate than there are upsides to having modification to custom_data trigger an automated redeploy of the entire VM.

image

@apellini
Copy link

apellini commented Jan 15, 2024

Consider also hostname could cause a recreation. Seems that this module is based for only creating F5 instances but not manage lifecycle. Pheraps it is better to accept a map where you insert hostname and type of machine, because sometimes you want only to upgrade size of VM. Consider also extensions ("custom data") to manage with lifecycle because them are managed by DO or Cloud-Init.

For customisation, you could need to put lifecycle also on image type. Because if you use terraform you have to import whole configuration. Instead if you use normal procedure, you could only import the bin file, but terraform sees a change and wants to force replacement.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants