Self-hosted, easily-deployable monitoring and alerts service - like a lightweight PagerDuty
Go to file
Frank Hamand 1f47702c22 Update django rest framework and other requirements
There are a few requirement patch version bumps that we should keep up
with. Also a major djangorestframework that will allow us to add their
new interactive API docs feature.
2017-03-29 12:23:51 +01:00
bin Set template debug to true when testing with coverage 2017-03-08 12:44:36 +00:00
cabot Add flash messages when updating user profile 2017-03-22 11:56:17 +00:00
conf In examples don't overwrite settings that match the default 2017-03-21 15:32:30 +00:00
upstart Add better string escaping to upstart template just in case somebody has an exclamation point in a Django key or something. 2015-04-03 11:47:58 -04:00
.coveragerc Add test coverage support 2016-12-22 11:09:43 +00:00
.foreman Clean repo 2014-01-05 17:24:04 +00:00
.gitignore Ignore Pipfile.lock for now 2017-03-16 10:33:31 +00:00
.travis.yml Fix migration test 2017-03-08 12:44:36 +00:00
CHANGES 0.10.1 2017-03-24 18:25:27 +00:00
Dockerfile Switch to using alpine linux for docker container 2017-02-13 14:08:24 +00:00
LICENSE Clean repo 2014-01-05 17:24:04 +00:00
MANIFEST.in Add static files and templates to MANIFEST.in 2017-02-17 14:47:56 +00:00
Pipfile Update django rest framework and other requirements 2017-03-29 12:23:51 +01:00
Procfile Fix all workers running beats 2017-02-09 12:19:40 +00:00
Procfile.dev Fix all workers running beats 2017-02-09 12:19:40 +00:00
README.md Merge pull request #472 from arachnys/gitter-badge 2017-03-24 17:51:16 +00:00
Vagrantfile Require YAML in Vagrantfile (#344) 2016-05-16 14:36:51 +01:00
docker-compose-base.yml Add default.env and test.env and multiple docker-compose files to override settings 2017-02-13 14:48:07 +00:00
docker-compose-test.yml Add temporary 'sut' service to docker-compose-test 2017-02-16 16:09:54 +00:00
docker-compose.yml Update to celery 4 2017-03-16 10:33:29 +00:00
docker-entrypoint.sh Update to celery 4 2017-03-16 10:33:29 +00:00
example_local_config.yml Make Cabot work on 14.04 as well as 12.04 2015-01-21 19:35:55 -08:00
fabfile.py Automatically create UserProfiles 2016-10-05 12:17:43 +01:00
gunicorn.conf Don't use gevent anymore 2014-08-02 01:13:55 +01:00
makemigrations Added support for alert plugins 2015-02-09 12:34:36 +00:00
manage.py More tweaks for Python packaging 2014-03-05 17:05:26 -06:00
requirements-dev.txt Update dev requirements 2017-03-16 10:33:31 +00:00
requirements-plugins.txt Fix cabot_alert_twilio not working on django 1.10 2017-03-24 18:25:01 +00:00
requirements.txt Update django rest framework and other requirements 2017-03-29 12:23:51 +01:00
setup.py Add `cabot` entrypoint 2017-03-13 16:58:57 +00:00
setup_dev.sh Clean repo 2014-01-05 17:24:04 +00:00
tox.ini Add Flake8 linting using tox 2016-12-08 12:31:28 +00:00

README.md

Cabot

Build Status PyPI version Coverage Status Requirements Status License: MIT Gitter

Cabot is a free, open-source, self-hosted infrastructure monitoring platform that provides some of the best features of PagerDuty, Server Density, Pingdom and Nagios without their cost and complexity. (Nagios, I'm mainly looking at you.)

It provides a web interface that allows you to monitor services (e.g. "Stage Redis server", "Production ElasticSearch cluster") and send telephone, sms or hipchat/email alerts to your on-duty team if those services start misbehaving or go down - all without writing a line of code. Best of all, you can use data that you're already pushing to Graphite/statsd to generate alerts, rather than implementing and maintaining a whole new system of data collectors.

You can alert based on:

  • Metrics from Graphite
  • Status code and response content of web endpoints
  • Jenkins build statuses

We built Cabot as a Christmas project at Arachnys because we couldn't wrap our heads around Nagios, and nothing else out there seemed to fit our use case. We're open-sourcing it in the hope that others find it useful.

Cabot is written in Python and uses Django, Bootstrap, Font Awesome and a whole host of other goodies under the hood.

Screenshots

Services dashboard

Services dashboard

Single service overview

Individual service overview

Quickstart

Using Docker: Deploy in 5 minutes or less using official quickstart guide at cabotapp.com. (See also https://hub.docker.com/r/cabotapp/cabot/)

How it works

Docs have moved to cabotapp.com

Sections:

For those who want to contribute:

FAQ

Why "Cabot"?

My dog is called Cabot and he loves monitoring things. Mainly the presence of food in his immediate surroundings, or perhaps the frequency of squirrel visits to our garden. He also barks loudly to alert us on certain events (e.g. the postman coming to the door).

Cabot watching... something

It's just a lucky coincidence that his name sounds like he could be an automation tool.

API

The API has automatically generated documentation available by browsing https://cabot.yourcompany.com/api. The browsable documentation displays example GET requests and lists other allowed HTTP methods.

To view individual items, append the item id to the url. For example, to view graphite_check 1, browse:

/api/graphite_checks/1/

Authentication

The API allows HTTP basic auth using standard Django usernames and passwords as well as session authentication (by submitting the login form on the login page). The API similarly uses standard Django permissions to allow and deny API access.

All resources are GETable by any authenticated user, but individual permissions must be granted for POST, PUT, and other write methods.

As an example, for POST access to all status_check subclasses, add the following permissions:

cabotapp | status check | Can add graphite status check
cabotapp | status check | Can add http status check
cabotapp | status check | Can add icmp status check
cabotapp | status check | Can add jenkins status check

Access the Django admin page at https://cabot.yourcompany.com/admin to add/remove users, change user permissions, add/remove groups for group-based permission control, and change group permissions.

Sorting and Filtering

Sorting and filtering can be used by both REST clients and on the browsable API. All fields visible in the browsable API can be used for filtering and sorting.

Get all jenkins_checks with debounce enabled and CRITICAL importance:

https://cabot.yourcompany.com/api/jenkins_checks/?debounce=1&importance=CRITICAL

Sort graphite_checks by name field, ascending:

https://cabot.yourcompany.com/api/graphite_checks/?ordering=name

Sort by name field, descending:

https://cabot.yourcompany.com/api/graphite_checks/?ordering=-name

Other (non-Cabot specific) examples are available in the Django REST Framework documentation.

License

See LICENSE file in this repo.