cabot
Self-hosted, easily-deployable monitoring and alerts service - like a lightweight PagerDuty
Top Related Projects
The open and composable observability and data visualization platform. Visualize metrics, logs, and traces from multiple sources like Prometheus, Loki, Elasticsearch, InfluxDB, Postgres and many more.
Open-source cron job and background task monitoring service, written in Python & Django
A fancy self-hosted monitoring tool
Status Page for monitoring your websites and applications with beautiful graphs, analytics, and plugins. Run on any type of environment.
Architected for speed. Automated for easy. Monitoring and troubleshooting, transformed!
Prometheus Alertmanager
Quick Overview
Cabot is an open-source, self-hosted monitoring and alerting tool that helps teams monitor their infrastructure and applications. It provides a web-based interface for configuring and managing checks, alerts, and escalation policies, making it easier to keep track of the health of your systems.
Pros
- Flexible Monitoring: Cabot supports a wide range of monitoring checks, including HTTP, TCP, Jenkins, Graphite, and more, allowing you to monitor various aspects of your infrastructure.
- Customizable Alerts: You can configure alerts to be sent via email, Slack, PagerDuty, or other channels, and set up escalation policies to ensure that the right people are notified.
- Easy to Set Up and Use: Cabot is designed to be easy to set up and use, with a user-friendly web interface and a straightforward configuration process.
- Open-Source and Self-Hosted: Cabot is an open-source project, allowing you to customize and extend it to fit your specific needs. It can be self-hosted, giving you full control over your monitoring data.
Cons
- Limited Documentation: The project's documentation could be more comprehensive, which may make it challenging for new users to get started.
- Dependency on Python: Cabot is built using Python, which may be a limitation for teams that prefer to use other programming languages.
- Lack of Enterprise-Level Features: Compared to some commercial monitoring solutions, Cabot may lack certain advanced features, such as more sophisticated alerting and reporting capabilities.
- Potential Performance Issues: As the number of checks and alerts increases, Cabot's performance may degrade, especially on smaller hardware setups.
Getting Started
To get started with Cabot, follow these steps:
- Clone the Cabot repository from GitHub:
git clone https://github.com/arachnys/cabot.git
- Change to the project directory and create a virtual environment:
cd cabot
python3 -m venv venv
source venv/bin/activate
- Install the required dependencies:
pip install -r requirements.txt
- Set up the database:
python manage.py migrate
- Create a superuser account:
python manage.py createsuperuser
- Start the development server:
python manage.py runserver
-
Access the Cabot web interface at
http://localhost:8000
and log in with the superuser account you created. -
Configure your monitoring checks and alerts by navigating to the appropriate sections in the web interface.
Competitor Comparisons
The open and composable observability and data visualization platform. Visualize metrics, logs, and traces from multiple sources like Prometheus, Loki, Elasticsearch, InfluxDB, Postgres and many more.
Pros of Grafana
- More comprehensive and feature-rich visualization platform
- Supports a wider range of data sources and integrations
- Larger community and more active development
Cons of Grafana
- Steeper learning curve due to its complexity
- May be overkill for simple monitoring needs
- Requires more resources to run and maintain
Code Comparison
Cabot (Python):
class Service(models.Model):
name = models.CharField(max_length=80, unique=True)
url = models.TextField(blank=True)
status_checks = models.ManyToManyField(StatusCheck, blank=True)
last_alert_sent = models.DateTimeField(null=True, blank=True)
overall_status = models.TextField(default=settings.STATUS_PASSING)
Grafana (Go):
type Dashboard struct {
Id int64
Uid string
Slug string
Title string
Data map[string]interface{}
OrgId int64
GnetId int64
Version int
PluginId string
}
Both repositories focus on monitoring and visualization, but Grafana offers a more extensive set of features and flexibility. Cabot is simpler and easier to set up for basic monitoring needs, while Grafana provides a powerful platform for creating complex dashboards and visualizations across various data sources. The code snippets show that Cabot uses Django models for defining services, while Grafana uses Go structs for dashboard configurations.
Open-source cron job and background task monitoring service, written in Python & Django
Pros of Healthchecks
- Simpler setup and configuration process
- Built-in integration with various notification channels (e.g., Slack, email, SMS)
- More active development and community support
Cons of Healthchecks
- Less comprehensive monitoring capabilities compared to Cabot
- Limited customization options for complex monitoring scenarios
- Fewer built-in integrations with external services and APIs
Code Comparison
Healthchecks (Python):
from django.core.management.base import BaseCommand
from hc.api.models import Check
class Command(BaseCommand):
help = 'Prunes old pings and notifications'
def handle(self, *args, **options):
Check.objects.prune()
Cabot (Python):
from django.core.management.base import BaseCommand
from cabot.cabotapp.models import StatusCheck
class Command(BaseCommand):
help = 'Run all checks'
def handle(self, *args, **options):
StatusCheck.run_all_checks()
Both projects use Django's management commands for core functionality. Healthchecks focuses on pruning old data, while Cabot emphasizes running checks. This reflects their different approaches to monitoring and data management.
A fancy self-hosted monitoring tool
Pros of Uptime Kuma
- More modern and actively maintained project with frequent updates
- User-friendly interface with a clean, responsive design
- Supports a wider range of monitoring types, including TCP, HTTP(S), DNS, and more
Cons of Uptime Kuma
- Less extensive notification options compared to Cabot
- Lacks some advanced features like maintenance windows and custom plugins
Code Comparison
Uptime Kuma (JavaScript):
async function ping(url, timeout = 5000) {
const controller = new AbortController();
const timeoutId = setTimeout(() => controller.abort(), timeout);
try {
const response = await fetch(url, { signal: controller.signal });
return response.ok;
} catch (error) {
return false;
} finally {
clearTimeout(timeoutId);
}
}
Cabot (Python):
def run_check(check):
try:
result = check.run()
except Exception as e:
result = StatusCheck(
check=check,
status=Service.ERROR_STATUS,
error=str(e)
)
return result
Both projects aim to provide uptime monitoring solutions, but they differ in their implementation and feature sets. Uptime Kuma offers a more modern and user-friendly approach, while Cabot provides more advanced features for complex monitoring scenarios. The code snippets showcase their different programming languages and approaches to handling checks and pings.
Status Page for monitoring your websites and applications with beautiful graphs, analytics, and plugins. Run on any type of environment.
Pros of Statping
- More active development with recent updates and releases
- Supports a wider range of service checks, including TCP, UDP, and gRPC
- Offers a mobile app for monitoring on-the-go
Cons of Statping
- Less mature project with potentially more bugs and instability
- Fewer integrations with third-party services and notification channels
- Limited documentation compared to Cabot
Code Comparison
Statping (Go):
func (s *Service) Check(guard bool) {
if guard {
s.checkGuard <- struct{}{}
defer func() {
<-s.checkGuard
}()
}
s.UpdateStats()
}
Cabot (Python):
def run_status_check(check):
service = check.service
try:
result = check.run()
except Exception as e:
result = StatusCheckResult(status=Service.CRITICAL, error=str(e))
service.update_status(result)
Both projects implement status checking mechanisms, but Statping uses Go's concurrency features with channels, while Cabot uses Python's exception handling for error management.
Architected for speed. Automated for easy. Monitoring and troubleshooting, transformed!
Pros of Netdata
- Real-time monitoring with per-second granularity
- Extensive built-in collectors for various systems and applications
- Lightweight and efficient, with minimal system overhead
Cons of Netdata
- Primarily focused on metrics and performance monitoring
- Less emphasis on alerting and incident management features
- Steeper learning curve for advanced configurations
Code Comparison
Netdata configuration (netdata.conf):
[global]
update every = 1
memory mode = ram
history = 3600
Cabot configuration (settings.py):
GRAPHITE_API = 'http://graphite.example.com'
JENKINS_API = 'https://jenkins.example.com'
ALERT_INTERVAL = 10
Key Differences
- Netdata excels in real-time performance monitoring and visualization
- Cabot focuses on service monitoring, checks, and alerting
- Netdata has a more extensive collection of built-in metrics
- Cabot offers better integration with external services like Jenkins and Graphite
- Netdata is more suitable for system administrators and DevOps
- Cabot is geared towards application developers and service reliability teams
Both tools serve different primary purposes, with Netdata being a comprehensive system monitoring solution and Cabot functioning as a service monitoring and alerting platform.
Prometheus Alertmanager
Pros of Alertmanager
- More actively maintained with frequent updates and a larger community
- Tightly integrated with Prometheus ecosystem for seamless monitoring and alerting
- Supports advanced features like alert grouping, silencing, and inhibition
Cons of Alertmanager
- Steeper learning curve, especially for those not familiar with Prometheus
- Requires additional setup and configuration compared to Cabot's simpler approach
Code Comparison
Alertmanager configuration (YAML):
route:
receiver: 'team-X-mails'
receivers:
- name: 'team-X-mails'
email_configs:
- to: 'team-X+alerts@example.org'
Cabot configuration (Python):
PLUGINS = [
'cabot_alert_hipchat',
'cabot_alert_twilio',
'cabot_alert_email',
]
Summary
Alertmanager offers more advanced features and integration with the Prometheus ecosystem, making it suitable for complex monitoring setups. Cabot, on the other hand, provides a simpler and more straightforward approach to monitoring and alerting, which may be preferable for smaller projects or teams new to monitoring. The choice between the two depends on the specific needs of the project and the team's expertise in monitoring and alerting systems.
Convert designs to code with AI
Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.
Try Visual CopilotREADME
Cabot
Maintainers wanted
Cabot is stable and used by hundreds of companies and individuals in production, but it is not actively maintained. We would like to hand over maintenance of the project to one or more responsible and experienced maintainers. Please email cabot@arachnys.com with some information about yourself (github profile and/or CV) if you are interested.
Why choose Cabot
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:
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
Single 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).
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.
Top Related Projects
The open and composable observability and data visualization platform. Visualize metrics, logs, and traces from multiple sources like Prometheus, Loki, Elasticsearch, InfluxDB, Postgres and many more.
Open-source cron job and background task monitoring service, written in Python & Django
A fancy self-hosted monitoring tool
Status Page for monitoring your websites and applications with beautiful graphs, analytics, and plugins. Run on any type of environment.
Architected for speed. Automated for easy. Monitoring and troubleshooting, transformed!
Prometheus Alertmanager
Convert designs to code with AI
Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.
Try Visual Copilot