Exec 事件处理程序
exec 事件处理程序会执行一个外部程序。事件数据通过 STDIN 传递给进程。
选项
以下 exec 事件处理程序的选项可以在 handler 文件中设置,或者在使用 TICKscript 中的 .exec() 时设置。
| 名称 | 类型 | 描述 |
|---|---|---|
| prog | string | 要执行的程序的路径。 |
| args | string 列表 | 程序的参数列表。 |
示例:处理程序文件
id: handler-id
topic: topic-name
kind: exec
options:
prog: /path/to/executable
args:
- 'executable arguments'示例:TICKscript
|alert()
// ...
.exec('/path/to/executable', 'executable arguments')使用 exec 事件处理程序
exec 事件处理程序可以在 TICKscripts 和 handler 文件中使用,以根据警报逻辑执行外部程序。
注意: Exec 程序以
kapacitor用户身份运行,该用户通常只能访问默认的系统$PATH。如果使用不在$PATH中的可执行文件,请传递可执行文件的绝对路径。
从 TICKscript 执行外部程序
下面的 TICKscript 在空闲 CPU 使用率低于 10% 时,使用 .exec() 事件处理程序执行 sound-the-alarm.py Python 脚本。
exec-cpu-alert.tick
stream
|from()
.measurement('cpu')
|alert()
.crit(lambda: "usage_idle" < 10)
.exec('/usr/bin/python', 'sound-the-alarm.py')从定义的 handler 执行外部程序
以下设置将一条消息“Hey, check your CPU”发送到 cpu 主题。添加了一个 exec handler,该 handler 订阅 cpu 主题,并在发布警报消息时执行 sound-the-alarm.py Python 脚本。
创建将警报消息发布到主题的 TICKscript。当空闲 CPU 使用率低于 10% 时,下面的 TICKscript 将警报消息发送到 cpu 主题。
cpu_alert.tick
stream
|from()
.measurement('cpu')
|alert()
.crit(lambda: "usage_idle" < 10)
.message('Hey, check your CPU')
.topic('cpu')添加并启用 TICKscript
kapacitor define cpu_alert -tick cpu_alert.tick
kapacitor enable cpu_alert创建一个订阅 cpu 主题的 handler 文件,并使用 exec 事件处理程序执行 sound-the-alarm.py Python 脚本。
exec_cpu_handler.yaml
id: exec-cpu-alert
topic: cpu
kind: exec
options:
prog: '/usr/bin/python'
args:
- 'sound-the-alarm.py'添加处理器
kapacitor define-topic-handler exec_cpu_handler.yaml此页面是否有帮助?
感谢您的反馈!
支持和反馈
感谢您成为我们社区的一员!我们欢迎并鼓励您对 Kapacitor 和本文档提供反馈和错误报告。要获取支持,请使用以下资源: