community.zabbix.zabbix_itemprototype 模块 – 创建/删除 Zabbix 项目原型
注意
此模块是 community.zabbix 集合 (版本 3.2.0) 的一部分。
如果您正在使用 ansible
包,则可能已安装此集合。它不包含在 ansible-core
中。要检查它是否已安装,请运行 ansible-galaxy collection list
。
要安装它,请使用: ansible-galaxy collection install community.zabbix
。您需要其他要求才能使用此模块,请参阅 需求 以了解详情。
要在 playbook 中使用它,请指定: community.zabbix.zabbix_itemprototype
。
概要
如果项目原型不存在,则创建它们。
如果项目原型存在,则删除它们。
需求
在执行此模块的主机上需要以下要求。
python >= 2.6
参数
参数 |
注释 |
---|---|
项目所属的 LLD 规则的名称。 |
|
要向其添加项目原型的宿主机名称。 当不使用 *template_name* 时必需。 与 *template_name* 互斥。 |
|
基本认证密码 |
|
基本认证用户名 |
|
要创建或删除的项目原型的名称。 |
|
用于创建/更新项目原型的参数。 如果 state 为“present”,则必需。 参数定义在 https://www.zabbix.com/documentation/current/en/manual/api/reference/itemprototype/object 另外支持的参数如下 |
|
项目原型的状态。 覆盖 API 文档中的“status” 选项
|
|
项目原型的更新间隔。 API 文档中“delay”的别名 |
|
项目原型键。 API 文档中“key_”的别名 |
|
作为当前项目主项目的项目 覆盖 API 文档中的“master_itemid” |
|
主项目所属的发现规则的名称 |
|
主项目所属的宿主机名称 当不使用 *template_name* 时必需。 与 *template_name* 互斥。 |
|
主项目的名称 |
|
主项目所属的模板名称。 当不使用 *host_name* 时必需。 与 *host_name* 互斥。 |
|
预处理步骤失败时使用的操作类型。 选项
|
|
预处理选项类型。 选项
|
|
项目原型的状态。 选项
|
|
项目原型的类型。 如果 state 为“present”,则必需。 选项
|
|
项目原型的信息类型。 如果 state 为“present”,则必需。 选项
|
|
创建或删除项目原型。 选项
|
|
要向其添加项目原型的模板名称。 当不使用 *host_name* 时必需。 与 *host_name* 互斥。 |
示例
# If you want to use Username and Password to be authenticated by Zabbix Server
- name: Set credentials to access Zabbix Server API
ansible.builtin.set_fact:
ansible_user: Admin
ansible_httpapi_pass: zabbix
# If you want to use API token to be authenticated by Zabbix Server
# https://www.zabbix.com/documentation/current/en/manual/web_interface/frontend_sections/administration/general#api-tokens
- name: Set API token
ansible.builtin.set_fact:
ansible_zabbix_auth_key: 8ec0d52432c15c91fcafe9888500cf9a607f44091ab554dbee860f6b44fac895
# Create item prototype on example_host using example_rule
- name: create item prototype
# set task level variables as we change ansible_connection plugin here
vars:
ansible_network_os: community.zabbix.zabbix
ansible_connection: httpapi
ansible_httpapi_port: 443
ansible_httpapi_use_ssl: true
ansible_httpapi_validate_certs: false
ansible_zabbix_url_path: 'zabbixeu' # If Zabbix WebUI runs on non-default (zabbix) path ,e.g. http://<FQDN>/zabbixeu
ansible_host: zabbix-example-fqdn.org
community.zabbix.zabbix_itemprototype:
name: '{% raw %}{#FSNAME}:Used space{% endraw %}'
discoveryrule_name: example_rule
host_name: example_host
params:
type: zabbix_agent
key: "{% raw %}vfs.fs.size[{#FSNAME},used]{% endraw %}"
value_type: numeric_unsigned
interval: 1m
state: present
# Create item prototype on example_template using example_rule
- name: create item prototype
# set task level variables as we change ansible_connection plugin here
vars:
ansible_network_os: community.zabbix.zabbix
ansible_connection: httpapi
ansible_httpapi_port: 443
ansible_httpapi_use_ssl: true
ansible_httpapi_validate_certs: false
ansible_zabbix_url_path: 'zabbixeu' # If Zabbix WebUI runs on non-default (zabbix) path ,e.g. http://<FQDN>/zabbixeu
ansible_host: zabbix-example-fqdn.org
community.zabbix.zabbix_itemprototype:
name: '{% raw %}{#FSNAME}:Used space{% endraw %}'
discoveryrule_name: example_rule
template_name: example_template
params:
type: zabbix_agent
key: "{% raw %}vfs.fs.size[{#FSNAME},used]{% endraw %}"
value_type: numeric_unsigned
interval: 1m
state: present
# Add tags to the existing Zabbix item prototype
- name: update item prototype
# set task level variables as we change ansible_connection plugin here
vars:
ansible_network_os: community.zabbix.zabbix
ansible_connection: httpapi
ansible_httpapi_port: 443
ansible_httpapi_use_ssl: true
ansible_httpapi_validate_certs: false
ansible_zabbix_url_path: 'zabbixeu' # If Zabbix WebUI runs on non-default (zabbix) path ,e.g. http://<FQDN>/zabbixeu
ansible_host: zabbix-example-fqdn.org
community.zabbix.zabbix_itemprototype:
name: '{% raw %}{#FSNAME}:Used space{% endraw %}'
discoveryrule_name: example_rule
template_name: example_template
params:
type: zabbix_agent
key: "{% raw %}vfs.fs.size[{#FSNAME},used]{% endraw %}"
value_type: numeric_unsigned
interval: 1m
tags:
- tag: class
value: application
state: present
- name: create dependent item
# set task level variables as we change ansible_connection plugin here
vars:
ansible_network_os: community.zabbix.zabbix
ansible_connection: httpapi
ansible_httpapi_port: 443
ansible_httpapi_use_ssl: true
ansible_httpapi_validate_certs: false
ansible_zabbix_url_path: 'zabbixeu' # If Zabbix WebUI runs on non-default (zabbix) path ,e.g. http://<FQDN>/zabbixeu
ansible_host: zabbix-example-fqdn.org
community.zabbix.zabbix_itemprototype:
name: '{% raw %}{#FSNAME}:example_depend_item_prototype{% endraw %}'
discoveryrule_name: example_rule
host_name: example_host
params:
type: dependent_item
key: '{% raw %}vfs.fs.size.half[{#FSNAME}]{% endraw %}'
value_type: numeric_float
units: B
master_item:
item_name: '{% raw %}{#FSNAME}:example_item_prototype{% endraw %}'
discoveryrule_name: example_rule
host_name: example_host
preprocessing:
- type: javascript
params: 'return value / 2;'
error_handler: zabbix_server
state: present
- name: Delete Zabbix item prototype
# set task level variables as we change ansible_connection plugin here
vars:
ansible_network_os: community.zabbix.zabbix
ansible_connection: httpapi
ansible_httpapi_port: 443
ansible_httpapi_use_ssl: true
ansible_httpapi_validate_certs: false
ansible_zabbix_url_path: 'zabbixeu' # If Zabbix WebUI runs on non-default (zabbix) path ,e.g. http://<FQDN>/zabbixeu
ansible_host: zabbix-example-fqdn.org
community.zabbix.zabbix_itemprototype:
name: '{% raw %}{#FSNAME}:Used space{% endraw %}'
discoveryrule_name: example_rule
template_name: example_template
state: absent