Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/sivel/overseer
Simple monitoring server written in Go, similar to pingdom but with no UI
https://github.com/sivel/overseer
Last synced: 3 months ago
JSON representation
Simple monitoring server written in Go, similar to pingdom but with no UI
- Host: GitHub
- URL: https://github.com/sivel/overseer
- Owner: sivel
- License: apache-2.0
- Created: 2015-02-06T20:54:37.000Z (almost 10 years ago)
- Default Branch: master
- Last Pushed: 2022-07-28T14:43:29.000Z (over 2 years ago)
- Last Synced: 2024-10-04T23:41:46.211Z (4 months ago)
- Language: Go
- Homepage:
- Size: 49.8 KB
- Stars: 4
- Watchers: 3
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# overseer
## Monitors
Monitor configurations live at `/etc/overseer/monitors` and each file must have a `.json` file extension.
In addition to the monitor configurations below, each monitor configuration can also name specific notifiers and loggers that it should use such as:
```json
{
...,
"notifiers": [
"Slack status channel",
"email ops team"
],
"loggers": [
"mongodb"
]
}
```The values for the `notifiers` key can either be the notifiers `name` or `type`.
### http-status
```json
{
"type": "http-status",
"name": "localhost status",
"url": "http://localhost/",
"codes": [
200,
400
],
"check_interval": "10s",
"notification_interval": "30m",
"timeout": "2s",
"verify": false,
"method": "HEAD",
"retries": 3
}
```### http-content
```json
{
"type": "http-content",
"name": "localhost content",
"url": "http://localhost/",
"content": "Welcome!",
"check_interval": "10s",
"notification_interval": "30m",
"timeout": "2s",
"verify": false,
"method": "HEAD",
"retries": 3
}
```### connect
```json
{
"type": "connect",
"name": "localhost port 80",
"host": "localhost",
"protocol": "tcp",
"port": 80,
"check_interval": "10s",
"notification_interval": "30m",
"timeout": "2s",
"retries": 3
}
```## Notifiers
Notifier configurations live at `/etc/overseer/notifiers` and each file must have a `.json` file extension.
### stderr
```json
{
"type": "stderr",
"name": "stderr notifier"
}
```### slack
```json
{
"type": "slack",
"name": "Slack status channel",
"webhook_url": "https://hooks.slack.com/services/stuff/goes/here",
"channel": "#status",
"username": "overseer"
}
```### mailgun
```json
{
"type": "mailgun",
"name": "email ops team",
"domain": "overseer.mailgun.org",
"apikey": "key-goes-here",
"from": "Overseer ",
"to": [
"[email protected]",
"[email protected]",
"[email protected]"
]
}
```## Loggers
Logger configurations live at `/etc/overseer/loggers` and each file must have a `.json` file extension.
Loggers differ from notifiers in that they log every status check result, as opposed to just results
from status changing state. This is useful for creating historical response time graphs.### stderr
```json
{
"type": "stderr",
"name": "stderr logger"
}
```### mongodb
```json
{
"type": "mongodb",
"name": "mongodb logger",
"mongodb_uri": "mongodb://localhost/overseer"
}
```### elasticsearch
```json
{
"type": "elasticsearch",
"name": "elasticsearch logger",
"servers": [
"http://127.0.0.1:9200"
],
"username": "elastic_user",
"password": "elastic_pass",
"index": "overseer",
"doc_type": "log"
}
```