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

Problem using snapshot_id while using module vmware_guest_snapshot #2236

Open
Rakesh2904 opened this issue Nov 5, 2024 · 6 comments
Open

Comments

@Rakesh2904
Copy link

SUMMARY

While using snapshot_id to delete the snapshot using module vmware_guest_snapshot , I get the below error

ISSUE TYPE
  • "Unsupported parameters for (vmware_guest_snapshot) module: snapshot_id Supported parameters include: datacenter, description, folder, hostname, memory_dump, moid, name, name_match, new_description, new_snapshot_name, password, port, proxy_host, proxy_port, quiesce, remove_children, snapshot_name, state, use_instance_uuid, username, uuid, validate_certs",
COMPONENT NAME
ANSIBLE VERSION
2.9.27
COLLECTION VERSION
ansible-galaxy collection list | grep community.vmware
community.vmware                         4.1.0

CONFIGURATION
python version = 3.8.16

OS / ENVIRONMENT
STEPS TO REPRODUCE
EXPECTED RESULTS
ACTUAL RESULTS

@Rakesh2904
Copy link
Author

The reason for me to try and use snapshot_id is because when snapshot_name is like this 'VM Snapshot 05/11/2024, 14:20:05' and when I try to delete it I get the error '"msg": "Couldn't find any snapshots with specified name: VM Snapshot 05/11/2024, 14:20:05 on VM: <vm_name>".

Also this name is fetched dynamically inside the play and the json result is as below

