moni
v0.2.2
https://monibot.io 的命令行工具 - 轻松服务器和应用程序监控。
Moni 是一个与 Monibot REST API 交互的命令行工具。它用于
从 Monibot 查询看门狗
向 Monibot 发送看门狗心跳
从 Monibot 查询机器
发送机器资源使用样本(CPU/内存/磁盘/时钟/网络)到Monibot
将机器文本(命令输出)发送到 Monibot
从 Monibot 查询指标
将指标值发送至 Monibot
它在 Linux/amd64 上运行,并用 Go 编写,请参阅 https://go.dev/
从这里下载预构建的 linux/amd64 二进制文件:https://github.com/cvilsmeier/moni/releases/latest
如果您不想下载预构建的二进制文件,可以从命令行安装 moni。
$ go install github.com/cvilsmeier/moni@latest
如果您不想下载预构建的二进制文件,可以从命令行构建 moni。
$ git clone https://github.com/cvilsmeier/moni $ cd moni/ $ CGO_ENABLED=0 go build $ ./moni help
$ moni help Moni - A command line tool for https://monibot.io Usage moni [flags] command Flags -url Monibot URL, default is "https://monibot.io". You can set this also via environment variable MONIBOT_URL. -apiKey Monibot API Key, default is "". You can set this also via environment variable MONIBOT_API_KEY (recommended). You can find your API Key in your profile on https://monibot.io. Note: For security, we recommend that you specify the API Key via MONIBOT_API_KEY, and not via -apiKey flag. The flag will show up in 'ps aux' outputs and can be eavesdropped. -trials Max. Send trials, default is 12. You can set this also via environment variable MONIBOT_TRIALS. -delay Delay between trials, default is 5s. You can set this also via environment variable MONIBOT_DELAY. -v Verbose output, default is false. You can set this also via environment variable MONIBOT_VERBOSE ('true' or 'false'). Commands ping Ping the Monibot API. If an error occurs, moni will print that error. It it succeeds, moni will print nothing. watchdogs List heartbeat watchdogs. watchdog <watchdogId> Get heartbeat watchdog by id. heartbeat <watchdogId> [interval] Send a heartbeat. If interval is not specified, moni sends one heartbeat and exits. If interval is specified, moni will stay in the background and send heartbeats in that interval. Min. interval is 5m. machines List machines. machine <machineId> Get machine by id. sample <machineId> <interval> Send resource usage (load/cpu/mem/disk) samples for machine. Moni consults various files (/proc/loadavg, /proc/cpuinfo, etc.) and commands (/usr/bin/free, /usr/bin/df, etc.) to calculate resource usage. Therefore it currently supports linux only. Moni will stay in background and keep sampling in specified interval. Min. interval is 5m. text <machineId> <filename> Send filename as text for machine. Filename can contain arbitrary text, e.g. arbitrary command outputs. It's used for information only, no logic is associated with texts. Moni will send the file as text and then exit. If an error occurs, moni will print an error message. Otherwise moni will print nothing. Max. filesize is 204800 bytes. metrics List metrics. metric <metricId> Get and print metric info. inc <metricId> <value> Increment a counter metric. Value must be a non-negative 64-bit integer value. set <metricId> <value> Set a gauge metric value. Value must be a non-negative 64-bit integer value. values <metricId> <values> Send histogram metric values. Values is a comma-separated list of 'value:count' pairs. Each value is a non-negative 64-bit integer value, each count is an integer value greater or equal to 1. If count is 1, the ':count' part is optional, so values '13:1,14:1' and '13,14' are sematically equal. A specific value may occur multiple times, its counts will then be added together, so values '13:2,13:2' and '13:4' are sematically equal. config Show config values. version Show moni program version. sdk-version Show the monibot-go SDK version moni was built with. help Show this help page. Exit Codes 0 ok 1 error 2 wrong user input
将beat命令重命名为heartbeat
更新值命令文档
用于发送直方图指标值的添加值命令
添加用于发送机器文本的文本命令
重大变化:设置最小看门狗节拍间隔 5m
突破性改变:设置最小机器采样间隔5m
更改命令名称和间隔处理
添加磁盘读/写采样
添加网络接收/发送采样
第一个版本