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

Improve: HA state #967

Open
Tinyblargon opened this issue Mar 18, 2024 · 3 comments
Open

Improve: HA state #967

Tinyblargon opened this issue Mar 18, 2024 · 3 comments
Assignees
Labels
help wanted resource/qemu Issue or PR related to Qemu resource type/enhancement An improvement of existing functionality

Comments

@Tinyblargon
Copy link
Collaborator

Adding in support for all HA settings Telmate/proxmox-api-go#317

@mleone87 @hestiahacker
As I don't use this resource in a module I'm wondering if my proposed schema is sensible

resource "proxmox_vm_qemu" "test" {
    ha {
        comment = "HA comment"
        group = "test"
        restarts = 3
        relocates = 1
        state = "started"
    }
}

Found a way to keep compatibility with the old hastate and hagroup attributes.

@Tinyblargon Tinyblargon added type/enhancement An improvement of existing functionality help wanted labels Mar 18, 2024
@Tinyblargon Tinyblargon self-assigned this Mar 18, 2024
@hestiahacker
Copy link
Contributor

This schema makes sense to me, but it seems like it conflicts with hastate and hagroup. For example: hastate might be set to "stopped" and ha could have { state = "started" }, which seems like it's going to cause confusion at best, and problems at worst.

At the same time, I understand the desire to keep backward compatibility. If we clearly document that the values in ha {} override the values in hastate and hagroup, I think that'll give us the best of both worlds. Maybe we could deprecate hastate and hagroup when this rolls out and remove them after a couple major releases?

Is there (or will there be) a way to define an HA group? I only see the ability to assign a VM to a group, but no way to programmatically ensure that the group exists.

Full disclosure: I don't use the HA feature, but I'd like to. I currently have a cluster on a production setup, but I don't have the automatic failover. It's currently all manual, as I don't have access enough NICs/server nor hardware to enforce fencing. I'd like to budget for these hardware upgrades and use this feature, but I am a little nervous seeing as how the HA documentation on the Proxmox wiki has screenshots of Proxmox 2.0 and the instructions for fencing don't work in Proxmox 4.0 and later.

Side note: I find it very ironic that the HA is not recommended for systems with unreliable hardware. It seems like that's exactly where it would be the most desirable! 😆

@Tinyblargon
Copy link
Collaborator Author

@hestiahacker thank you for the feedback.

hagroup and hastate will be marked as deprecated and are mutually exclusive with ha. This will make it possible to keep using the legacy hastate.

In the future there will be support for creating ha groups with terraform.

@hestiahacker
Copy link
Contributor

In that case, looks good to me. Thanks for coming up with this and collecting community input. ❤️

@Tinyblargon Tinyblargon added the resource/qemu Issue or PR related to Qemu resource label Nov 27, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
help wanted resource/qemu Issue or PR related to Qemu resource type/enhancement An improvement of existing functionality
Projects
None yet
Development

No branches or pull requests

2 participants