community.vmware.vcenter_folder 模块 – 管理给定数据中心的文件夹

注意

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

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

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

要在 Playbook 中使用它,请指定:community.vmware.vcenter_folder

概要

  • 此模块可用于在给定的数据中心上创建、删除、移动和重命名文件夹。

  • 此模块仅支持 vCenter。

参数

参数

注释

datacenter

别名:datacenter_name

字符串 / 必需

数据中心的名称。

folder_name

字符串 / 必需

要管理的文件夹的名称。

文件夹名称应少于 80 个字符。这是一个 VMware 限制。

folder_type

字符串

这是文件夹的类型。

如果设置为 vm,则会在数据中心下创建“VM 和模板文件夹”。

如果设置为 host,则会在数据中心下创建“主机和集群文件夹”。

如果设置为 datastore,则会在数据中心下创建“存储文件夹”。

如果设置为 network,则会在数据中心下创建“网络文件夹”。

如果未设置 state=absent 且未设置 parent_folder,则此参数为必需。

选项

  • "datastore"

  • "host"

  • "network"

  • "vm" ←(默认)

hostname

字符串

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

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

parent_folder

字符串

要在其下创建新文件夹的父文件夹的名称。

如果用户想在“/DC0/vm/vm_folder”下创建一个文件夹,则此值将为“vm_folder”。

如果用户想在“/DC0/vm/folder1/folder2”下创建一个文件夹,则此值将为“folder1/folder2”。

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 且没有父文件夹参数,则会创建具有 folder_type 的文件夹。

如果设置为 present 且带有父文件夹参数,则会在父文件夹下创建文件夹。folder_type 将被忽略。

如果设置为 absent,则会注销并销毁该文件夹。

选项

  • "present" ← (默认)

  • "absent"

username

别名: admin, user

字符串

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

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

validate_certs

布尔值

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

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

选项

  • false

  • true ← (默认)

备注

注意

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

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

示例

- name: Create a VM folder on given datacenter
  community.vmware.vcenter_folder:
    hostname: '{{ vcenter_hostname }}'
    username: '{{ vcenter_username }}'
    password: '{{ vcenter_password }}'
    datacenter_name: datacenter_name
    folder_name: sample_vm_folder
    folder_type: vm
    state: present
  register: vm_folder_creation_result
  delegate_to: localhost

- name: Create a datastore folder on given datacenter
  community.vmware.vcenter_folder:
    hostname: '{{ vcenter_hostname }}'
    username: '{{ vcenter_username }}'
    password: '{{ vcenter_password }}'
    datacenter_name: datacenter_name
    folder_name: sample_datastore_folder
    folder_type: datastore
    state: present
  register: datastore_folder_creation_result
  delegate_to: localhost

- name: Create a sub folder under VM folder on given datacenter
  community.vmware.vcenter_folder:
    hostname: '{{ vcenter_hostname }}'
    username: '{{ vcenter_username }}'
    password: '{{ vcenter_password }}'
    datacenter_name: datacenter_name
    folder_name: sample_sub_folder
    parent_folder: vm_folder
    state: present
  register: sub_folder_creation_result
  delegate_to: localhost

- name: Delete a VM folder on given datacenter
  community.vmware.vcenter_folder:
    hostname: '{{ vcenter_hostname }}'
    username: '{{ vcenter_username }}'
    password: '{{ vcenter_password }}'
    datacenter_name: datacenter_name
    folder_name: sample_vm_folder
    folder_type: vm
    state: absent
  register: vm_folder_deletion_result
  delegate_to: localhost

返回值

通用返回值记录在这里,以下是此模块独有的字段

描述

result

复杂

关于新文件夹的详细信息

返回: 成功时

msg

字符串

描述结果的字符串

返回: 成功时

path

字符串

新文件夹的完整路径

返回: 成功时

作者

  • Abhijeet Kasurde (@Akasurde)

  • Christian Kotte (@ckotte)

  • Jan Meerkamp (@meerkampdvv)