Checkmk Integration (v 1.x)

Use this guide for checkmk v 1.x
With the ilert checkmk notification plugin you can easily integrate checkmk into ilert and extend your existing checkmk system with SMS, push and voice notifications as well as on-call schedules from ilert. The screenshots below are based on the checkmk Raw Edition (CRE) 1.2.8. The ilert checkmk plugin is compatible with all checkmk versions.
Did you know we offer a native integration for checkmk 2.x

System requirements

  • Python >= 3.7 (alternatively Python >= 2.7.9, we suggest 2.7.10)
Python 2.x is EOL (end of life) we suggest to use Python >= 3.7

In ilert: create alert source

  1. 1.
    Create a new alert source in ilert
  1. 1.
    Select the type Nagios / Icinga and click save.
  1. 1.
    An API key is generated. You will need the API conclusions below when setting up the plugin.

In checkmk: configure ilert Plugin

Download the checkmk plugin package and unzip it:
> unzip
For Python >= 2.7.9 support, please use the files in the python2 folder
For checkmk you need the two files and You can delete the remaining files in the directory. Move the plugin file into the directory /usr/local/bin . Both files must be executable by both checkmk and the cron daemon:
> mv /usr/local/bin
> chmod 755 /usr/local/bin/
> chmod 755
Standalone version of checkmk
OMD version of checkmk
If you are using the standalone version of checkmk, follow the instructions below. If you are using the OMD version, please go the tab OMD version of checkmk.
> crontab -u nagios -e
Add the following entry:
* * * * * python3 /usr/local/bin/ -m send
Via this cron job, events are sent to ilert every minute that failed in the first send attempt (e..g due to a network error).
Move the ilert alerting script to the notifications directory of checkmk:
> mv /usr/share/check_mk/notifications
If you are using the OMD version of checkmk, follow the instructions below.
> su - {site-name}
Create a file named ilert under the cron.d directory of your monitoring instance (e.g. /omd/sites/{site-name}/etc/cron.d). The file should contain the following content:
* * * * * python3 /usr/local/bin/ -m send
Execute the following command for the changes to take effect:
> omd reload crontab
> exit
Move the ilert alerting script to the notifications directory of checkmk:
> mv /omd/sites/{site-name}/local/share/check_mk/notifications
Log in to checkmk's web GUI and continue there.
  1. 1.
    Navigate to the "Users" menu and click on "New User".
  1. 1.
    Fill in the fields marked below. Add the user to the contact groups to which the hosts or services that you want to be alerted for. Click on "Save".
  1. 1.
    Go to the notification settings of this user (by clicking on the "Notifications" icon).
  1. 1.
    Click on "New Rule" and select ilert checkmk Plugin as the "Notification Method". Enter your ilert API key (see above) as a parameter.
  1. 1.
    Go back to the user list and activate your changes by clicking on "1 Changes":

Test the integration

You can test the integration directly in checkmk to verify that everything is working. To do this, open a host or service check in the Web GUI and click on the "Execute" icon (Hammer Icon). In "Fake check results" you can manually set the state of a host or service. Click on "Down" (for a host) or "Critical" (for a service) and then confirm with "Yes!". You should now see an alert in ilert.


Which notification types are processed by the plugin?
The plugin processes the notification types PROBLEM , ACKNOWLEDGEMENT and RECOVERY. The remaining Notification Types (including FLAPPING* and DOWNTIME*) are ignored.
checkmk has the following notification types:
Normal host or service problem
Host / service goes UP / OK again
Acknowledgment of a problem
A host / service begins to be discontinuous
End of discontinuity
Start of scheduled maintenance.
Normal end of maintenance
Premature termination of maintenance
Alarm triggered manually by command
Alerthandler execution (CEE from 1.4.0i2)
What happens if my internet connection is lost? Are the events generated in checkmk lost?
No, events won't be lost. The plugin stores the events locally in a temporary directory (by default in /tmp/ilert_nagios) and tries to send them to ilert every minute. This means that as soon as your connection is available again, cached events will be sent to ilert. In addition, we recommend that you monitor your Internet connection using our uptime monitoring feature.
Will alerts in ilert be resolved automatically?
Yes, as soon as the state of a host / service is UP or OK again in checkmk, the associated alert is resolved in ilert. If a problem is acknowledged in checkmk, the associated alert in ilert is set to the status Accepted.
Can I link checkmk to multiple alert sources in ilert?
Yes, create a checkmk user for each alert source in checkmk. Proceed as described above in the instructions.
The plugin does not work. How do I find the issue?
Please look first in the log file. The plugin uses the Unix / Linux system log for logging (eg under /var/log/messages or /var/log/syslog ). If you can not find the error, please contact our support at [email protected] .
Please also have a look at the checkmk documentation, where additional log files related to alerting are documented: The course of a notification from beginning to end
(c) 2011 - 2023 iLert GmbH