"guest_snapshots": {
"snapshots": [
{
"id": 164,
"name": "VM Snapshot 05%2f11%2f2024, 14:20:05",
"description": "This is a test snapshot, can be deleted any time",
"creation_time": "2024-11-05T08:50:20.310483+00:00",
"state": "poweredOff"
},

But I've tried to delete the snapshot by hard coding the snapshot name by copy pasting directly from vCenter to the task but still I've the same error.

So I'd need to have a fix to have to delete snapshot when name is like this or using snapshot_id

@sky-joker
Copy link
Collaborator

Hi @Rakesh2904

I noticed that your Ansible version is outdated.
If possible, could you provide the trace log using the command below?

ansible-playbook -i INVENTORY PLAYBOOK -vvv

This will help me confirm whether the path to the module being called by Ansible is correct.

@Rakesh2904
Copy link
Author

Rakesh2904 commented Dec 4, 2024

Hello @sky-joker

Below are the details

ansible-playbook 2.9.27
config file = /etc/ansible/ansible.cfg
configured module search path = ['/home/runner/.ansible/plugins/modules', '/usr/share/ansible/plugins/modules']
ansible python module location = /usr/lib/python3.8/site-packages/ansible
executable location = /usr/bin/ansible-playbook
python version = 3.8.16 (default, May 31 2023, 12:44:21) [GCC 8.5.0 20210514 (Red Hat 8.5.0-18)]


{
"msg": "Unable to manage snapshots for non-existing VM <vm_name>",
"invocation": {
"module_args": {
"hostname": "",
"username": "",
"password": "VALUE_SPECIFIED_IN_NO_LOG_PARAMETER",
"validate_certs": false,
"datacenter": "",
"folder": "",
"name": "<vm_name>",
"snapshot_name": "VM Snapshot 04/12/2024, 09:15:39",
"state": "absent",
"port": 443,
"name_match": "first",
"use_instance_uuid": false,
"description": "",
"quiesce": false,
"memory_dump": false,
"remove_children": false,
"proxy_host": null,
"proxy_port": null,
"uuid": null,
"moid": null,
"new_snapshot_name": null,
"new_description": null
}
},
"_ansible_no_log": false,
"changed": false
}

@sky-joker
Copy link
Collaborator

Thank you for providing the details.
Could you also provide the Using module file info?

e.g.

$ ansible-playbook playbook.yml -vvv
ansible-playbook [core 2.14.14]
  config file = /etc/ansible/ansible.cfg
(snip)
PLAY [test] ****************************************************************************************************************************************************************************

TASK [command] *************************************************************************************************************************************************************************
task path: /root/dev/playbook.yml:6
(snip)
Using module file /root/dev/venv/lib64/python3.9/site-packages/ansible/modules/command.py <- this
(snip)

@Rakesh2904
Copy link
Author

Sorry for the delayed response

TASK [Delete snapshots older than retention period] ****************************
task path: /runner/project/test.yml:147
<{launch_node}> ESTABLISH SSH CONNECTION FOR USER: jh2_id
<{launch_node}> SSH: EXEC ssh -C -o ControlMaster=auto -o ControlPersist=60s -o StrictHostKeyChecking=no -o KbdInteractiveAuthentication=no -o PreferredAuthentications=gssapi-with-mic,gssapi-keyex,hostbased,publickey -o PasswordAuthentication=no -o 'User="jh2_id"' -o ConnectTimeout=60 -oStrictHostKeyChecking=no -oUserKnownHostsFile=/dev/null '-oProxyCommand=ssh -i $JH2_SSH_PRIVATE_KEY -W %h:%p -oStrictHostKeyChecking=no -oUserKnownHostsFile=/dev/null -oProxyCommand="ssh -i $JH1_SSH_PRIVATE_KEY -W {ip_launch_node}:22 -oStrictHostKeyChecking=no -oUserKnownHostsFile=/dev/null jh1_id@jh1_ip" micjpat2@{ip_launch_node}' -o ControlPath=/runner/cp/e0bd1ddedb {launch_node} '/bin/sh -c '"'"'echo ~jh2_id && sleep 0'"'"''
<{launch_node}> (0, b'/home/users/jh2_id\n', b'')
<{launch_node}> ESTABLISH SSH CONNECTION FOR USER: jh2_id
<{launch_node}> SSH: EXEC ssh -C -o ControlMaster=auto -o ControlPersist=60s -o StrictHostKeyChecking=no -o KbdInteractiveAuthentication=no -o PreferredAuthentications=gssapi-with-mic,gssapi-keyex,hostbased,publickey -o PasswordAuthentication=no -o 'User="jh2_id"' -o ConnectTimeout=60 -oStrictHostKeyChecking=no -oUserKnownHostsFile=/dev/null '-oProxyCommand=ssh -i $JH2_SSH_PRIVATE_KEY -W %h:%p -oStrictHostKeyChecking=no -oUserKnownHostsFile=/dev/null -oProxyCommand="ssh -i $JH1_SSH_PRIVATE_KEY -W {ip_launch_node}:22 -oStrictHostKeyChecking=no -oUserKnownHostsFile=/dev/null jh1_id@jh1_ip" micjpat2@{ip_launch_node}' -o ControlPath=/runner/cp/e0bd1ddedb {launch_node} '/bin/sh -c '"'"'( umask 77 && mkdir -p "echo /home/users/jh2_id/.ansible/tmp"&& mkdir "echo /home/users/jh2_id/.ansible/tmp/ansible-tmp-1733284390.6682315-46-238404572987453" && echo ansible-tmp-1733284390.6682315-46-238404572987453="echo /home/users/jh2_id/.ansible/tmp/ansible-tmp-1733284390.6682315-46-238404572987453" ) && sleep 0'"'"''
<{launch_node}> (0, b'ansible-tmp-1733284390.6682315-46-238404572987453=/home/users/jh2_id/.ansible/tmp/ansible-tmp-1733284390.6682315-46-238404572987453\n', b'')
Using module file /usr/lib/python3.8/site-packages/ansible/modules/cloud/vmware/vmware_guest_snapshot.py
<{launch_node}> PUT /home/runner/.ansible/tmp/ansible-local-20hvujv_sd/tmpn4d535xa TO /home/users/jh2_id/.ansible/tmp/ansible-tmp-1733284390.6682315-46-238404572987453/AnsiballZ_vmware_guest_snapshot.py
<{launch_node}> SSH: EXEC scp -C -o ControlMaster=auto -o ControlPersist=60s -o StrictHostKeyChecking=no -o KbdInteractiveAuthentication=no -o PreferredAuthentications=gssapi-with-mic,gssapi-keyex,hostbased,publickey -o PasswordAuthentication=no -o 'User="jh2_id"' -o ConnectTimeout=60 -oStrictHostKeyChecking=no -oUserKnownHostsFile=/dev/null '-oProxyCommand=ssh -i $JH2_SSH_PRIVATE_KEY -W %h:%p -oStrictHostKeyChecking=no -oUserKnownHostsFile=/dev/null -oProxyCommand="ssh -i $JH1_SSH_PRIVATE_KEY -W {ip_launch_node}:22 -oStrictHostKeyChecking=no -oUserKnownHostsFile=/dev/null jh1_id@jh1_ip" micjpat2@{ip_launch_node}' -o ControlPath=/runner/cp/e0bd1ddedb /home/runner/.ansible/tmp/ansible-local-20hvujv_sd/tmpn4d535xa '[{launch_node}]:/home/users/jh2_id/.ansible/tmp/ansible-tmp-1733284390.6682315-46-238404572987453/AnsiballZ_vmware_guest_snapshot.py'
<{launch_node}> (0, b'', b'')
<{launch_node}> ESTABLISH SSH CONNECTION FOR USER: jh2_id
<{launch_node}> SSH: EXEC ssh -C -o ControlMaster=auto -o ControlPersist=60s -o StrictHostKeyChecking=no -o KbdInteractiveAuthentication=no -o PreferredAuthentications=gssapi-with-mic,gssapi-keyex,hostbased,publickey -o PasswordAuthentication=no -o 'User="jh2_id"' -o ConnectTimeout=60 -oStrictHostKeyChecking=no -oUserKnownHostsFile=/dev/null '-oProxyCommand=ssh -i $JH2_SSH_PRIVATE_KEY -W %h:%p -oStrictHostKeyChecking=no -oUserKnownHostsFile=/dev/null -oProxyCommand="ssh -i $JH1_SSH_PRIVATE_KEY -W {ip_launch_node}:22 -oStrictHostKeyChecking=no -oUserKnownHostsFile=/dev/null jh1_id@jh1_ip" micjpat2@{ip_launch_node}' -o ControlPath=/runner/cp/e0bd1ddedb {launch_node} '/bin/sh -c '"'"'chmod u+x /home/users/jh2_id/.ansible/tmp/ansible-tmp-1733284390.6682315-46-238404572987453/ /home/users/jh2_id/.ansible/tmp/ansible-tmp-1733284390.6682315-46-238404572987453/AnsiballZ_vmware_guest_snapshot.py && sleep 0'"'"''
<{launch_node}> (0, b'', b'')
<{launch_node}> ESTABLISH SSH CONNECTION FOR USER: jh2_id
<{launch_node}> SSH: EXEC ssh -C -o ControlMaster=auto -o ControlPersist=60s -o StrictHostKeyChecking=no -o KbdInteractiveAuthentication=no -o PreferredAuthentications=gssapi-with-mic,gssapi-keyex,hostbased,publickey -o PasswordAuthentication=no -o 'User="jh2_id"' -o ConnectTimeout=60 -oStrictHostKeyChecking=no -oUserKnownHostsFile=/dev/null '-oProxyCommand=ssh -i $JH2_SSH_PRIVATE_KEY -W %h:%p -oStrictHostKeyChecking=no -oUserKnownHostsFile=/dev/null -oProxyCommand="ssh -i $JH1_SSH_PRIVATE_KEY -W {ip_launch_node}:22 -oStrictHostKeyChecking=no -oUserKnownHostsFile=/dev/null jh1_id@jh1_ip" micjpat2@{ip_launch_node}' -o ControlPath=/runner/cp/e0bd1ddedb -tt {launch_node} '/bin/sh -c '"'"'/usr/libexec/platform-python /home/users/jh2_id/.ansible/tmp/ansible-tmp-1733284390.6682315-46-238404572987453/AnsiballZ_vmware_guest_snapshot.py && sleep 0'"'"''
<{launch_node}> (1, b'\r\n{"msg": "Unable to manage snapshots for non-existing VM vm_name", "failed": true, "invocation": {"module_args": {"hostname": "vcenter_name", "username": "Adgroup\\\\ILMT_Admin", "password": "VALUE_SPECIFIED_IN_NO_LOG_PARAMETER", "validate_certs": false, "datacenter": "", "folder": "", "name": "vm_name", "snapshot_name": "VM Snapshot 04/12/2024, 09:15:39", "state": "absent", "port": 443, "name_match": "first", "use_instance_uuid": false, "description": "", "quiesce": false, "memory_dump": false, "remove_children": false, "proxy_host": null, "proxy_port": null, "uuid": null, "moid": null, "new_snapshot_name": null, "new_description": null}}}\r\n', b'Shared connection to {launch_node} closed.\r\n')
<{launch_node}> Failed to connect to the host via ssh: Shared connection to {launch_node} closed.
<{launch_node}> ESTABLISH SSH CONNECTION FOR USER: jh2_id
<{launch_node}> SSH: EXEC ssh -C -o ControlMaster=auto -o ControlPersist=60s -o StrictHostKeyChecking=no -o KbdInteractiveAuthentication=no -o PreferredAuthentications=gssapi-with-mic,gssapi-keyex,hostbased,publickey -o PasswordAuthentication=no -o 'User="jh2_id"' -o ConnectTimeout=60 -oStrictHostKeyChecking=no -oUserKnownHostsFile=/dev/null '-oProxyCommand=ssh -i $JH2_SSH_PRIVATE_KEY -W %h:%p -oStrictHostKeyChecking=no -oUserKnownHostsFile=/dev/null -oProxyCommand="ssh -i $JH1_SSH_PRIVATE_KEY -W {ip_launch_node}:22 -oStrictHostKeyChecking=no -oUserKnownHostsFile=/dev/null jh1_id@jh1_ip" micjpat2@{ip_launch_node}' -o ControlPath=/runner/cp/e0bd1ddedb {launch_node} '/bin/sh -c '"'"'rm -f -r /home/users/jh2_id/.ansible/tmp/ansible-tmp-1733284390.6682315-46-238404572987453/ > /dev/null 2>&1 && sleep 0'"'"''
<{launch_node}> (0, b'', b'')
fatal: []: FAILED! => {
"changed": false,
"invocation": {
"module_args": {
"datacenter": "",
"description": "",
"folder": "",
"hostname": “vcenter_name”,
"memory_dump": false,
"moid": null,
"name": "vm_name",
"name_match": "first",
"new_description": null,
"new_snapshot_name": null,
"password": "VALUE_SPECIFIED_IN_NO_LOG_PARAMETER",
"port": 443,
"proxy_host": null,
"proxy_port": null,
"quiesce": false,
"remove_children": false,
"snapshot_name": "VM Snapshot 04/12/2024, 09:15:39",
"state": "absent",
"use_instance_uuid": false,
"username": “user_id”,
"uuid": null,
"validate_certs": false
}
},
"msg": "Unable to manage snapshots for non-existing VM vm_name”
}
...ignoring
META: ran handlers
META: ran handlers

@Rakesh2904
Copy link
Author

Please note I'm using AAP to launch my ansible playbook not the CLI from control node

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

No branches or pull requests

2 participants