icinga2/doc/3.3-object-types.md

618 lines
17 KiB
Markdown
Raw Normal View History

2013-09-27 07:19:13 +02:00
## Object Types
2013-09-26 08:59:29 +02:00
2013-09-27 07:19:13 +02:00
### Host
2013-09-26 08:59:29 +02:00
2013-09-27 07:19:13 +02:00
A host.
> **Note**
>
> Unlike in Icinga 1.x hosts are not checkable objects in Icinga 2.
2013-09-26 08:59:29 +02:00
Example:
2013-09-27 07:19:13 +02:00
object Host "localhost" {
display_name = "The best host there is",
2013-09-26 08:59:29 +02:00
2013-09-27 07:19:13 +02:00
groups = [ "all-hosts" ],
2013-09-26 08:59:29 +02:00
2013-09-27 07:19:13 +02:00
check = "ping",
2013-09-26 08:59:29 +02:00
2013-09-27 07:19:13 +02:00
host_dependencies = [ "router" ],
2013-09-26 08:59:29 +02:00
2013-09-27 07:19:13 +02:00
service_dependencies = [
{ host = "db-server", service = "mysql" }
],
2013-09-26 08:59:29 +02:00
2013-09-27 07:19:13 +02:00
services["ping"] = {
templates = [ "ping" ]
},
2013-09-26 08:59:29 +02:00
2013-09-27 07:19:13 +02:00
services["http"] = {
templates = [ "my-http" ],
macros = {
vhost = "test1.example.org",
port = 81
}
}
2013-09-26 08:59:29 +02:00
}
Attributes:
2013-09-26 14:01:29 +02:00
Name |Description
2013-09-26 08:59:29 +02:00
----------------|----------------
2013-09-27 07:19:13 +02:00
display_name |**Optional.** A short description of the host.
check |**Optional.** A service that is used to determine whether the host is up or down. This must be a service short name of a service that belongs to the host.
groups |**Optional.** A list of host groups this host belongs to.
host_dependencies|**Optional.** A list of host names which this host depends on. These dependencies are used to determine whether the host is unreachable.
service_dependencies|**Optional.** A list of services which this host depends on. Each array element must be a dictionary containing the keys "host" and "service". These dependencies are used to determine whether the host is unreachable.
services |**Optional.** Inline definition of services. Each dictionary item specifies a service.<br /><br />The *templates* attribute can be used to specify an array of templates that should be inherited by the service.<br /><br />The new service's name is "hostname:service" - where "service" is the dictionary key in the services dictionary.<br /><br />The dictionary key is used as the service's short name.
macros |TODO
2013-09-26 08:59:29 +02:00
2013-09-27 07:19:13 +02:00
### HostGroup
2013-09-26 08:59:29 +02:00
2013-09-27 07:19:13 +02:00
A group of hosts.
2013-09-26 08:59:29 +02:00
Example:
2013-09-27 07:19:13 +02:00
object HostGroup "my-hosts" {
display_name = "My hosts",
2013-09-26 08:59:29 +02:00
}
Attributes:
2013-09-26 14:01:29 +02:00
Name |Description
2013-09-26 08:59:29 +02:00
----------------|----------------
2013-09-27 07:19:13 +02:00
display_name |**Optional.** A short description of the host group.
2013-09-26 08:59:29 +02:00
2013-09-27 07:19:13 +02:00
### Service
2013-09-26 08:59:29 +02:00
Service objects describe network services and how they should be checked
by Icinga 2.
> **Best Practice**
>
> Rather than creating a *Service* object for a specific host it is usually easier
> to just create a *Service* template and using the *services* attribute in the *Host*
> object to associate these templates with a host.
Example:
object Service "localhost-uptime" {
host = "localhost",
short_name = "uptime",
display_name = "localhost Uptime",
check_command = "check_snmp",
macros = {
community = "public",
oid = "DISMAN-EVENT-MIB::sysUpTimeInstance"
}
check_interval = 60s,
retry_interval = 15s,
servicegroups = [ "all-services", "snmp" ],
}
Attributes:
2013-09-26 14:01:29 +02:00
Name |Description
2013-09-26 08:59:29 +02:00
----------------|----------------
host |**Required.** The host this service belongs to. There must be a *Host* object with that name.
short_name |**Required.** The service name. Must be unique on a per-host basis (Similar to the service_description attribute in Icinga 1.x).
display_name |**Optional.** A short description of the service.
2013-09-27 07:19:13 +02:00
macros |**Optional.**
2013-09-26 08:59:29 +02:00
check\_command |**Required.** The name of the check command.
max\_check\_attempts|TODO
2013-09-27 07:19:13 +02:00
check\_period |**Optional.** The name of a time period which determines when this service should be checked. Not set by default.
2013-09-26 08:59:29 +02:00
check\_interval |**Optional.** The check interval (in seconds).
retry\_interval |**Optional.** The retry interval (in seconds). This is used when the service is in a soft state. Defaults to 1/5th of the check interval if not specified.
2013-09-27 07:19:13 +02:00
event\_command |**Optional.** The name of an event command that should be executed every time the service's state changes.
2013-09-26 08:59:29 +02:00
flapping\_threshold|TODO
volatile |TODO
host\_dependencies|TODO
service\_dependencies|TODO
groups |**Optional.** The service groups this service belongs to.
notifications |TODO
2013-09-27 07:19:13 +02:00
### ServiceGroup
2013-09-26 08:59:29 +02:00
A group of services.
Example:
object ServiceGroup "snmp" {
display_name = "SNMP services",
}
Attributes:
2013-09-26 14:01:29 +02:00
Name |Description
2013-09-26 08:59:29 +02:00
----------------|----------------
display_name |**Optional.** A short description of the service group.
2013-09-27 07:19:13 +02:00
### Notification
2013-09-26 08:59:29 +02:00
TODO
Example:
TODO
Attributes:
2013-09-26 14:01:29 +02:00
Name |Description
2013-09-26 08:59:29 +02:00
----------------|----------------
2013-09-27 07:19:13 +02:00
host |**Required.** The name of the host this notification belongs to.
service |**Required.** The short name of the service this notification belongs to.
2013-09-26 08:59:29 +02:00
macros |TODO
2013-09-27 07:19:13 +02:00
users |**Optional.** A list of user names who should be notified.
user_groups |**Optional.** A list of user group names who should be notified.
2013-09-26 08:59:29 +02:00
times |TODO
notification_command|TODO
notification_interval|TODO
notification_period|TODO
notification_type_filter|TODO
notification_state_filter|TODO
2013-09-27 07:19:13 +02:00
### User
2013-09-26 08:59:29 +02:00
2013-09-27 07:19:13 +02:00
A user.
2013-09-26 08:59:29 +02:00
Example:
TODO
Attributes:
2013-09-26 14:01:29 +02:00
Name |Description
2013-09-26 08:59:29 +02:00
----------------|----------------
2013-09-27 07:19:13 +02:00
display_name |**Optional.** A short description of the user.
2013-09-26 08:59:29 +02:00
macros |TODO
groups |TODO
enable_notifications|TODO
notification_period|TODO
notification_type_filter|TODO
notification_state_filter|TODO
2013-09-27 07:19:13 +02:00
### UserGroup
2013-09-26 08:59:29 +02:00
2013-09-27 07:19:13 +02:00
A user group.
2013-09-26 08:59:29 +02:00
Example:
2013-09-27 07:19:13 +02:00
object UserGroup "noc-staff" {
display_name = "NOC Staff"
}
2013-09-26 08:59:29 +02:00
Attributes:
2013-09-26 14:01:29 +02:00
Name |Description
2013-09-26 08:59:29 +02:00
----------------|----------------
2013-09-27 07:19:13 +02:00
display_name |**Optional.** A short description of the user group.
2013-09-26 08:59:29 +02:00
2013-09-27 07:19:13 +02:00
### TimePeriod
2013-09-26 08:59:29 +02:00
2013-09-27 07:19:13 +02:00
Time periods can be used to specify when services should be checked or to limit
when notifications should be sent out.
2013-09-26 08:59:29 +02:00
Example:
TODO
Attributes:
2013-09-26 14:01:29 +02:00
Name |Description
2013-09-26 08:59:29 +02:00
----------------|----------------
2013-09-27 07:19:13 +02:00
display_name |**Optional.** A short description of the time period.
2013-09-26 08:59:29 +02:00
methods |TODO
ranges |TODO
2013-09-27 07:19:13 +02:00
### ConsoleLogger
2013-09-26 08:59:29 +02:00
2013-09-27 07:19:13 +02:00
Specifies Icinga 2 logging to the console.
2013-09-26 08:59:29 +02:00
Example:
2013-09-27 07:19:13 +02:00
object ConsoleLogger "my-debug-console" {
severity = "debug"
}
2013-09-26 08:59:29 +02:00
Attributes:
2013-09-26 14:01:29 +02:00
Name |Description
2013-09-26 08:59:29 +02:00
----------------|----------------
2013-09-27 07:19:13 +02:00
severity |**Optional.** The minimum severity for this log. Can be "debug", "information", "warning" or "critical". Defaults to "information".
2013-09-26 08:59:29 +02:00
2013-09-27 07:19:13 +02:00
### FileLogger
2013-09-26 08:59:29 +02:00
2013-09-27 07:19:13 +02:00
Specifies Icinga 2 logging to a file.
2013-09-26 08:59:29 +02:00
Example:
2013-09-27 07:19:13 +02:00
object FileLogger "my-debug-file" {
severity = "debug",
path = "/var/log/icinga2/icinga2-debug.log"
}
2013-09-26 08:59:29 +02:00
Attributes:
2013-09-26 14:01:29 +02:00
Name |Description
2013-09-26 08:59:29 +02:00
----------------|----------------
2013-09-27 07:19:13 +02:00
path |**Required.** The log path.
severity |**Optional.** The minimum severity for this log. Can be "debug", "information", "warning" or "critical". Defaults to "information".
2013-09-26 08:59:29 +02:00
2013-09-27 07:19:13 +02:00
### SyslogLogger
2013-09-26 08:59:29 +02:00
2013-09-27 07:19:13 +02:00
Specifies Icinga 2 logging to syslog.
2013-09-26 08:59:29 +02:00
Example:
2013-09-27 07:19:13 +02:00
object SyslogLogger "my-crit-syslog" {
severity = "critical"
}
2013-09-26 08:59:29 +02:00
2013-09-27 07:19:13 +02:00
Attributes:
2013-09-26 08:59:29 +02:00
2013-09-27 07:19:13 +02:00
Name |Description
----------------|----------------
severity |**Optional.** The minimum severity for this log. Can be "debug", "information", "warning" or "critical". Defaults to "information".
2013-09-26 08:59:29 +02:00
2013-09-27 07:19:13 +02:00
### CheckCommand
2013-09-26 08:59:29 +02:00
2013-09-27 07:19:13 +02:00
A check command definition. Additional default command macros can be
defined here.
2013-09-26 08:59:29 +02:00
2013-09-27 07:19:13 +02:00
Example:
2013-09-26 08:59:29 +02:00
2013-09-27 07:19:13 +02:00
object CheckCommand "check_snmp" inherits "plugin-check-command" {
command = "$plugindir$/check_snmp -H $address$ -C $community$ -o $oid$",
macros = {
address = "127.0.0.1",
community = "public",
2013-09-26 08:59:29 +02:00
}
}
Attributes:
2013-09-26 14:01:29 +02:00
Name |Description
2013-09-26 08:59:29 +02:00
----------------|----------------
2013-09-27 07:19:13 +02:00
methods |TODO
command |TODO
export_macros |TODO
escape_macros |TODO
2013-09-26 08:59:29 +02:00
macros |TODO
2013-09-27 07:19:13 +02:00
timeout |TODO
2013-09-26 08:59:29 +02:00
2013-09-27 07:19:13 +02:00
### NotificationCommand
2013-09-26 08:59:29 +02:00
2013-09-27 07:19:13 +02:00
A notification command definition.
2013-09-26 08:59:29 +02:00
Example:
2013-09-27 07:19:13 +02:00
object NotificationCommand "mail-service-notification" inherits "plugin-notification-command" {
command = [
"/opt/bin/send-mail-notification",
"$CONTACTEMAIL$",
"$NOTIFICATIONTYPE$ - $HOSTNAME$ - $SERVICEDESC$ - $SERVICESTATE$",
{{{***** Icinga *****
Notification Type: $NOTIFICATIONTYPE$
Service: $SERVICEDESC$
Host: $HOSTALIAS$
Address: $HOSTADDRESS$
State: $SERVICESTATE$
Date/Time: $LONGDATETIME$
Additional Info: $SERVICEOUTPUT$
Comment: [$NOTIFICATIONAUTHORNAME$] $NOTIFICATIONCOMMENT$}}}
]
2013-09-26 08:59:29 +02:00
}
Attributes:
2013-09-26 14:01:29 +02:00
Name |Description
2013-09-26 08:59:29 +02:00
----------------|----------------
2013-09-27 07:19:13 +02:00
methods |TODO
command |TODO
export_macros |TODO
escape_macros |TODO
macros |TODO
timeout |TODO
2013-09-26 08:59:29 +02:00
2013-09-27 07:19:13 +02:00
### EventCommand
An event command definition.
> **Note**
>
> Similar to Icinga 1.x event handlers.
Example:
object EventCommand "restart-httpd-event" inherits "plugin-event-command" {
command = "/opt/bin/restart-httpd.sh",
}
Attributes:
Name |Description
----------------|----------------
methods |TODO
command |TODO
export_macros |TODO
escape_macros |TODO
macros |TODO
timeout |TODO
### PerfdataWriter
2013-09-26 08:59:29 +02:00
Writes check result performance data to a defined path using macro
pattern.
Example
object PerfdataWriter "pnp" {
perfdata_path = "/var/spool/icinga2/perfdata/service-perfdata",
format_template = "DATATYPE::SERVICEPERFDATA\tTIMET::$TIMET$\tHOSTNAME::$HOSTNAME$\tSERVICEDESC::$SERVICEDESC$\tSERVICEPERFDATA::$SERVICEPERFDATA$\tSERVICECHECKCOMMAND::$SERVICECHECKCOMMAND$\tHOSTSTATE::$HOSTSTATE$\tHOSTSTATETYPE::$HOSTSTATETYPE$\tSERVICESTATE::$SERVICESTATE$\tSERVICESTATETYPE::$SERVICESTATETYPE$",
rotation_interval = 15s,
}
Attributes:
2013-09-26 14:01:29 +02:00
Name |Description
2013-09-26 08:59:29 +02:00
----------------|----------------
perfdata\_path |**Optional.** Path to the service perfdata file. Defaults to IcingaLocalStateDir + "/cache/icinga2/perfdata/perfdata".
format\_template|**Optional.** Format template for the perfdata file. Defaults to a template that's suitable for use with PNP4Nagios.
rotation\_interval|**Optional.** Rotation interval for the file specified in *perfdata\_path*. Defaults to 30 seconds.
> **Note**
>
> When rotating the perfdata file the current UNIX timestamp is appended to the path specified
> in *perfdata\_path* to generate a unique filename.
2013-09-27 07:19:13 +02:00
### IdoMySqlConnection
2013-09-26 08:59:29 +02:00
IDO DB schema compatible output into MySQL database.
Example:
library "db_ido_mysql"
object IdoMysqlConnection "mysql-ido" {
host = "127.0.0.1",
port = 3306,
user = "icinga",
password = "icinga",
database = "icinga",
table_prefix = "icinga_",
instance_name = "icinga2",
instance_description = "icinga2 dev instance"
cleanup = {
2013-09-26 19:05:52 +02:00
downtimehistory_age = 48h,
logentries_age = 31d,
}
2013-09-26 08:59:29 +02:00
}
Attributes:
2013-09-26 14:01:29 +02:00
Name |Description
2013-09-26 08:59:29 +02:00
----------------|----------------
host |**Optional.** MySQL database host address. Defaults to "localhost".
port |**Optional.** MySQL database port. Defaults to 3306.
user |**Optional.** MySQL database user with read/write permission to the icinga database. Defaults to "icinga".
2013-09-26 14:01:29 +02:00
password |**Optional.** MySQL database user's password. Defaults to "icinga".
2013-09-26 08:59:29 +02:00
database |**Optional.** MySQL database name. Defaults to "icinga".
table\_prefix |**Optional.** MySQL database table prefix. Defaults to "icinga\_".
instance\_name |**Optional.** Unique identifier for the local Icinga 2 instance. Defaults to "default".
instance\_description|**Optional.** Description for the Icinga 2 instance.
cleanup |**Optional.** Dictionary with items for historical table cleanup.
Cleanup Items:
----------------|----------------
acknowledgement_age |**Optional.** Max age for acknowledgement table rows (entry_time)
commenthistory_age |**Optional.** Max age for commenthistory table rows (entry_time)
contactnotifications_age |**Optional.** Max age for contactnotifications table rows (start_time)
contactnotificationmethods_age |**Optional.** Max age for contactnotificationmethods table rows (start_time)
downtimehistory_age |**Optional.** Max age for downtimehistory table rows (entry_time)
eventhandlers_age |**Optional.** Max age for eventhandlers table rows (start_time)
externalcommands_age |**Optional.** Max age for externalcommands table rows (entry_time)
flappinghistory_age |**Optional.** Max age for flappinghistory table rows (event_time)
hostchecks_age |**Optional.** Max age for hostchecks table rows (start_time)
logentries_age |**Optional.** Max age for logentries table rows (logentry_time)
notifications_age |**Optional.** Max age for notifications table rows (start_time)
processevents_age |**Optional.** Max age for processevents table rows (event_time)
statehistory_age |**Optional.** Max age for statehistory table rows (state_time)
servicechecks_age |**Optional.** Max age for servicechecks table rows (start_time)
systemcommands_age |**Optional.** Max age for systemcommands table rows (start_time)
2013-09-26 08:59:29 +02:00
2013-09-27 07:19:13 +02:00
### LiveStatusListener
2013-09-26 08:59:29 +02:00
Livestatus API interface available as TCP or UNIX socket.
Example:
library "livestatus"
object LivestatusListener "livestatus-tcp" {
socket_type = "tcp",
bind_host = "127.0.0.1",
bind_port = "6558"
}
object LivestatusListener "livestatus-unix" {
socket_type = "unix",
socket_path = "/var/run/icinga2/livestatus"
}
Attributes:
2013-09-26 14:01:29 +02:00
Name |Description
2013-09-26 08:59:29 +02:00
----------------|----------------
socket\_type |**Optional.** Specifies the socket type. Can be either "tcp" or "unix". Defaults to "unix".
bind\_host |**Optional.** Only valid when socket\_type is "tcp". Host address to listen on for connections. Defaults to "127.0.0.1".
bind\_port |**Optional.** Only valid when *socket\_type* is "tcp". Port to listen on for connections. Defaults to 6558.
socket\_path |**Optional.** Only valid when *socket\_type* is "unix". Specifies the path to the UNIX socket file. Defaults to IcingaLocalStateDir + "/run/icinga2/livestatus".
> **Note**
>
> UNIX sockets are not supported on Windows.
2013-09-27 07:19:13 +02:00
### StatusDataWriter
2013-09-26 08:59:29 +02:00
2013-09-27 07:19:13 +02:00
Periodically writes status data files which are used by the Classic UI and other third-party tools.
2013-09-26 08:59:29 +02:00
Example:
2013-09-27 07:19:13 +02:00
library "compat"
object StatusDataWriter "status" {
status\_path = "/data/status.dat",
objects\_path = "/data/objects.path"
}
2013-09-26 08:59:29 +02:00
Attributes:
2013-09-26 14:01:29 +02:00
Name |Description
2013-09-26 08:59:29 +02:00
----------------|----------------
2013-09-27 07:19:13 +02:00
status\_path |**Optional.** Path to the status.dat file. Defaults to IcingaLocalStateDir + "/cache/icinga2/status.dat".
objects\_path |**Optional.** Path to the objects.cache file. Defaults to IcingaLocalStateDir + "/cache/icinga2/objects.cache".
2013-09-26 08:59:29 +02:00
2013-09-27 07:19:13 +02:00
### ExternalCommandListener
2013-09-26 08:59:29 +02:00
2013-09-27 07:19:13 +02:00
Implements the Icinga 1.x command pipe which can be used to send commands to Icinga.
2013-09-26 08:59:29 +02:00
Example:
2013-09-27 07:19:13 +02:00
library "compat"
object ExternalCommandListener "external" {
command\_path = "/data/icinga2.cmd"
}
2013-09-26 08:59:29 +02:00
Attributes:
2013-09-26 14:01:29 +02:00
Name |Description
2013-09-26 08:59:29 +02:00
----------------|----------------
2013-09-27 07:19:13 +02:00
command\_path |**Optional.** Path to the command pipe. Defaults to IcingaLocalStateDir + "/run/icinga2/icinga2.cmd".
2013-09-26 08:59:29 +02:00
2013-09-27 07:19:13 +02:00
### CompatLogger
2013-09-26 08:59:29 +02:00
2013-09-27 07:19:13 +02:00
Writes log files in a format that's compatible with Icinga 1.x.
2013-09-26 08:59:29 +02:00
Example:
2013-09-27 07:19:13 +02:00
library "compat"
object CompatLogger "my-log" {
log\_dir = "/data/compat-log",
rotation\_method = "HOURLY"
}
2013-09-26 08:59:29 +02:00
Attributes:
2013-09-26 14:01:29 +02:00
Name |Description
2013-09-26 08:59:29 +02:00
----------------|----------------
2013-09-27 07:19:13 +02:00
log\_dir |**Optional.** Path to the compat log directory. Defaults to IcingaLocalStateDir + "/log/icinga2/compat".
rotation\_method|**Optional.** Specifies when to rotate log files. Can be one of "HOURLY", "DAILY", "WEEKLY" or "MONTHLY". Defaults to "HOURLY".
2013-09-26 08:59:29 +02:00
2013-09-27 07:19:13 +02:00
### CheckResultReader
2013-09-26 08:59:29 +02:00
TODO
Example:
TODO
Attributes:
2013-09-26 14:01:29 +02:00
Name |Description
2013-09-26 08:59:29 +02:00
----------------|----------------
spool\_dir |TODO
2013-09-27 07:19:13 +02:00
### CheckerComponent
2013-09-26 08:59:29 +02:00
TODO
Example:
library "checker"
object CheckerComponent "checker" { }
2013-09-27 07:19:13 +02:00
### NotificationComponent
2013-09-26 08:59:29 +02:00
TODO
Example:
library "notification"
object NotificationComponent "notification" { }
2013-09-27 07:19:13 +02:00
### ClusterListener
2013-09-26 08:59:29 +02:00
TODO
Example:
TODO
Attributes:
2013-09-26 14:01:29 +02:00
Name |Description
2013-09-26 08:59:29 +02:00
----------------|----------------
cert\_path |TODO
ca\_path |TODO
bind\_host |TODO
bind\_port |TODO
peers |TODO
2013-09-27 07:19:13 +02:00
### Endpoint
2013-09-26 08:59:29 +02:00
Endpoint objects are used to specify connection information for remote
Icinga 2 instances.
Example:
library "cluster"
object Endpoint "icinga-c2" {
node = "192.168.5.46",
service = 7777,
}
Attributes:
2013-09-26 14:01:29 +02:00
Name |Description
2013-09-26 08:59:29 +02:00
----------------|----------------
node |**Required.** The hostname/IP address of the remote Icinga 2 instance.
service |**Required.** The service name/port of the remote Icinga 2 instance.
config\_files |TODO
2013-09-27 07:19:13 +02:00
accept\_config |**Optional.** A list of endpoint names from which this endpoint accepts configuration files.
### Domain
TODO
Example:
TODO
Attributes:
Name |Description
----------------|----------------
acl |TODO