community.zabbix.zabbix_service module – Create/update/delete Zabbix service
Note
This module is part of the community.zabbix collection (version 1.7.0).
You might already have this collection installed if you are using the ansible
package.
It is not included in ansible-core
.
To check whether it is installed, run ansible-galaxy collection list
.
To install it, use: ansible-galaxy collection install community.zabbix
.
To use it in a playbook, specify: community.zabbix.zabbix_service
.
Requirements
The below requirements are needed on the host that executes this module.
python >= 2.7
zabbix-api >= 0.5.4
Parameters
Parameter |
Comments |
---|---|
Algorithm used to calculate the sla with < Zabbix 6.0
Status calculation rule. Only applicable if child services exists with >= Zabbix 6.0
Choices:
|
|
If yes, calculate the SLA value for this service, showsla in Zabbix API With >= Zabbix 6.0 this field is removed from the API and is dropped silently by module. Choices:
|
|
Child services to be linked to the service. New field with >= Zabbix 6.0. |
|
Description of the service. New field with >= Zabbix 6.0. |
|
Basic Auth password |
|
Basic Auth login |
|
Zabbix user password. If not set the environment variable |
|
Zabbix user name. If not set the environment variable |
|
Name of Zabbix service |
|
Name of Zabbix service parent With >= Zabbix 6.0 this field is removed from the API and is dropped silently by module. |
|
Parent services to be linked to the service. New field with >= Zabbix 6.0. |
|
Problem tags to be created for the service. New field with >= Zabbix 6.0. |
|
Mapping condition operator.
Choices:
|
|
Problem tag name. |
|
Problem tag value. Default: “” |
|
Status propagation value. Must be set together with propagation_rule. New field with >= Zabbix 6.0.
Required with Default: “as_is” |
|
Status propagation value. Must be set together with propagation_rule. New field with >= Zabbix 6.0. Possible values when propagation_rule=as_is or ignore:
Possible values when propagation_rule=increase or decrease:
Possible values when propagation_rule=fixed:
Required with |
|
URL of Zabbix server, with protocol (http or https). If not set the environment variable |
|
Sla value (i.e 99.99), goodsla in Zabbix API With >= Zabbix 6.0 this field is removed from the API and is dropped silently by module. |
|
Position of the service used for sorting. |
|
State: present - create/update service; absent - delete service. Choices:
|
|
Status rules for the service. New field with >= Zabbix 6.0. |
|
Limit status.
|
|
Limit value: N, N% or W Possible values: 1-100000 for N and W, 1-100 for N% |
|
New status value.
|
|
Condition for setting (New status) status.
|
|
Service tags to be created for the service. New field with >= Zabbix 6.0. |
|
Service tag name. |
|
Service tag value. |
|
The timeout of API request (seconds). Default: 10 |
|
Name of host linked to the service. With >= Zabbix 6.0 this field is removed from the API and is dropped silently by module. |
|
Name of trigger linked to the service. With >= Zabbix 6.0 this field is removed from the API and is dropped silently by module. |
|
If set to False, SSL certificates will not be validated. This should only be used on personally controlled sites using self-signed certificates. If not set the environment variable Choices:
|
|
Service weight. New field with >= Zabbix 6.0. Default: “0” |
Notes
Note
If you use login_password=zabbix, the word “zabbix” is replaced by “****” in all module output, because login_password uses
no_log
. See this FAQ for more information.
Examples
---
# Creates a new Zabbix service with Zabbix < 6.0
- name: Manage services
community.zabbix.zabbix_service:
server_url: "http://zabbix.example.com/zabbix/"
login_user: username
login_password: password
name: apache2 service
sla: 99.99
calculate_sla: yes
algorithm: one_child
trigger_name: apache2 service status
trigger_host: webserver01
state: present
# Creates a new Zabbix service with Zabbix >= 6.0
- name: Create Zabbix service monitoring Apache2 in DCs in Toronto area
community.zabbix.zabbix_service:
server_url: "zabbix.example.com/zabbix/"
login_user: username
login_password: password
name: 'apache2 service Toronto'
description: Apache2 services in Toronto area
sortorder: 0
propagation_rule: increase
propagation_value: warning
weight: 1
state: present
tags:
- tag: zabbix_service
value: apache2
- tag: area
value: Toronto
problem_tags:
- tag: service_name
value: httpd
- tag: area
operator: like
value: toronto
status_rules:
- type: at_least_n_child_services_have_status_or_above
limit_value: 4242
limit_status: ok
new_status: average
- name: Create Zabbix service monitoring all Apache2 services
community.zabbix.zabbix_service:
server_url: "zabbix.example.com/zabbix/"
login_user: username
login_password: password
name: apache2 service
description: Apache2 services
tags:
- tag: zabbix_service
value: apache2
- tag: area
value: global
children:
- 'apache2 service Toronto'
Authors
Emmanuel Riviere (@emriver)
Evgeny Yurchenko (@BGmot)