A command line tool for https://monibot.io - Website-, Server- and Application Monitoring.
Moni is a command-line tool to interact with the Monibot REST API. It is used to
- Send watchdog heartbeats to Monibot
- Send machine resource usage samples (CPU/Memory/Disk/Clock/Network) to Monibot
- Send machine text data to Monibot
- Send metric values to Monibot
It is written in Go and runs on Linux and Windows.
For installing moni on your machine, we provide several options.
Download a pre-built binary for Linux/amd64 or Windows/amd64 here: https://github.com/cvilsmeier/moni/releases/latest
If you do not want to download a pre-built binary, you can install moni from the command line, using Go:
go install github.com/cvilsmeier/moni@latest
If you do not want to download a pre-built binary, you can build moni from source:
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. If it succeeds, it 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. Minimum 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.
This command will stay in background and keep sampling
in specified interval. Minimum 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.
Maximum filesize is 200K.
metrics
List metrics.
metric <metricId>
Get metric by id.
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
- update github.com/cvilsmeier/monibot-go@v0.2.0
- skip loopback network interface(s) on windows
- use shirou/gopsutil for machine sampling (support windows)
- renamed beat command to heartbeat
- update values command docs
- add values command for sending histogram metric values
- add text command for sending machine text
- breaking change: set min watchdog beat interval 5m
- breaking change: set min machine sample interval 5m
- change command names and interval handling
- add disk read/write sampling
- add network recv/send sampling
- first version