VictorOps event handler
VictorOps is an incident management platform that provides observability, collaboration, & real-time alerting. Kapacitor can be configured to send alert messages to VictorOps.
Configuration
Configuration as well as default option values for the VictorOps
event handler are set in your kapacitor.conf.
Below is an example configuration:
[victorops]
enabled = true
api-key = "xxxx"
routing-key = "xxxx"
url = "https://alert.victorops.com/integrations/generic/20131114/alert"
json-data = false
global = falseenabled
Set to true to enable the VictorOps event handler.
api-key
Your VictorOps API Key.
routing-key
Default VictorOps routing key, can be overridden per alert.
url
The VictorOps API URL. This should not need to be changed.
json-data
Use JSON for the “data” field.
New VictorOps installations will want to set this to
trueas it makes the data that triggered the alert available within VictorOps. The default isfalsefor backwards compatibility.
global
If true the all alerts will be sent to VictorOps without explicitly specifying VictorOps in the TICKscript. The routing key can still be overridden.
Options
The following VictorOpas event handler options can be set in a
handler file or when using
.victorOps() in a TICKscript.
| Name | Type | Description |
|---|---|---|
| routing-key | string | The routing key of the alert event. |
Example: handler file
id: handler-id
topic: topic-name
kind: victorops
options:
routing-key: ops_teamExample: TICKscript
|alert()
// ...
.victorOps()
.routingKey('team_rocket')VictorOps Setup
To allow Kapacitor to send alerts to VictorOps, do the following:
- Enable the “Alert Ingestion API” in the “Integrations” section of your VictorOps dashboard.
- Use provided API key as the
api-keyin the[victorops]section of yourkapacitor.conf.
Using the VictorOps event handler
With the VictorOps event handler enabled and configured in your kapacitor.conf,
use the .victorOps() attribute in your TICKscripts to send alerts to VictorOps
or define a VictorOps handler that subscribes to a topic and sends published
alerts to VictorOps.
The examples below use the following VictorOps configuration defined in the kapacitor.conf:
VictorOps settings in kapacitor.conf
[victorops]
enabled = true
api-key = "mysupersecretapikey"
routing-key = "team_rocket"
url = "https://alert.victorops.com/integrations/generic/20131114/alert"
json-data = true
global = falseSend alerts to an VictorOps room from a TICKscript
The following TICKscript uses the .victorOps() event handler to send the
message, “Hey, check your CPU”, to VictorOps whenever idle CPU usage drops
below 10%.
victorops-cpu-alert.tick
stream
|from()
.measurement('cpu')
|alert()
.crit(lambda: "usage_idle" < 10)
.message('Hey, check your CPU')
.victorOps()
.routingKey('team_rocket')Send alerts to an VictorOps room from a defined handler
The following setup sends an alert to the cpu topic with the message,
“Hey, check your CPU”.
A VictorOps handler is added that subscribes to the cpu topic and publishes
all alert messages to VictorOps using default settings defined in the kapacitor.conf.
Create a TICKscript that publishes alert messages to a topic.
The TICKscript below sends an alert message to the cpu topic any time idle
CPU usage drops below 10%.
cpu_alert.tick
stream
|from()
.measurement('cpu')
|alert()
.crit(lambda: "usage_idle" < 10)
.message('Hey, check your CPU')
.topic('cpu')Add and enable the TICKscript:
kapacitor define cpu_alert -tick cpu_alert.tick
kapacitor enable cpu_alertCreate a handler file that subscribes to the cpu topic and uses the VictorOps
event handler to send alerts VictorOps.
victorops_cpu_handler.yaml
topic: cpu
id: victorops-cpu-alert
kind: victorops
options:
routing-key: 'team_rocket'Add the handler:
kapacitor define-topic-handler victorops_cpu_handler.yamlWas this page helpful?
Thank you for your feedback!
Support and feedback
Thank you for being part of our community! We welcome and encourage your feedback and bug reports for Kapacitor and this documentation. To find support, use the following resources: