community.general.dimensiondata_vlan 模块 – 在 Cloud Control 网络域中管理 VLAN

注意

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

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

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

要在 playbook 中使用它,请指定:community.general.dimensiondata_vlan

概要

  • 在 Cloud Control 网络域中管理 VLAN。

参数

参数

注释

allow_expand

布尔值

如果模块参数指定的网络大于 VLAN 当前拥有的网络,则允许扩展目标 VLAN 的网络。

如果为 false,则模块在此条件下将失败。

这旨在防止意外扩展 VLAN 的网络(因为此操作不可逆)。

选项

  • false ← (默认)

  • true

description

字符串

VLAN 的描述。

默认值: ""

location

字符串 / 必填

目标数据中心。

mcp_password

字符串

用于向 CloudControl API 进行身份验证的密码。

如果未指定,将回退到环境变量中的 MCP_PASSWORD~/.dimensiondata

如果指定了 mcp_user,则需要此参数。

mcp_user

字符串

用于向 CloudControl API 进行身份验证的用户名。

如果未指定,将回退到环境变量中的 MCP_USER~/.dimensiondata

name

字符串 / 必填

目标 VLAN 的名称。

network_domain

字符串 / 必填

目标网络域的 ID 或名称。

private_ipv4_base_address

字符串

VLAN 的 IPv4 网络的基本地址(例如 192.168.1.0)。

默认值: ""

private_ipv4_prefix_size

整数

IPv4 地址空间的大小,例如 24。

如果指定了 private_ipv4_base_address,则需要此参数。

默认值: 0

region

字符串

目标区域。

区域在 Apache libcloud 项目 [libcloud/common/dimensiondata.py] 中定义。

它们也列在 https://libcloud.readthedocs.io/en/latest/compute/drivers/dimensiondata.html 中。

请注意,默认值 na 代表“北美”。

模块在区域选择前添加 dd-

默认值: "na"

state

字符串

目标 VLAN 的所需状态。

readonly 确保状态仅读取,不修改(如果资源不存在,模块将失败)。

选项

  • "present" ← (默认)

  • "absent"

  • "readonly"

validate_certs

布尔值

如果为 false,则不会验证 SSL 证书。

这仅应在使用自签名证书的 CloudControl API 的私有实例上使用。

选项

  • false

  • true ← (默认)

wait

布尔值

我们是否应该等待任务完成才能继续下一个任务。

选项

  • false ← (默认)

  • true

wait_poll_interval

整数

等待任务完成之间检查的时间量(以秒为单位)。

仅当 wait=true 时适用。

默认值: 2

wait_time

整数

等待任务完成的最大时间量(以秒为单位)。

仅当 wait=true 时适用。

默认值: 600

属性

属性

支持

描述

check_mode

支持:不支持

可以在 check_mode 下运行并返回更改状态预测,而无需修改目标。

diff_mode

支持:不支持

在差异模式下,将返回有关已更改内容(或可能需要在 check_mode 中更改的内容)的详细信息。

示例

- name: Add or update VLAN
  community.general.dimensiondata_vlan:
    region: na
    location: NA5
    network_domain: test_network
    name: my_vlan1
    description: A test VLAN
    private_ipv4_base_address: 192.168.23.0
    private_ipv4_prefix_size: 24
    state: present
    wait: true

- name: Read / get VLAN details
  community.general.dimensiondata_vlan:
    region: na
    location: NA5
    network_domain: test_network
    name: my_vlan1
    state: readonly
    wait: true

- name: Delete a VLAN
  community.general.dimensiondata_vlan:
    region: na
    location: NA5
    network_domain: test_network
    name: my_vlan_1
    state: absent
    wait: true

返回值

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

描述

vlan

复杂

描述 VLAN 的字典。

返回:state=present 成功时

description

字符串

VLAN 描述。

返回:成功

示例: "My VLAN description"

id

字符串

VLAN ID。

返回:成功

示例: "aaaaa000-a000-4050-a215-2808934ccccc"

location

字符串

数据中心位置。

返回:成功

示例: "NA3"

name

字符串

VLAN 名称。

返回:成功

示例: "My VLAN"

private_ipv4_base_address

字符串

VLAN 私有 IPV4 网络的基本地址。

返回:成功

示例: "192.168.23.0"

private_ipv4_gateway_address

字符串

VLAN 私有 IPV4 网络的网关地址。

返回:成功

示例: "192.168.23.1"

private_ipv4_prefix_size

整数

VLAN 私有 IPV4 网络的前缀大小。

返回:成功

示例: 24

private_ipv6_base_address

字符串

VLAN IPV6 网络的基本地址。

返回:成功

示例: "2402:9900:111:1195:0:0:0:0"

private_ipv6_gateway_address

字符串

VLAN IPV6 网络的网关地址。

返回:成功

示例: "2402:9900:111:1195:0:0:0:1"

private_ipv6_prefix_size

整数

VLAN IPV6 网络的前缀大小。

返回:成功

示例: 64

状态

字符串

VLAN 状态。

返回:成功

示例: "NORMAL"

作者

  • Adam Friedman (@tintoy)