2015-01-23 14:15:57 +01:00
# <a id="configuring-icinga2-first-steps"></a> Configuring Icinga 2: First Steps
2015-05-07 16:01:12 +02:00
This chapter provides an introduction into best practices with your Icinga 2 configuration.
2015-02-11 17:16:44 +01:00
The configuration files which are automatically created when installing the Icinga 2 packages
are a good way to start with Icinga 2.
2015-01-23 15:32:41 +01:00
If you're interested in a detailed explanation of each language feature used in those
2016-05-23 11:48:50 +02:00
configuration files, you can find more information in the [Language Reference ](18-language-reference.md#language-reference )
2015-01-23 15:32:41 +01:00
chapter.
2015-02-11 17:16:44 +01:00
## <a id="configuration-best-practice"></a> Configuration Best Practice
If you are ready to configure additional hosts, services, notifications,
2016-05-23 11:48:50 +02:00
dependencies, etc., you should think about the requirements first and then
2015-02-11 17:16:44 +01:00
decide for a possible strategy.
There are many ways of creating Icinga 2 configuration objects:
* Manually with your preferred editor, for example vi(m), nano, notepad, etc.
2015-08-28 17:17:07 +02:00
* Generated by a [configuration management tool ](14-addons-plugins.md#configuration-tools ) such as Puppet, Chef, Ansible, etc.
2015-02-11 17:16:44 +01:00
* A configuration addon for Icinga 2
* A custom exporter script from your CMDB or inventory tool
* your own.
In order to find the best strategy for your own configuration, ask yourself the following questions:
2016-05-23 14:14:59 +02:00
* Do your hosts share a common group of services (for example linux hosts with disk, load, etc. checks)?
2015-02-11 17:16:44 +01:00
* Only a small set of users receives notifications and escalations for all hosts/services?
If you can at least answer one of these questions with yes, look for the
[apply rules ](3-monitoring-basics.md#using-apply ) logic instead of defining objects on a per
host and service basis.
* You are required to define specific configuration for each host/service?
* Does your configuration generation tool already know about the host-service-relationship?
2016-05-23 14:14:59 +02:00
Then you should look for the object specific configuration setting `host_name` etc. accordingly.
2015-02-11 17:16:44 +01:00
Finding the best files and directory tree for your configuration is up to you. Make sure that
2015-06-16 16:01:02 +02:00
the [icinga2.conf ](4-configuring-icinga-2.md#icinga2-conf ) configuration file includes them,
2015-02-11 17:16:44 +01:00
and then think about:
* tree-based on locations, hostgroups, specific host attributes with sub levels of directories.
2016-05-23 14:14:59 +02:00
* flat `hosts.conf` , `services.conf` , etc. files for rule based configuration.
2015-02-11 17:16:44 +01:00
* generated configuration with one file per host and a global configuration for groups, users, etc.
* one big file generated from an external application (probably a bad idea for maintaining changes).
* your own.
In either way of choosing the right strategy you should additionally check the following:
* Are there any specific attributes describing the host/service you could set as `vars` custom attributes?
You can later use them for applying assign/ignore rules, or export them into external interfaces.
* Put hosts into hostgroups, services into servicegroups and use these attributes for your apply rules.
* Use templates to store generic attributes for your objects and apply rules making your configuration more readable.
Details can be found in the [using templates ](3-monitoring-basics.md#object-inheritance-using-templates ) chapter.
2015-06-16 16:01:02 +02:00
* Apply rules may overlap. Keep a central place (for example, [services.conf ](4-configuring-icinga-2.md#services-conf ) or [notifications.conf ](4-configuring-icinga-2.md#notifications-conf )) storing
2015-02-11 17:16:44 +01:00
the configuration instead of defining apply rules deep in your configuration tree.
* Every plugin used as check, notification or event command requires a `Command` definition.
Further details can be looked up in the [check commands ](3-monitoring-basics.md#check-commands ) chapter.
If you happen to have further questions, do not hesitate to join the
[community support channels ](https://support.icinga.org )
and ask community members for their experience and best practices.
## <a id="configuring-icinga2-overview"></a> Configuration Overview
### <a id="icinga2-conf"></a> icinga2.conf
2015-01-23 14:15:57 +01:00
An example configuration file is installed for you in `/etc/icinga2/icinga2.conf` .
Here's a brief description of the example configuration:
/**
* Icinga 2 configuration file
2016-05-23 11:48:50 +02:00
* -- this is where you define settings for the Icinga application including
2015-01-23 14:15:57 +01:00
* which hosts/services to check.
*
* For an overview of all available configuration options please refer
* to the documentation that is distributed as part of Icinga 2.
*/
2015-10-28 21:07:12 +01:00
Icinga 2 supports [C/C++-style comments ](18-language-reference.md#comments ).
2015-01-23 14:15:57 +01:00
/**
* The constants.conf defines global constants.
*/
include "constants.conf"
The `include` directive can be used to include other files.
/**
* The zones.conf defines zones for a cluster setup.
* Not required for single instance setups.
*/
include "zones.conf"
/**
* The Icinga Template Library (ITL) provides a number of useful templates
* and command definitions.
* Common monitoring plugin command definitions are included separately.
*/
include < itl >
include < plugins >
/**
* The features-available directory contains a number of configuration
* files for features which can be enabled and disabled using the
* icinga2 feature enable / icinga2 feature disable CLI commands.
* These commands work by creating and removing symbolic links in
* the features-enabled directory.
*/
include "features-enabled/*.conf"
This `include` directive takes care of including the configuration files for all
the features which have been enabled with `icinga2 feature enable` . See
2015-10-28 21:07:12 +01:00
[Enabling/Disabling Features ](8-cli-commands.md#enable-features ) for more details.
2015-01-23 14:15:57 +01:00
/**
* The repository.d directory contains all configuration objects
* managed by the 'icinga2 repository' CLI commands.
*/
include_recursive "repository.d"
This `include_recursive` directive is used for discovery of services on remote clients
and their generated configuration described in
2015-08-28 17:17:07 +02:00
[this chapter ](11-icinga2-client.md#icinga2-remote-monitoring-master-discovery ).
2015-01-23 14:15:57 +01:00
/**
* Although in theory you could define all your objects in this file
* the preferred way is to create separate directories and files in the conf.d
* directory. Each of these files must have the file extension ".conf".
*/
include_recursive "conf.d"
2015-06-16 16:01:02 +02:00
You can put your own configuration files in the [conf.d ](4-configuring-icinga-2.md#conf-d ) directory. This
2015-01-23 14:15:57 +01:00
directive makes sure that all of your own configuration files are included.
2015-02-11 17:16:44 +01:00
### <a id="constants-conf"></a> constants.conf
2015-01-23 14:15:57 +01:00
The `constants.conf` configuration file can be used to define global constants.
By default, you need to make sure to set these constants:
2015-01-25 16:07:43 +01:00
* The `PluginDir` constant must be set to the path where the [Monitoring Project plugins ](2-getting-started.md#setting-up-check-plugins ) are installed.
2015-02-11 17:16:44 +01:00
This constant is used by a number of
2015-02-11 11:51:58 +01:00
[built-in check command definitions ](7-icinga-template-library.md#plugin-check-commands ).
2015-01-23 14:15:57 +01:00
* The `NodeName` constant defines your local node name. Should be set to FQDN which is the default
if not set. This constant is required for local host configuration, monitoring remote clients and
cluster setup.
Example:
/* The directory which contains the plugins from the Monitoring Plugins project. */
const PluginDir = "/usr/lib64/nagios/plugins"
/* The directory which contains the Manubulon plugins.
* Check the documentation, chapter "SNMP Manubulon Plugin Check Commands", for details.
*/
const ManubulonPluginDir = "/usr/lib64/nagios/plugins"
/* Our local instance name. By default this is the server's hostname as returned by `hostname --fqdn` .
* This should be the common name from the API certificate.
*/
//const NodeName = "localhost"
/* Our local zone name. */
const ZoneName = NodeName
/* Secret key for remote node tickets */
const TicketSalt = ""
The `ZoneName` and `TicketSalt` constants are required for remote client
and distributed setups only.
2015-02-11 17:16:44 +01:00
### <a id="conf-d"></a> The conf.d Directory
2015-01-23 14:15:57 +01:00
This directory contains example configuration which should help you get started
with monitoring the local host and its services. It is included in the
2015-06-16 16:01:02 +02:00
[icinga2.conf ](4-configuring-icinga-2.md#icinga2-conf ) configuration file by default.
2015-01-23 14:15:57 +01:00
It can be used as reference example for your own configuration strategy.
Just keep in mind to include the main directories in the
2015-06-16 16:01:02 +02:00
[icinga2.conf ](4-configuring-icinga-2.md#icinga2-conf ) file.
2015-01-23 14:15:57 +01:00
2016-05-23 11:48:50 +02:00
You are certainly not bound to it. Remove it if you prefer your own
2015-01-23 14:15:57 +01:00
way of deploying Icinga 2 configuration.
Further details on configuration best practice and how to build your
2015-06-16 16:01:02 +02:00
own strategy is described in [this chapter ](4-configuring-icinga-2.md#configuration-best-practice ).
2015-01-23 14:15:57 +01:00
2015-01-25 16:07:43 +01:00
Available configuration files which are installed by default:
2015-01-23 14:15:57 +01:00
2015-06-16 16:01:02 +02:00
* [hosts.conf ](4-configuring-icinga-2.md#hosts-conf )
* [services.conf ](4-configuring-icinga-2.md#services-conf )
* [users.conf ](4-configuring-icinga-2.md#users-conf )
* [notifications.conf ](4-configuring-icinga-2.md#notifications-conf )
* [commands.conf ](4-configuring-icinga-2.md#commands-conf )
* [groups.conf ](4-configuring-icinga-2.md#groups-conf )
* [templates.conf ](4-configuring-icinga-2.md#templates-conf )
* [downtimes.conf ](4-configuring-icinga-2.md#downtimes-conf )
* [timeperiods.conf ](4-configuring-icinga-2.md#timeperiods-conf )
* [satellite.conf ](4-configuring-icinga-2.md#satellite-conf )
2015-09-28 18:38:36 +02:00
* [api-users.conf ](4-configuring-icinga-2.md#api-users-conf )
* [app.conf ](4-configuring-icinga-2.md#app-conf )
2015-01-23 14:15:57 +01:00
2015-02-11 17:16:44 +01:00
#### <a id="hosts-conf"></a> hosts.conf
2015-01-23 14:15:57 +01:00
The `hosts.conf` file contains an example host based on your
2015-06-16 16:01:02 +02:00
`NodeName` setting in [constants.conf ](4-configuring-icinga-2.md#constants-conf ). You
2015-01-23 14:15:57 +01:00
can use global constants for your object names instead of string
values.
The `import` keyword is used to import the `generic-host` template which
takes care of setting up the host check command to `hostalive` . If you
require a different check command, you can override it in the object definition.
The `vars` attribute can be used to define custom attributes which are available
2015-02-11 11:51:58 +01:00
for check and notification commands. Most of the [Plugin Check Commands ](7-icinga-template-library.md#plugin-check-commands )
2015-01-23 14:15:57 +01:00
in the Icinga Template Library require an `address` attribute.
The custom attribute `os` is evaluated by the `linux-servers` group in
2015-06-16 16:01:02 +02:00
[groups.conf ](4-configuring-icinga-2.md#groups-conf ) making the local host a member.
2015-01-23 14:15:57 +01:00
The example host will show you how to
* define http vhost attributes for the `http` service apply rule defined
2015-06-16 16:01:02 +02:00
in [services.conf ](4-configuring-icinga-2.md#services-conf ).
2015-01-23 14:15:57 +01:00
* define disks (all, specific `/` ) and their attributes for the `disk`
2015-06-16 16:01:02 +02:00
service apply rule defined in [services.conf ](4-configuring-icinga-2.md#services-conf ).
2015-01-23 14:15:57 +01:00
* define notification types (`mail`) and set the groups attribute. This
will be used by notification apply rules in [notifications.conf ](notifications-conf ).
2016-05-23 11:48:50 +02:00
If you've installed [Icinga Web 2 ](2-getting-started.md#setting-up-icingaweb2 ), you can
2015-03-08 22:34:31 +01:00
uncomment the http vhost attributes and reload Icinga 2. The apply
2015-06-16 16:01:02 +02:00
rules in [services.conf ](4-configuring-icinga-2.md#services-conf ) will automatically
2015-01-23 14:15:57 +01:00
generate a new service checking the `/icingaweb2` URI using the `http`
check.
/*
* Host definitions with object attributes
* used for apply rules for Service, Notification,
* Dependency and ScheduledDowntime objects.
*
* Tip: Use `icinga2 object list --type Host` to
* list all host objects after running
* configuration validation (`icinga2 daemon -C`).
*/
/*
* This is an example host based on your
* local host's FQDN. Specify the NodeName
* constant in `constants.conf` or use your
* own description, e.g. "db-host-1".
*/
object Host NodeName {
/* Import the default host template defined in `templates.conf` . */
import "generic-host"
/* Specify the address attributes for checks e.g. `ssh` or `http` . */
address = "127.0.0.1"
address6 = "::1"
/* Set custom attribute `os` for hostgroup assignment in `groups.conf` . */
vars.os = "Linux"
/* Define http vhost attributes for service apply rules in `services.conf` . */
vars.http_vhosts["http"] = {
http_uri = "/"
}
/* Uncomment if you've sucessfully installed Icinga Web 2. */
//vars.http_vhosts["Icinga Web 2"] = {
// http_uri = "/icingaweb2"
//}
/* Define disks and attributes for service apply rules in `services.conf` . */
vars.disks["disk"] = {
/* No parameters. */
}
vars.disks["disk /"] = {
disk_partitions = "/"
}
/* Define notification mail attributes for notification apply rules in `notifications.conf` . */
vars.notification["mail"] = {
/* The UserGroup `icingaadmins` is defined in `users.conf` . */
groups = [ "icingaadmins" ]
}
}
This is only the host object definition. Now we'll need to make sure that this
2015-06-16 16:01:02 +02:00
host and your additional hosts are getting [services ](4-configuring-icinga-2.md#services-conf ) applied.
2015-01-23 14:15:57 +01:00
> **Tip**
>
2016-05-23 11:48:50 +02:00
> If you don't understand all the attributes and how to use [apply rules](18-language-reference.md#apply),
> don't worry -- the [monitoring basics](3-monitoring-basics.md#monitoring-basics) chapter will explain
2015-01-23 14:15:57 +01:00
> that in detail.
2015-02-11 17:16:44 +01:00
#### <a id="services-conf"></a> services.conf
2015-01-23 14:15:57 +01:00
2015-10-28 21:07:12 +01:00
These service [apply rules ](18-language-reference.md#apply ) will show you how to monitor
2015-01-23 14:15:57 +01:00
the local host, but also allow you to re-use or modify them for
your own requirements.
You should define all your service apply rules in `services.conf`
or any other central location keeping them organized.
By default, the local host will be monitored by the following services
Service(s) | Applied on host(s)
--------------------------------------------|------------------------
`load` , `procs` , `swap` , `users` , `icinga` | The `NodeName` host only
`ping4` , `ping6` | All hosts with `address` resp. `address6` attribute
`ssh` | All hosts with `address` and `vars.os` set to `Linux`
`http` , optional: `Icinga Web 2` | All hosts with custom attribute `http_vhosts` defined as dictionary
`disk` , `disk /` | All hosts with custom attribute `disks` defined as dictionary
2015-01-25 16:07:43 +01:00
The Debian packages also include an additional `apt` service check applied to the local host.
2015-01-23 14:15:57 +01:00
The command object `icinga` for the embedded health check is provided by the
2015-02-11 11:51:58 +01:00
[Icinga Template Library (ITL) ](7-icinga-template-library.md#icinga-template-library ) while `http_ip` , `ssh` , `load` , `processes` ,
`users` and `disk` are all provided by the [Plugin Check Commands ](7-icinga-template-library.md#plugin-check-commands )
2015-01-23 14:15:57 +01:00
which we enabled earlier by including the `itl` and `plugins` configuration file.
Example `load` service apply rule:
apply Service "load" {
import "generic-service"
check_command = "load"
/* Used by the ScheduledDowntime apply rule in `downtimes.conf` . */
vars.backup_downtime = "02:00-03:00"
assign where host.name == NodeName
}
The `apply` keyword can be used to create new objects which are associated with
another group of objects. You can `import` existing templates, define (custom)
attributes.
The custom attribe `backup_downtime` is defined to a specific timerange string.
This variable value will be used for applying a `ScheduledDowntime` object to
2015-06-16 16:01:02 +02:00
these services in [downtimes.conf ](4-configuring-icinga-2.md#downtimes-conf ).
2015-01-23 14:15:57 +01:00
In this example the `assign where` condition is a boolean expression which is
evaluated for all objects of type `Host` and a new service with name "load"
2015-10-28 21:07:12 +01:00
is created for each matching host. [Expression operators ](18-language-reference.md#expression-operators )
2015-01-23 14:15:57 +01:00
may be used in `assign where` conditions.
Multiple `assign where` condition can be combined with `AND` using the `&&` operator
as shown in the `ssh` example:
apply Service "ssh" {
import "generic-service"
check_command = "ssh"
assign where host.address & & host.vars.os == "Linux"
}
In this example, the service `ssh` is applied to all hosts having the `address`
attribute defined `AND` having the custom attribute `os` set to the string
`Linux` .
You can modify this condition to match multiple expressions by combinding `AND`
2015-10-28 21:07:12 +01:00
and `OR` using `&&` and `||` [operators ](18-language-reference.md#expression-operators ), for example
2015-01-23 14:15:57 +01:00
`assign where host.address && (vars.os == "Linux" || vars.os == "Windows")` .
A more advanced example is shown by the `http` and `disk` service apply
rules. While one `apply` rule for `ssh` will only create a service for matching
hosts, you can go one step further: Generate apply rules based on array items
or dictionary key-value pairs.
2015-06-16 16:01:02 +02:00
The idea is simple: Your host in [hosts.conf ](4-configuring-icinga-2.md#hosts-conf ) defines the
2015-01-23 14:15:57 +01:00
`disks` dictionary as custom attribute in `vars` .
2015-06-16 16:01:02 +02:00
Remember the example from [hosts.conf ](4-configuring-icinga-2.md#hosts-conf ):
2015-01-23 14:15:57 +01:00
...
/* Define disks and attributes for service apply rules in `services.conf` . */
vars.disks["disk"] = {
/* No parameters. */
}
vars.disks["disk /"] = {
disk_partition = "/"
}
...
This dictionary contains multiple service names we want to monitor. `disk`
should just check all available disks, while `disk /` will pass an additional
parameter `disk_partition` to the check command.
2016-05-23 11:48:50 +02:00
You'll recognize that the naming is important -- that's the very same name
2015-01-23 14:15:57 +01:00
as it is passed from a service to a check command argument. Read about services
and passing check commands in [this chapter ](3-monitoring-basics.md#command-passing-parameters ).
Using `apply Service for` omits the service name, it will take the key stored in
the `disk` variable in `key => config` as new service object name.
The `for` keyword expects a loop definition, for example `key => value in dictionary`
as known from Perl and other scripting languages.
Once defined like this, the `apply` rule defined below will do the following:
* only match hosts with `host.vars.disks` defined through the `assign where` condition
* loop through all entries in the `host.vars.disks` dictionary. That's `disk` and `disk /` as keys.
* call `apply` on each, and set the service object name from the provided key
* inside apply, the `generic-service` template is imported
2015-02-11 11:51:58 +01:00
* defining the [disk ](7-icinga-template-library.md#plugin-check-command-disk ) check command requiring command arguments like `disk_partition`
2015-01-23 14:15:57 +01:00
* adding the `config` dictionary items to `vars` . Simply said, there's now `vars.disk_partition` defined for the
generated service
Configuration example:
apply Service for (disk => config in host.vars.disks) {
import "generic-service"
check_command = "disk"
vars += config
}
A similar example is used for the `http` services. That way you can make your
host the information provider for all apply rules. Define them once, and only
manage your hosts.
2015-06-16 16:01:02 +02:00
Look into [notifications.conf ](4-configuring-icinga-2.md#notifications-conf ) how this technique is used
2015-01-23 14:15:57 +01:00
for applying notifications to hosts and services using their type and user
attributes.
Don't forget to install the [check plugins ](2-getting-started.md#setting-up-check-plugins ) required by
the hosts and services and their check commands.
Further details on the monitoring configuration can be found in the
[monitoring basics ](3-monitoring-basics.md#monitoring-basics ) chapter.
2015-02-11 17:16:44 +01:00
#### <a id="users-conf"></a> users.conf
2015-01-23 14:15:57 +01:00
Defines the `icingaadmin` User and the `icingaadmins` UserGroup. The latter is used in
2015-06-16 16:01:02 +02:00
[hosts.conf ](4-configuring-icinga-2.md#hosts-conf ) for defining a custom host attribute later used in
[notifications.conf ](4-configuring-icinga-2.md#notifications-conf ) for notification apply rules.
2015-01-23 14:15:57 +01:00
object User "icingaadmin" {
import "generic-user"
display_name = "Icinga 2 Admin"
groups = [ "icingaadmins" ]
email = "icinga@localhost"
}
object UserGroup "icingaadmins" {
display_name = "Icinga 2 Admin Group"
}
2015-02-11 17:16:44 +01:00
#### <a id="notifications-conf"></a> notifications.conf
2015-01-23 14:15:57 +01:00
Notifications for check alerts are an integral part or your
Icinga 2 monitoring stack.
2015-01-25 16:07:43 +01:00
The examples in this file define two notification apply rules for hosts and services.
2015-01-23 14:15:57 +01:00
Both `apply` rules match on the same condition: They are only applied if the
nested dictionary attribute `notification.mail` is set.
Please note that the `to` keyword is important in [notification apply rules ](3-monitoring-basics.md#using-apply-notifications )
defining whether these notifications are applies to hosts or services.
2015-06-16 16:01:02 +02:00
The `import` keyword imports the specific mail templates defined in [templates.conf ](4-configuring-icinga-2.md#templates-conf ).
2015-01-23 14:15:57 +01:00
2016-05-23 11:48:50 +02:00
The `interval` attribute is not explicitly set -- it [defaults to 30 minutes ](6-object-types.md#objecttype-notification ).
2015-01-23 14:15:57 +01:00
By setting the `user_groups` to the value provided by the
2015-06-16 16:01:02 +02:00
respective [host.vars.notification.mail ](4-configuring-icinga-2.md#hosts-conf ) attribute we'll
implicitely use the `icingaadmins` UserGroup defined in [users.conf ](4-configuring-icinga-2.md#users-conf ).
2015-01-23 14:15:57 +01:00
apply Notification "mail-icingaadmin" to Host {
import "mail-host-notification"
user_groups = host.vars.notification.mail.groups
2015-03-20 14:57:30 +01:00
users = host.vars.notification.mail.users
2015-01-23 14:15:57 +01:00
assign where host.vars.notification.mail
}
apply Notification "mail-icingaadmin" to Service {
import "mail-service-notification"
user_groups = host.vars.notification.mail.groups
2015-03-20 14:57:30 +01:00
users = host.vars.notification.mail.users
2015-01-23 14:15:57 +01:00
assign where host.vars.notification.mail
}
More details on defining notifications and their additional attributes such as
filters can be read in [this chapter ](3-monitoring-basics.md#notifications ).
### <a id="commands-conf"></a> commands.conf
This is the place where your own command configuration can be defined. By default
2015-06-16 16:01:02 +02:00
only the notification commands used by the notification templates defined in [templates.conf ](4-configuring-icinga-2.md#templates-conf ).
2015-01-23 14:15:57 +01:00
You can freely customize these notification commands, and adapt them for your needs.
Read more on that topic [here ](3-monitoring-basics.md#notification-commands ).
### <a id="groups-conf"></a> groups.conf
The example host defined in [hosts.conf ](hosts-conf ) already has the
custom attribute `os` set to `Linux` and is therefore automatically
a member of the host group `linux-servers` .
2015-10-28 21:07:12 +01:00
This is done by using the [group assign ](18-language-reference.md#group-assign ) expressions similar
2015-01-23 14:15:57 +01:00
to previously seen [apply rules ](3-monitoring-basics.md#using-apply ).
object HostGroup "linux-servers" {
display_name = "Linux Servers"
assign where host.vars.os == "Linux"
}
object HostGroup "windows-servers" {
display_name = "Windows Servers"
assign where host.vars.os == "Windows"
}
Service groups can be grouped together by similar pattern matches.
2015-10-28 21:07:12 +01:00
The [match() function ](18-language-reference.md#function-calls ) expects a wildcard match string
2015-01-23 14:15:57 +01:00
and the attribute string to match with.
object ServiceGroup "ping" {
display_name = "Ping Checks"
assign where match("ping*", service.name)
}
object ServiceGroup "http" {
display_name = "HTTP Checks"
assign where match("http*", service.check_command)
}
object ServiceGroup "disk" {
display_name = "Disk Checks"
assign where match("disk*", service.check_command)
}
2015-02-11 17:16:44 +01:00
#### <a id="templates-conf"></a> templates.conf
2015-01-23 14:15:57 +01:00
2015-01-25 16:07:43 +01:00
Most of the example configuration objects use generic global templates by
default:
2015-01-23 14:15:57 +01:00
template Host "generic-host" {
max_check_attempts = 5
check_interval = 1m
retry_interval = 30s
check_command = "hostalive"
}
template Service "generic-service" {
max_check_attempts = 3
check_interval = 1m
retry_interval = 30s
}
2015-01-25 16:07:43 +01:00
The `hostalive` check command is part of the
2015-02-11 11:51:58 +01:00
[Plugin Check Commands ](7-icinga-template-library.md#plugin-check-commands ).
2015-01-23 14:15:57 +01:00
template Notification "mail-host-notification" {
command = "mail-host-notification"
states = [ Up, Down ]
types = [ Problem, Acknowledgement, Recovery, Custom,
FlappingStart, FlappingEnd,
DowntimeStart, DowntimeEnd, DowntimeRemoved ]
period = "24x7"
}
template Notification "mail-service-notification" {
command = "mail-service-notification"
states = [ OK, Warning, Critical, Unknown ]
types = [ Problem, Acknowledgement, Recovery, Custom,
FlappingStart, FlappingEnd,
DowntimeStart, DowntimeEnd, DowntimeRemoved ]
period = "24x7"
}
2015-02-11 11:51:58 +01:00
More details on `Notification` object attributes can be found [here ](6-object-types.md#objecttype-notification ).
2015-01-23 14:15:57 +01:00
2015-02-11 17:16:44 +01:00
#### <a id="downtimes-conf"></a> downtimes.conf
2015-01-23 14:15:57 +01:00
2015-06-16 16:01:02 +02:00
The `load` service apply rule defined in [services.conf ](4-configuring-icinga-2.md#services-conf ) defines
2015-01-23 14:15:57 +01:00
the `backup_downtime` custom attribute.
2015-02-11 11:51:58 +01:00
The [ScheduledDowntime ](6-object-types.md#objecttype-scheduleddowntime ) apply rule uses this attribute
2015-01-23 14:15:57 +01:00
to define the default value for the time ranges required for recurring downtime slots.
apply ScheduledDowntime "backup-downtime" to Service {
author = "icingaadmin"
comment = "Scheduled downtime for backup"
ranges = {
monday = service.vars.backup_downtime
tuesday = service.vars.backup_downtime
wednesday = service.vars.backup_downtime
thursday = service.vars.backup_downtime
friday = service.vars.backup_downtime
saturday = service.vars.backup_downtime
sunday = service.vars.backup_downtime
}
assign where service.vars.backup_downtime != ""
}
2015-02-11 17:16:44 +01:00
#### <a id="timeperiods-conf"></a> timeperiods.conf
2015-01-23 14:15:57 +01:00
2015-01-25 16:07:43 +01:00
This file contains the default timeperiod definitions for `24x7` , `9to5`
2015-11-11 15:46:11 +01:00
and `never` . TimePeriod objects are referenced by `*period`
2015-01-23 14:15:57 +01:00
objects such as hosts, services or notifications.
2015-02-11 17:16:44 +01:00
#### <a id="satellite-conf"></a> satellite.conf
2015-01-23 14:15:57 +01:00
2015-02-11 17:16:44 +01:00
Includes default templates and dependencies for
2015-08-28 17:17:07 +02:00
[monitoring remote clients ](11-icinga2-client.md#icinga2-client )
2015-02-11 17:16:44 +01:00
using service discovery and
2015-08-28 17:17:07 +02:00
[config generation ](11-icinga2-client.md#icinga2-remote-monitoring-master-discovery )
2015-09-28 18:38:36 +02:00
on the master. Can be ignored/removed on setups not using this feature.
2015-01-23 14:15:57 +01:00
Further details on the monitoring configuration can be found in the
[monitoring basics ](3-monitoring-basics.md#monitoring-basics ) chapter.
2015-09-28 18:38:36 +02:00
#### <a id="api-users-conf"></a> api-users.conf
Provides the default [ApiUser ](6-object-types.md#objecttype-apiuser ) object
named "root" for the [API authentication ](9-icinga2-api.md#icinga2-api-authentication ).
#### <a id="app-conf"></a> app.conf
Provides the default [IcingaApplication ](6-object-types.md#objecttype-icingaapplication )
object named "app" for additional settings such as disabling notifications
globally, etc.