mirror of https://github.com/Icinga/icinga2.git
Documentation: Update migration, add agent based dependency example.
Refs #6225 Fixes #6272 Fixes #6271
This commit is contained in:
parent
c4fa6e2ea2
commit
2027b301a7
|
@ -920,6 +920,52 @@ be suppressed. This is achieved by setting the `disable_checks` attribute to `tr
|
||||||
assign where host.name != "dsl-router"
|
assign where host.name != "dsl-router"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Another classic example are agent based checks. You would define a health check
|
||||||
|
for the agent daemon responding to your requests, and make all other services
|
||||||
|
querying that daemon depend on that health check.
|
||||||
|
|
||||||
|
The following configuration defines two nrpe based service checks `nrpe-load`
|
||||||
|
and `nrpe-disk` applied to the `nrpe-server`. The health check is defined as
|
||||||
|
`nrpe-health` service.
|
||||||
|
|
||||||
|
apply Service "nrpe-health" {
|
||||||
|
import "generic-service"
|
||||||
|
check_command = "nrpe"
|
||||||
|
assign where match("nrpe-*", host.name)
|
||||||
|
}
|
||||||
|
|
||||||
|
apply Service "nrpe-load" {
|
||||||
|
import "generic-service"
|
||||||
|
check_command = "nrpe"
|
||||||
|
vars.nrpe_command = "check_load"
|
||||||
|
assign where match("nrpe-*", host.name)
|
||||||
|
}
|
||||||
|
|
||||||
|
apply Service "nrpe-disk" {
|
||||||
|
import "generic-service"
|
||||||
|
check_command = "nrpe"
|
||||||
|
vars.nrpe_command = "check_disk"
|
||||||
|
assign where match("nrpe-*", host.name)
|
||||||
|
}
|
||||||
|
|
||||||
|
object Host "nrpe-server" {
|
||||||
|
import "generic-host"
|
||||||
|
address = "192.168.1.5",
|
||||||
|
}
|
||||||
|
|
||||||
|
apply Dependency "disable-nrpe-checks" to Service {
|
||||||
|
parent_service_name = "nrpe-health"
|
||||||
|
|
||||||
|
states = [ Warning, Critical, Unknown ]
|
||||||
|
disable_checks = true
|
||||||
|
disable_notifications = true
|
||||||
|
assign where match("nrpe-*", host.name)
|
||||||
|
ignore where service.name == "nrpe-health"
|
||||||
|
}
|
||||||
|
|
||||||
|
The `disable-nrpe-checks` dependency is applied to all services
|
||||||
|
on the `nrpe-service` host but not the `nrpe-health` service itself.
|
||||||
|
|
||||||
|
|
||||||
## <a id="custom-attributes"></a> Custom Attributes
|
## <a id="custom-attributes"></a> Custom Attributes
|
||||||
|
|
||||||
|
|
|
@ -1970,6 +1970,22 @@ by_ssh_warn | **Optional.** The warning threshold.
|
||||||
by_ssh_crit | **Optional.** The critical threshold.
|
by_ssh_crit | **Optional.** The critical threshold.
|
||||||
by_ssh_timeout | **Optional.** The timeout in seconds.
|
by_ssh_timeout | **Optional.** The timeout in seconds.
|
||||||
|
|
||||||
|
#### <a id="plugin-check-command-nrpe"></a> nrpe
|
||||||
|
|
||||||
|
Check command object for the `check_nrpe` plugin.
|
||||||
|
|
||||||
|
Custom Attributes:
|
||||||
|
|
||||||
|
Name | Description
|
||||||
|
----------------|--------------
|
||||||
|
nrpe_address | **Optional.** The host's address. Defaults to "$address$".
|
||||||
|
nrpe_port | **Optional.** The NRPE port. Defaults to 5668.
|
||||||
|
nrpe_command | **Optional.** The command that should be executed.
|
||||||
|
nrpe_no_ssl | **Optional.** Whether to disable SSL or not.
|
||||||
|
nrpe_timeout_unknown | **Optional.** Whether to set timeouts to unknown instead of critical state.
|
||||||
|
nrpe_timeout | **Optional.** The timeout in seconds.
|
||||||
|
nrpe_arguments | **Optional.** Optional nrpe arguments (must be enabled on the NRPE client).
|
||||||
|
|
||||||
#### <a id="plugin-check-command-apt"></a> apt
|
#### <a id="plugin-check-command-apt"></a> apt
|
||||||
|
|
||||||
Check command for the `check_apt` plugin.
|
Check command for the `check_apt` plugin.
|
||||||
|
|
|
@ -60,6 +60,8 @@ While Icinga 1.x ships sample configuration and templates spread in various
|
||||||
object files Icinga 2 moves all templates into the Icinga Template Library (ITL)
|
object files Icinga 2 moves all templates into the Icinga Template Library (ITL)
|
||||||
and includes that in the sample configuration.
|
and includes that in the sample configuration.
|
||||||
|
|
||||||
|
Additional plugin check commands are shipped with Icinga 2 as well.
|
||||||
|
|
||||||
The ITL will be updated on every release and should not be edited by the user.
|
The ITL will be updated on every release and should not be edited by the user.
|
||||||
|
|
||||||
There are still generic templates available for your convenience which may or may
|
There are still generic templates available for your convenience which may or may
|
||||||
|
@ -69,6 +71,15 @@ all required attributes except `check_command` for an inline service.
|
||||||
Sample configuration files are located in the `conf.d/` directory which is
|
Sample configuration files are located in the `conf.d/` directory which is
|
||||||
included in `icinga2.conf` by default.
|
included in `icinga2.conf` by default.
|
||||||
|
|
||||||
|
### <a id="differences-1x-2-main-config"></a> Main Config File
|
||||||
|
|
||||||
|
In Icinga 1.x there are many global configuration settings available in `icinga.cfg`.
|
||||||
|
Icinga 2 only uses a small set of [global constants](#global-constants) allowing
|
||||||
|
you to specify certain different setting such as the `NodeName` in a cluster scenario.
|
||||||
|
|
||||||
|
Aside from that, the [icinga2.conf](#icinga2-conf) should take care of including
|
||||||
|
global constants, enabled [features](#features) and the object configuration.
|
||||||
|
|
||||||
### <a id="differences-1x-2-include-files-dirs"></a> Include Files and Directories
|
### <a id="differences-1x-2-include-files-dirs"></a> Include Files and Directories
|
||||||
|
|
||||||
In Icinga 1.x the `icinga.cfg` file contains `cfg_file` and `cfg_dir`
|
In Icinga 1.x the `icinga.cfg` file contains `cfg_file` and `cfg_dir`
|
||||||
|
@ -86,9 +97,9 @@ Icinga 2 supports wildcard includes and relative paths, e.g. for including
|
||||||
include "conf.d/*.conf"
|
include "conf.d/*.conf"
|
||||||
|
|
||||||
If you want to include files and directories recursively, you need to define
|
If you want to include files and directories recursively, you need to define
|
||||||
a separate option and add the directory and an option pattern.
|
a separate option and add the directory and an optional pattern.
|
||||||
|
|
||||||
include_recursive "conf.d" "*.conf"
|
include_recursive "conf.d"
|
||||||
|
|
||||||
A global search path for includes is available for advanced features like
|
A global search path for includes is available for advanced features like
|
||||||
the Icinga Template Library (ITL) or additional monitoring plugins check
|
the Icinga Template Library (ITL) or additional monitoring plugins check
|
||||||
|
@ -125,7 +136,8 @@ In Icinga 1.x comments are made using a leading hash (`#`) or a semi-colon (`;`)
|
||||||
for inline comments.
|
for inline comments.
|
||||||
|
|
||||||
In Icinga 2 comments can either be encapsulated by `/*` and `*/` (allowing for
|
In Icinga 2 comments can either be encapsulated by `/*` and `*/` (allowing for
|
||||||
multi-line comments) or starting with two slashes (`//`).
|
multi-line comments) or starting with two slashes (`//`). A leading hash (`#`)
|
||||||
|
could also be used.
|
||||||
|
|
||||||
### <a id="differences-1x-2-object-names"></a> Object names
|
### <a id="differences-1x-2-object-names"></a> Object names
|
||||||
|
|
||||||
|
@ -166,9 +178,11 @@ Icinga 2 uses the keyword `import` with template names in double quotes.
|
||||||
import "tmpl3"
|
import "tmpl3"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
The last template overrides previously set values.
|
||||||
|
|
||||||
### <a id="differences-1x-2-object-attributes"></a> Object attributes
|
### <a id="differences-1x-2-object-attributes"></a> Object attributes
|
||||||
|
|
||||||
Icinga 1.x separates attribute and value with whitespaces/tabs. Icinga 2
|
Icinga 1.x separates attribute and value pairs with whitespaces/tabs. Icinga 2
|
||||||
requires an equal sign (=) between them.
|
requires an equal sign (=) between them.
|
||||||
|
|
||||||
define service {
|
define service {
|
||||||
|
@ -193,7 +207,7 @@ In Icinga 1.x a host can have an `alias` and a `display_name` attribute used
|
||||||
for a more descriptive name. A service only can have a `display_name` attribute.
|
for a more descriptive name. A service only can have a `display_name` attribute.
|
||||||
The `alias` is used for group, timeperiod, etc. objects too.
|
The `alias` is used for group, timeperiod, etc. objects too.
|
||||||
Icinga 2 only supports the `display_name` attribute which is also taken into
|
Icinga 2 only supports the `display_name` attribute which is also taken into
|
||||||
account by Icinga 1.x Classic UI and Web.
|
account by Icinga web interfaces.
|
||||||
|
|
||||||
### <a id="differences-1x-2-custom-attributes"></a> Custom Attributes
|
### <a id="differences-1x-2-custom-attributes"></a> Custom Attributes
|
||||||
|
|
||||||
|
@ -211,6 +225,8 @@ In Icinga 2 these attributes must be added to the `vars` dictionary as custom at
|
||||||
vars.dn = "cn=icinga2-dev-host,ou=icinga,ou=main,ou=IcingaConfig,ou=LConf,dc=icinga,dc=org"
|
vars.dn = "cn=icinga2-dev-host,ou=icinga,ou=main,ou=IcingaConfig,ou=LConf,dc=icinga,dc=org"
|
||||||
vars.cv = "my custom cmdb description"
|
vars.cv = "my custom cmdb description"
|
||||||
|
|
||||||
|
These custom attributes are also used as [command parameters](#command-passing-parameters).
|
||||||
|
|
||||||
### <a id="differences-1x-2-host-service-relation"></a> Host Service Relation
|
### <a id="differences-1x-2-host-service-relation"></a> Host Service Relation
|
||||||
|
|
||||||
In Icinga 1.x a service object is associated with a host by defining the
|
In Icinga 1.x a service object is associated with a host by defining the
|
||||||
|
@ -218,7 +234,7 @@ In Icinga 1.x a service object is associated with a host by defining the
|
||||||
to `hostgroup_name` or behavior changing regular expression.
|
to `hostgroup_name` or behavior changing regular expression.
|
||||||
|
|
||||||
The preferred way of associating hosts with services in Icinga 2 is by
|
The preferred way of associating hosts with services in Icinga 2 is by
|
||||||
using the `apply` keyword.
|
using the [apply](#using-apply) keyword.
|
||||||
|
|
||||||
### <a id="differences-1x-2-users"></a> Users
|
### <a id="differences-1x-2-users"></a> Users
|
||||||
|
|
||||||
|
@ -282,8 +298,8 @@ The Classic UI feature named `Command Expander` does not work with Icinga 2.
|
||||||
The global configuration setting `enable_environment_macros` does not exist in
|
The global configuration setting `enable_environment_macros` does not exist in
|
||||||
Icinga 2.
|
Icinga 2.
|
||||||
|
|
||||||
Macros exported into the environment must be set using the `env`
|
Macros exported into the [environment](#runtime-custom-attribute-env-vars)
|
||||||
attribute in command objects.
|
must be set using the `env` attribute in command objects.
|
||||||
|
|
||||||
#### <a id="differences-1x-2-runtime-macros"></a> Runtime Macros
|
#### <a id="differences-1x-2-runtime-macros"></a> Runtime Macros
|
||||||
|
|
||||||
|
@ -334,7 +350,7 @@ Changes to host runtime macros
|
||||||
HOSTNAME | host.name
|
HOSTNAME | host.name
|
||||||
HOSTDISPLAYNAME | host.display_name
|
HOSTDISPLAYNAME | host.display_name
|
||||||
HOSTCHECKCOMMAND | host.check_command
|
HOSTCHECKCOMMAND | host.check_command
|
||||||
HOSTALIAS | ..
|
HOSTALIAS | (use `host.display_name` instead)
|
||||||
HOSTSTATE | host.state
|
HOSTSTATE | host.state
|
||||||
HOSTSTATEID | host.state_id
|
HOSTSTATEID | host.state_id
|
||||||
HOSTSTATETYPE | host.state_type
|
HOSTSTATETYPE | host.state_type
|
||||||
|
@ -374,8 +390,8 @@ Changes to notification runtime macros
|
||||||
NOTIFICATIONTYPE | notification.type
|
NOTIFICATIONTYPE | notification.type
|
||||||
NOTIFICATIONAUTHOR | notification.author
|
NOTIFICATIONAUTHOR | notification.author
|
||||||
NOTIFICATIONCOMMENT | notification.comment
|
NOTIFICATIONCOMMENT | notification.comment
|
||||||
NOTIFICATIONAUTHORNAME | --
|
NOTIFICATIONAUTHORNAME | (use `notification.author`)
|
||||||
NOTIFICATIONAUTHORALIAS | --
|
NOTIFICATIONAUTHORALIAS | (use `notification.author`)
|
||||||
|
|
||||||
|
|
||||||
Changes to global runtime macros:
|
Changes to global runtime macros:
|
||||||
|
@ -523,7 +539,7 @@ conditions.
|
||||||
assign where match("*-dev", host.name)
|
assign where match("*-dev", host.name)
|
||||||
}
|
}
|
||||||
|
|
||||||
#### <a id="differences-1x-2-service-hostgroup-host"></a> Add Service to Hostgroup where Host is member
|
#### <a id="differences-1x-2-service-hostgroup-host"></a> Add Service to Hostgroup where Host is Member
|
||||||
|
|
||||||
In order to associate a service with all hosts in a host group the `apply`
|
In order to associate a service with all hosts in a host group the `apply`
|
||||||
keyword can be used:
|
keyword can be used:
|
||||||
|
@ -631,6 +647,13 @@ object.
|
||||||
A service can now depend on a host, and vice versa. A service has an implicit dependeny
|
A service can now depend on a host, and vice versa. A service has an implicit dependeny
|
||||||
(parent) to its host. A host to host dependency acts implicit as host parent relation.
|
(parent) to its host. A host to host dependency acts implicit as host parent relation.
|
||||||
|
|
||||||
|
The former `host_name` and `dependent_host_name` have been renamed to `parent_host_name`
|
||||||
|
and `child_host_name` (same for the service attribute). When using apply rules the
|
||||||
|
child attributes may be omitted.
|
||||||
|
|
||||||
|
For detailed examples on how to use the dependencies please check the [dependencies](#dependencies)
|
||||||
|
chapter.
|
||||||
|
|
||||||
Dependencies can be applied to hosts or services using the [apply rules](#apply).
|
Dependencies can be applied to hosts or services using the [apply rules](#apply).
|
||||||
|
|
||||||
The `StatusDataWriter`, `IdoMysqlConnection` and `LivestatusListener` types
|
The `StatusDataWriter`, `IdoMysqlConnection` and `LivestatusListener` types
|
||||||
|
@ -696,10 +719,6 @@ popular broker modules was implemented for Icinga 2:
|
||||||
* Livestatus
|
* Livestatus
|
||||||
* Cluster (allows for high availability and load balancing)
|
* Cluster (allows for high availability and load balancing)
|
||||||
|
|
||||||
In Icinga 1.x broker modules may only be loaded once which means it is not easily possible
|
|
||||||
to have one Icinga instance write to multiple IDO databases. Due to the way
|
|
||||||
objects work in Icinga 2 it is possible to set up multiple IDO database instances.
|
|
||||||
|
|
||||||
|
|
||||||
### <a id="differences-1x-2-distributed-monitoring"></a> Distributed Monitoring
|
### <a id="differences-1x-2-distributed-monitoring"></a> Distributed Monitoring
|
||||||
|
|
||||||
|
@ -710,8 +729,8 @@ distribution out-of-the-box. Furthermore comments, downtimes and other stateful
|
||||||
not synced between the master and slave nodes. There are addons available solving the check
|
not synced between the master and slave nodes. There are addons available solving the check
|
||||||
and configuration distribution problems Icinga 1.x distributed monitoring currently suffers from.
|
and configuration distribution problems Icinga 1.x distributed monitoring currently suffers from.
|
||||||
|
|
||||||
Icinga 2 implements a new built-in distributed monitoring architecture, including config and check
|
Icinga 2 implements a new built-in [distributed monitoring architecture](#distributed-monitoring-high-availability),
|
||||||
distribution, IPv4/IPv6 support, SSL certificates and domain support for DMZ. High Availability
|
including config and check distribution, IPv4/IPv6 support, SSL certificates and zone support for DMZ.
|
||||||
and load balancing are also part of the Icinga 2 Cluster setup.
|
High Availability and load balancing are also part of the Icinga 2 Cluster setup.
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue