Skip to content

Latest commit

 

History

History
252 lines (198 loc) · 9.59 KB

README.md

File metadata and controls

252 lines (198 loc) · 9.59 KB

Zabbix

Zabbix is a mature and effortless enterprise-class open source monitoring solution for network monitoring and application monitoring of millions of metrics. This integration extends the alerting capabilities to use xMatters.



An updated version of this integration is available, supporting the latest version of Zabbix and based on xMatters Flow Designer so you can easily connect other tools to your toolchain. Install it right from the Workflow Template directory within your xMatters instance. Learn more.


Pre-Requisites

  • Zabbix (tested with version 4.0-5.0 but should support others)
  • (v4.0 and below) jq command line utility installed on your Zabbix server.
  • xMatters account - If you don't have one, get one!

Files

Note: To download, follow each link above and then click the Download button. Do not try to download by right-clicking the links.

Installation

xMatters set up

Import the Workflow

To import the Workflow into xMatters:

  1. Go to the xMatters Workflows tab
  2. Click Import.
  3. Set your API account password as a constant in xMatters.
  4. Create an Endpoint for Zabbix. http://127.0.0.1/zabbix/api_jsonrpc.php
  5. Update the constants of the Zabbix - Acknowledge Event step to your needs.

Initiation URL

The Workflow has a URL that is required when configuring Zabbix. To get the URL:

  1. In the Zabbix Workflow click on the Flows tab.
  2. Click on the Inbound from Zabbix step and copy the initiation URL.
  3. This URL will be used when setting up the xMatters Media type in Zabbix.

Zabbix Setup

Setup Alert Step

This is only required for Zabbix 4.0 and before.
  1. Under the zabbix-alertscripts folder, copy xMattersEvent.sh to the Zabbix AlertScripts folder.
    • If you don't know the location of the Zabbix AlertScripts folder, check your Zabbix configuration file.
  2. Run chmod 755 xMattersEvent.sh to make sure it's executable.

Add xMatters API User

In order for xMatters to Acknowledge and add comments to a Zabbix event, it needs to be able to use the Zabbix API. In order to use the API, an xMatters user needs to be created in Zabbix for authentication:

  1. In Zabbix, go to Administration, then Users and click Create User.
  2. On the User tab, enter the following:
    • Alias: xMatters
    • Name: xMatters
    • Surname: API
    • Groups: <select any group available in your instance of Zabbix>
    • Password: <set a password for this user>
    • Password (once again): <repeat the previous password>
      • Remember this password as it will be needed later
Click to reveal image.
  1. On the Permissions tab, enter the following:
    • User Type: Zabbix Super Admin
  2. Click Add.

Create the xMatters Media Type

Zabbix 4.0 and before
  1. Check you have installed the jq command line utilty. apt install jq.
  2. In Zabbix, go to Administration, then Media Types and click Create Media Type.
  3. Enter the following:
    • Name: xMatters
    • Type Script
    • Script Name: xMattersEvent.sh
    • Script Parmeters:
      • {ALERT.SENDTO}
      • {ALERT.SUBJECT}
      • {ALERT.MESSAGE}
  4. Click the Add button.
Zabbix 4.4 and later
  1. Go to Administration > Media Types in Zabbix.
  2. Click Import in the upper right corner.
  3. Import the provided xMatters media type file.
  4. Modify the xm_url value to have initation URL from xMatters.
  5. Modify the xm_auth value if you are using basic authentication into xMatters. This value should be what goes in an HTTP authorization header. Take your xMatters API username and password and put it in this format username:password. Then in bash run echo -n "VALUE" | openssl base64 with VALUE being what you just created with your username and password. If not using xm_auth then leave this value blank.

Create/Update Recipients

If you intend to send notifications directly to specific users
  1. In Zabbix, go to Administration, then Users and select your user.
  2. In the Media tab, click the Add link.
  3. Enter the following:
    • Type: xMatters
    • Send to: <the user's xMatters User ID>
    • When active: 1-7,00:00-24:00
    • Use if severity: <select the severity levels you want to notify on>
  4. Click Add.
  5. Repeat these steps for each of your users.
Click to reveal image

If you intend to send notifications to groups in xMatters, you will need to create a user (not a group) in Zabbix to represent the xMatters group. You cannot use Zabbix groups as Zabbix expands those groups before calling xMatters, sending it to each user individually instead of following group shifts and escalations.

To send to notifications to xMatters groups
  1. In Zabbix, go to Administration, then Users and click Create User.
  2. On the User tab, enter the following:
    • Alias: <the name of your xMatters group>
    • Groups: <either select a group that has access to all hosts that you'll want this xMatters group to get notifications on OR select any group and set the User Type to Zabbix Super Admin (see below)>
    • Password: <set a password for this user>
    • Password (once again): <repeat the previous password>
  3. In the Media tab, click the Add link.
  4. Enter the following:
    • Type: xMatters
    • Send to: <the name of your xMatters group>
    • When active: 1-7,00:00-24:00
    • Use if severity: <select the severity levels you want to notify on>
  5. Click the Add button.
  6. On the Permissions tab, enter the following:
    • User Type: <depending on the Groups setting in step 2, set this to Zabbix User or Zabbix Super Admin)
  7. Click Add.
  8. Repeat these steps for each of your xMatters groups.

Create Actions

In Zabbix, an Action is used to when you want to do something (such as send a notification) based on an event. To create an Action that sends a notification via xMatters:

Zabbix 4.0 and before
  1. In Zabbix, go to Configuration, then Actions and click Create Action.
  2. In the Action tab, set a Name and Conditions for your Action.
  3. In the Operations tab, under the Operations section click the New link.
  4. Enter the following:
    • Send to Groups: <leave empty>
    • Send to Users: <select your users and/or xMatters groups>
    • Send only to: xMatters
    • Default message: <unchecked>
    • Message: <enter the following in order, one per line> Fill in <xm_url> with the HTTP Trigger URL from xMatters.
{ALERT.SENDTO}
{EVENT.ACK.STATUS}
{EVENT.DATE}
{EVENT.ID}
{EVENT.NAME}
{EVENT.NSEVERITY}
{ITEM.VALUE1}
{EVENT.TAGS}
{EVENT.TIME}
NONE
{EVENT.VALUE}
{HOST.IP}
{HOST.NAME}
{TRIGGER.NAME}
{TRIGGER.ID}
<xm_url>
<xm_username>
<xm_password>

note: <xm_username> and <xm_password> are optional arguments for basic authentication into xMatters.

  1. Click the Add link (not the button).
  2. Do the same in the Recovery Operations tab
Zabbix 4.4 and later
  1. In Zabbix, go to Configuration, then Actions and click Create Action.
  2. In the Action tab, set a Name and Conditions for your Action.
Click to reveal image.
  1. In the Operations tab, under the Operations section click the New link.

  2. Enter the following:

    • Send to Groups: <leave empty>
    • Send to Users: <select your users and/or xMatters groups>
    • Send only to: xMatters
    • Custom message: <unchecked>
  3. Still in the Operations tab, under the Recovery Operations section click the New link.

  4. Enter the following:

    • Send to Groups: <leave empty>
    • Send to Users: <select your users and/or xMatters groups>
    • Send only to: xMatters
    • Custom message: <unchecked>
Click to reveal image.
  1. Click the Add link (not the button).
  2. Click the Add button.

Testing

To test the integration, create a Zabbix event by causing the conditions required to trigger it. The associated Action will call xMatters to send notifications.

When you receive the xMatters notification, respond with Acknowledge and, if using the xMatters Mobile App, add a comment. In Zabbix, go to Monitoring, then Problems to verify that the event is acknowledged and that any comment is shown when you mouse over the Ack.

Check here for more documentation on the acknowledge API call.