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

字符串

要操作电源的虚拟机所在的数据中心。

默认: "ha-datacenter"

folder

字符串

目标文件夹,用于查找现有虚拟机的绝对或相对路径。

该文件夹应包含数据中心。ESX 的数据中心是 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,则默认情况下,模块会在发送关闭信号后立即返回。

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

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

默认值: 0

use_instance_uuid

布尔值

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

选择

  • false ← (默认)

  • true

username

别名: 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)