community.vmware.vmware_guest_powerstate 模块 – 管理 vCenter 中虚拟机的电源状态

注意

此模块是 community.vmware 集合 (版本 5.2.0) 的一部分。

如果您使用的是 ansible 包,则可能已安装此集合。它不包含在 ansible-core 中。要检查它是否已安装,请运行 ansible-galaxy collection list

要安装它,请使用: ansible-galaxy collection install community.vmware

要在 playbook 中使用它,请指定: community.vmware.vmware_guest_powerstate

概要

  • 启动/关闭/重启虚拟机。

参数

参数

注释

answer

列表 / 元素=字典

要回答的问题列表,如果在等待任务完成时出现一个或多个问题。

一些常见用途是允许更改即使已锁定的 CD-ROM,或回答有关虚拟机是复制还是移动的问题。

如果使用 state=powered-on,则可以使用。

question

字符串 / 必需

消息 ID,例如 msg.uuid.altered

response

字符串 / 必需

选择键,例如 button.uuid.copiedTheVM

datacenter

字符串

您想要操作电源的虚拟机所在的 Datacenter。

默认值: "ha-datacenter"

folder

字符串

目标文件夹,查找现有访客的绝对或相对路径。

文件夹应包含 Datacenter。ESX 的 Datacenter 是 ha-datacenter

示例

folder: /ha-datacenter/vm

folder: ha-datacenter/vm

folder: /datacenter1/vm

folder: datacenter1/vm

folder: /datacenter1/vm/folder1

folder: datacenter1/vm/folder1

folder: /folder1/datacenter1/vm

folder: folder1/datacenter1/vm

folder: /folder1/datacenter1/vm/folder2

force

布尔值

忽略警告并完成操作。

强制虚拟机状态时,此参数很有用。

选项

  • false ← (默认)

  • true

hostname

字符串

vSphere vCenter 或 ESXi 服务器的主机名或 IP 地址。

如果任务中未指定该值,则将改用环境变量 VMWARE_HOST 的值。

moid

字符串

如果已知要管理的实例的托管对象 ID,则这是一个仅在单个 vCenter 实例中唯一的标识符。

如果未提供 nameuuid,则需要此参数。

name

字符串

要使用的虚拟机的名称。

vCenter 中的虚拟机名称不一定是唯一的,这可能会有问题,请参见 name_match

name_match

字符串

如果有多个虚拟机与名称匹配,则使用找到的第一个或最后一个。

选项

  • "first" ← (默认)

  • "last"

password

别名:pass、pwd

字符串

vSphere vCenter 或 ESXi 服务器的密码。

如果任务中未指定该值,则将改用环境变量 VMWARE_PASSWORD 的值。

port

整数

vSphere vCenter 或 ESXi 服务器的端口号。

如果任务中未指定该值,则将改用环境变量 VMWARE_PORT 的值。

默认值: 443

proxy_host

字符串

接收所有 HTTPS 请求并转发它们的代理服务器地址。

格式为主机名或 IP 地址。

如果任务中未指定此值,则将使用环境变量 VMWARE_PROXY_HOST 的值。

proxy_port

整数

接收所有 HTTPS 请求并转发它们的 HTTP 代理服务器端口。

如果任务中未指定此值,则将使用环境变量 VMWARE_PROXY_PORT 的值。

schedule_task_description

字符串

计划任务的描述。

仅当指定了 scheduled_at 时有效。

schedule_task_enabled

布尔值

指示计划任务是启用还是禁用的标志。

选项

  • false

  • true ← (默认)

schedule_task_name

字符串

计划任务的名称。

仅当指定了 scheduled_at 时有效。

scheduled_at

字符串

需要执行指定任务的日期和时间,以字符串格式表示。

日期和时间的所需格式:'dd/mm/yyyy hh:mm'。

计划任务需要 vCenter 服务器。独立的 ESXi 服务器不支持此选项。

state

字符串

设置虚拟机的状态。

选项

  • "powered-off"

  • "powered-on"

  • "reboot-guest"

  • "restarted"

  • "shutdown-guest"

  • "suspended"

  • "present" ← (默认)

