Ian Fijolek 00029a6327
All checks were successful
continuous-integration/drone/push Build is passing
Make Python compatability a flag
2020-02-19 17:38:07 -08:00
2020-02-19 17:38:07 -08:00
2020-01-10 14:25:02 -08:00
2020-01-10 13:58:17 -08:00
2020-02-19 17:38:07 -08:00
2020-02-19 17:38:07 -08:00
2020-02-19 17:38:07 -08:00
2019-11-15 17:14:20 -08:00
2019-11-15 17:14:20 -08:00
2019-11-21 15:32:57 -08:00
2020-02-19 17:38:07 -08:00
2020-01-10 13:58:17 -08:00
2020-01-10 13:58:17 -08:00
2019-11-21 15:32:57 -08:00

minitor-go

A reimplementation of Minitor in Go

Minitor is already a minimal monitoring tool. Python 3 was a quick way to get something live, but Python itself comes with a large footprint. Thus Go feels like a better fit for the project, longer term.

Initial target is meant to be roughly compatible requiring only minor changes to configuration. Future iterations may diverge to take advantage of Go specific features.

Differences from Python version

Templating for Alert messages has been updated. In the Python version, str.format(...) was used with certain keys passed in that could be used to format messages. In the Go version, we use a struct, AlertNotice defined in alert.go and the built in Go templating format. Eg.

minitor-py:

alerts:
  log_command:
    command: ['echo', '{monitor_name}']
  log_shell:
    command: 'echo {monitor_name}'

minitor-go:

alerts:
  log_command:
    command: ['echo', '{{.MonitorName}}']
  log_shell:
    command: 'echo {{.MonitorName}}'

Finally, newlines in a shell command don't terminate a particular command. Semicolons must be used and continuations should not.

minitor-py:

alerts:
  log_shell:
    command: >
      echo "line 1"
      echo "line 2"
      echo "continued" \
        "line"

minitor-go:

alerts:
  log_shell:
    command: >
      echo "line 1";
      echo "line 2";
      echo "continued"
        "line"

To do

There are two sets of task lists. The first is to get rough parity on key features with the Python version. The second is to make some improvements to the framework.

Pairity:

  • Run monitor commands
  • Run monitor commands in a shell
  • Run alert commands
  • Run alert commands in a shell
  • Allow templating of alert commands
  • Implement Prometheus client to export metrics
  • Test coverage
  • Integration testing (manual or otherwise)
  • Allow commands and shell commands in the same config key

Improvement (potentially breaking):

  • Implement leveled logging (maybe glog or logrus)
  • Consider switching from YAML to TOML
  • Consider value of templating vs injecting values into Env variables
  • Consider dropping alert_up and alert_down in favor of using Go templates that offer more control of messaging
  • Async checking
  • Use durations rather than seconds checked in event loop
  • Revisit metrics and see if they all make sense
Description
A minimal monitoring tool
Readme 527 KiB
v1.5.0 Latest
2024-04-03 19:15:11 +00:00
Languages
Go 86%
Shell 6.8%
Makefile 4.9%
Dockerfile 2.3%