How to use it
How to use it
First you need to install Epazote, either you can compile it from source or download a pre-compiled binary matching your operating system from here: https://bintray.com/nbari/epazote/epazote/_latestVersion
To compile from source, after downloading the sources use make
to build the
binary:
~/projects/go/src/github.com/epazote/epazote
$ make
Epazote was designed with simplicity in mind, as an easy tool for DevOps and as a complement to infrastructure orchestration tools like Ansible and SaltStack, because of this YAML is used for the configuration files, avoiding with this, the learn of a new language or syntax and simplifying the setup.
Basic example
services:
google:
url: https://www.google.com
seconds: 5
expect:
status: 302
ssl:
hours: 72
if_not:
cmd: echo -n "google down"
To supervise google
you would run (basic.yml is a file containing the above code):
$ epazote -f /path/to/yaml/file/basic.yml -d
-d is for debugging, will print all output to standard output.
This example, will supervise every 5 seconds the service with name
google
, it will do an HTTP GET to http://www.google.com
and will expect
an 302 Status code
if not, it will echo -n "google down"
The ssl: hours: 72
means to send an alert if the certificate is about to
expire in the next 72 hours.
Extending the basic example for receiving notifications:
config:
smtp:
username: smtp@domain.tld
password: password
server: mail.example.com
port: 587
headers:
from: you@domain.tld
to: team@domain.tld
subject: "[_name_, _because_]"
services:
google:
url: http://www.google.com
minutes: 3
threshold:
healthy: 2 # consecutive successes
unhealthy: 2 # consecutive failures
expect:
status: 200
if_not:
cmd: echo -n "google down"
notify: yes
In this case, every 3 minutes the service will be checked and in case of not
receiving a 200 Status code
more than 2 times:
threshold:
unhealthy: 2
Besides executing the command: echo -n "google down"
an email is going to be
send to team@domain.tld
, this because of the notify: yes
setting.
After getting 2 consecutive successful responses 200 status code
, an alert
is also sent.
The configuration file
The configuration file (YAML formated) consists of two parts, a config and a services (Key-value pairs).