state_change_timeout

整数

如果 state=shutdown-guest,默认情况下,模块将在发送关机信号后立即返回。

如果将此参数设置为正整数,则模块将等待虚拟机达到 powered-off 状态。

该值设置模块等待状态更改的超时时间(以秒为单位)。

默认值: 0

use_instance_uuid

布尔值

是否使用 VMware 实例 UUID 而不是 BIOS UUID。

选项

  • false ← (默认)

  • true

用户名

别名:admin,user

字符串

vSphere vCenter 或 ESXi 服务器的用户名。

如果任务中未指定此值,则将使用环境变量 VMWARE_USER 的值。

uuid

字符串

要管理的实例的 UUID(如果已知),这是 VMware 的唯一标识符。

如果未提供 namemoid,则需要此参数。

validate_certs

布尔值

允许在 SSL 证书无效时连接。当证书不受信任时,设置为 false

如果任务中未指定此值,则将使用环境变量 VMWARE_VALIDATE_CERTS 的值。

选项

  • false

  • true ← (默认)

注释

注意

  • 所有模块都需要 API 写入访问权限,因此不受免费 ESXi 许可证的支持。

  • 所有变量和 VMware 对象名称都区分大小写。

示例

- name: Set the state of a virtual machine to poweroff
  community.vmware.vmware_guest_powerstate:
    hostname: "{{ vcenter_hostname }}"
    username: "{{ vcenter_username }}"
    password: "{{ vcenter_password }}"
    folder: "/{{ datacenter_name }}/vm/my_folder"
    name: "{{ guest_name }}"
    state: powered-off
  delegate_to: localhost
  register: deploy

- name: Set the state of a virtual machine to poweron using MoID
  community.vmware.vmware_guest_powerstate:
    hostname: "{{ vcenter_hostname }}"
    username: "{{ vcenter_username }}"
    password: "{{ vcenter_password }}"
    folder: "/{{ datacenter_name }}/vm/my_folder"
    moid: vm-42
    state: powered-on
  delegate_to: localhost
  register: deploy

- name: Set the state of a virtual machine to poweroff at given scheduled time
  community.vmware.vmware_guest_powerstate:
    hostname: "{{ vcenter_hostname }}"
    username: "{{ vcenter_username }}"
    password: "{{ vcenter_password }}"
    folder: "/{{ datacenter_name }}/vm/my_folder"
    name: "{{ guest_name }}"
    state: powered-off
    scheduled_at: "09/01/2018 10:18"
    schedule_task_name: "task_00001"
    schedule_task_description: "Sample task to poweroff VM"
    schedule_task_enabled: true
  delegate_to: localhost
  register: deploy_at_schedule_datetime

- name: Wait for the virtual machine to shutdown
  community.vmware.vmware_guest_powerstate:
    hostname: "{{ vcenter_hostname }}"
    username: "{{ vcenter_username }}"
    password: "{{ vcenter_password }}"
    name: "{{ guest_name }}"
    state: shutdown-guest
    state_change_timeout: 200
  delegate_to: localhost
  register: deploy

- name: Automatically answer if a question locked a virtual machine
  block:
    - name: Power on a virtual machine without the answer param
      community.vmware.vmware_guest_powerstate:
        hostname: "{{ esxi_hostname }}"
        username: "{{ esxi_username }}"
        password: "{{ esxi_password }}"
        validate_certs: false
        folder: "{{ f1 }}"
        name: "{{ vm_name }}"
        state: powered-on
  rescue:
    - name: Power on a virtual machine with the answer param
      community.vmware.vmware_guest_powerstate:
        hostname: "{{ esxi_hostname }}"
        username: "{{ esxi_username }}"
        password: "{{ esxi_password }}"
        validate_certs: false
        folder: "{{ f1 }}"
        name: "{{ vm_name }}"
        answer:
          - question: "msg.uuid.altered"
            response: "button.uuid.copiedTheVM"
        state: powered-on

作者

  • Abhijeet Kasurde (@Akasurde)