community.vmware.vmware_vm_vm_drs_rule 模块 – 配置给定集群中虚拟机的 VMware DRS 亲和性规则

注意

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

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

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

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

概要

  • 此模块可用于配置给定集群中虚拟机的 VMware DRS 亲和性规则。

参数

参数

注释

affinity_rule

布尔值

如果设置为 true,则 DRS 规则将为亲和性规则。

如果设置为 false,则 DRS 规则将为反亲和性规则。

仅在 state=present 时有效。

选项

  • false

  • true ← (默认)

cluster_name

字符串 / 必需

DRS 规则的虚拟机所在的所需集群名称。

datacenter

字符串

在 community.vmware 4.6.0 中添加

搜索给定集群的数据中心。如果未设置,则使用遇到的第一个具有 cluster_name 的集群。

drs_rule_name

字符串 / 必需

要管理的 DRS 规则的名称。

enabled

布尔值

如果设置为 true,则将启用 DRS 规则。

仅在 state=present 时有效。

选项

  • false ← (默认)

  • true

hostname

字符串

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

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

mandatory

布尔值

如果设置为 true,则 DRS 规则将为强制性规则。

仅在 state=present 时有效。

选项

  • false ← (默认)

  • true

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 的值。

state

字符串

如果设置为 present,则在不存在的情况下创建 DRS 规则。

如果设置为 present,则 DRS 规则已存在,它将更新为给定的配置。

如果设置为 absent,则如果存在 DRS 规则,则将其删除。

选项

  • "present" ← (默认)

  • "absent"

username

别名:admin, user

字符串

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

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

validate_certs

布尔值

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

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

选项

  • false

  • true ← (默认)

vms

列表 / 元素=字符串

需要应用 DRS 规则的虚拟机名称列表。

state=present 时为必填项。

注意

注意

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

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

示例

- name: Create DRS Affinity Rule for VM-VM
  community.vmware.vmware_vm_vm_drs_rule:
    hostname: "{{ esxi_server }}"
    username: "{{ esxi_username }}"
    password: "{{ esxi_password }}"
    datacenter: "{{ datacenter }}"
    cluster_name: "{{ cluster_name }}"
    vms:
        - vm1
        - vm2
    drs_rule_name: vm1-vm2-affinity-rule-001
    enabled: true
    mandatory: true
    affinity_rule: true
  delegate_to: localhost

- name: Create DRS Anti-Affinity Rule for VM-VM
  community.vmware.vmware_vm_vm_drs_rule:
    hostname: "{{ esxi_server }}"
    username: "{{ esxi_username }}"
    password: "{{ esxi_password }}"
    datacenter: "{{ datacenter }}"
    cluster_name: "{{ cluster_name }}"
    enabled: true
    vms:
        - vm1
        - vm2
    drs_rule_name: vm1-vm2-affinity-rule-001
    mandatory: true
    affinity_rule: false
  delegate_to: localhost

- name: Delete DRS Affinity Rule for VM-VM
  community.vmware.vmware_vm_vm_drs_rule:
    hostname: "{{ esxi_server }}"
    username: "{{ esxi_username }}"
    password: "{{ esxi_password }}"
    datacenter: "{{ datacenter }}"
    cluster_name: "{{ cluster_name }}"
    drs_rule_name: vm1-vm2-affinity-rule-001
    state: absent
  delegate_to: localhost

返回值

常见返回值已在此处记录 此处,以下是此模块特有的字段

描述

结果

字典

关于 DRS VM 和 VM 规则的元数据

返回值: 当 state 为 present 时

示例: {"rule_enabled": false, "rule_key": 20, "rule_mandatory": true, "rule_name": "drs_rule_0014", "rule_uuid": "525f3bc0-253f-825a-418e-2ec93bffc9ae", "rule_vms": ["VM_65", "VM_146"]}

作者

  • Abhijeet Kasurde (@Akasurde)