Lightning-fast, reliable health monitoring for your services with Prometheus metrics and smart alerting
Sky Puppy is a powerful, lightweight health monitoring service that keeps your applications running smoothly. Monitor HTTP endpoints, databases, and custom services with real-time alerts and Prometheus metrics export.
- 🚀 Lightning Fast: Built with Fastify for exceptional performance
- 🔍 Multiple Checkers: HTTP/HTTPS, MongoDB, Cloudflare Status, and custom checkers
- 📊 Prometheus Metrics: Built-in metrics export for monitoring dashboards
- 🔔 Smart Alerting: Discord, Slack, and custom webhook integrations
- ⚡ Real-time Monitoring: Configurable check intervals down to seconds
- 🛡️ Reliable: Robust error handling and automatic recovery
- 🔧 Easy Configuration: Simple JSON configuration
- 🌐 RESTful API: Full API for dynamic service management
- 📈 Health Status Tracking: Detailed uptime and performance metrics
npm install -g sky-puppy
- Create a configuration file (
sky-puppy-config.json
):
{
"services": {
"my-website": {
"interval": 30,
"checker": {
"name": "request",
"settings": {
"uri": "https://mywebsite.com/health",
"timeout": 5,
"method": "GET"
}
}
}
}
}
- Run Sky Puppy:
sky-puppy
- Check your service status:
curl http://localhost:8069/skypuppy/v1/service/my-website
Sky Puppy uses a JSON configuration file to define services, checkers, and alerters.
{
"services": {
"service-name": {
"interval": 30, // Check interval in seconds
"start_delay": 5, // Initial delay before first check
"expected_status": 200, // Expected HTTP status code
"checker": {
"name": "request", // Checker type
"settings": {
"uri": "https://api.example.com/health",
"timeout": 5, // Request timeout in seconds
"method": "GET", // HTTP method
"headers": { // Custom headers
"Authorization": "Bearer token"
},
"body": { // Request body (for POST/PUT)
"test": "data"
}
}
},
"alerts": [ // Alert configurations
{
"type": "down",
"alerter": "discord_down"
},
{
"type": "healthy",
"alerter": "discord_healthy"
}
]
}
}
}
{
"alerters": {
"discord_down": {
"uri": "https://discord.com/api/webhooks/YOUR_WEBHOOK_URL",
"json": true,
"method": "POST",
"body": {
"embeds": [
{
"title": "🚨 undefined is undefined!",
"description": "Service was healthy for undefined seconds",
"color": 14828098,
"timestamp": "undefined"
}
],
"username": "Sky Puppy",
"avatar_url": "https://i.imgur.com/J5vIVSt.png"
}
}
}
}
request
: HTTP/HTTPS endpoint monitoringmongodb
: MongoDB connection health checkscloudflare-status
: Cloudflare service status monitoring
Create your own checkers using the checker template:
npm install -g sky-puppy-checker-template
GET /skypuppy/health
- Service health statusGET /skypuppy/metrics
- Prometheus metrics export
GET /skypuppy/v1/service/{name}
- Get service statusPOST /skypuppy/v1/service
- Add new servicePUT /skypuppy/v1/service/{name}
- Update serviceDELETE /skypuppy/v1/service/{name}
- Remove service
Sky Puppy exports the following metrics:
sky_puppy_service_health_status
- Service health status (0=down, 1=unhealthy, 2=healthy)sky_puppy_service_response_time
- Service response time in millisecondssky_puppy_service_check_count
- Total number of checks performed
{
"services": {
"web-app": {
"interval": 30,
"checker": {
"name": "request",
"settings": {
"uri": "https://myapp.com/api/health",
"timeout": 10,
"method": "GET"
}
}
}
}
}
{
"services": {
"mongodb": {
"interval": 60,
"checker": {
"name": "sky-puppy-checker-mongodb",
"settings": {
"uri": "mongodb://localhost:27017",
"database": "myapp"
}
}
}
}
}
{
"services": {
"cloudflare": {
"interval": 300,
"checker": {
"name": "sky-puppy-checker-cloudflare-status",
"settings": {
"services": ["cloudflare-dns", "cloudflare-cdn"]
}
}
}
}
}
SKY_PUPPY_PORT
- Server port (default: 8069)SKY_PUPPY_IP
- Server IP (default: 0.0.0.0)SKY_PUPPY_CONFIG_PATH
- Custom config folder path
{
"skypuppy": {
"version": "1.0.0",
"log": {
"enable": true,
"colors": true,
"level": "info"
}
}
}
FROM node:18-alpine
RUN npm install -g sky-puppy
COPY sky-puppy-config.json /app/
WORKDIR /app
EXPOSE 8069
CMD ["sky-puppy"]
[Unit]
Description=Sky Puppy Health Monitor
After=network.target
[Service]
Type=simple
User=sky-puppy
WorkingDirectory=/opt/sky-puppy
ExecStart=/usr/bin/sky-puppy
Restart=always
RestartSec=10
[Install]
WantedBy=multi-user.target
We welcome contributions! Please see our contributing guidelines for details.
git clone https://github.com/Phara0h/sky-puppy.git
cd sky-puppy
npm install
npm test
This project is licensed under the GPL-3.0-or-later License - see the LICENSE file for details.
- Built with Fastify for blazing fast performance
- Prometheus metrics powered by nstats
- Templating with the tiniest and fastest javascript templating engine nbars
Made with ❤️ by the Sky Puppy community
Report a Bug | Request a Feature | Star on GitHub
All notable changes to this project will be documented in this file. Dates are displayed in UTC.
370545f
update mdsquash
10 July 2025
596e16d
Tons of documentation, new website and cleanup
11 December 2020
628dc13
FIxed some bugs, made sky puppy more crash safe and better logging
18 November 2020
0cc7817
Fixed a minor bug, dates should now work in prom.
17 November 2020
61b2674
Minor debug fix
17 November 2020
ec30c55
Few fixes
- Added date to each prom stats only when it was updated
- Fixed bug with version not showing in prom stats
- Fixed possible bug around alerts
4 November 2020
e196e2b
Fixed bug Cannot find module
package.json
4 November 2020
9b1b3c0
Fixed bin package bug
4 November 2020
6197717
ETIMEDOUT is now unhealthy
instead of down
4 November 2020
9712744
Update changelog-template.hbs
4 November 2020
bd98346
Fixed bugs and added pretty console logs
- Fixed
last_unhealthy_total_duration
andlast_healthy_total_duration
bug reporting the wrong elapsed time. - Fixed
healthy
status getting reported even when unhealthy/down has not yet been reported. - Fixed bug relating to console title displaying config version instead of application version.
- Added new console logs (see sample config for details)
- Added 2 new test-server routes
3 November 2020
6604d77
Clean up and more
- Added skypuppy console log title
- Fixed eslint issues
- Fixed bug that altered on healthy status at start of sky puppy
- Fixed bug if settings field was left out of services checkers
2 November 2020
6e251c0
Added sky-puppy-checker-cloudflare-status
to the list of checkers
d204255
Added sky-puppy-checker-mongodb to list of checkers
2 November 2020
4b1a2e4
Fixed changelog to have full commit message
2 November 2020
7f27201
New feature: Messages
- Added the ability to add messages from checkers
- Messages can be accessed in alterters message / viewed in prom
- Added the ability to map codes to messages in a global setting via checkers settings EX:
"sky-puppy-checker-template": {
"foo": "bar",
"code_messages": {
"200": "Override me plz",
"500": "Yikes its down"
}
}
- Added the ability to override those code_messages inside each service as well EX:
"checker": {
"name": "sky-puppy-checker-template",
"settings": {
"bar": "test"
},
"code_messages": {
"200": "Yup its up"
}
}
30 October 2020
a927cdf
Added sky-puppy-checker-template to tests and readme
30 October 2020
7674805
Fixed bug around checkers name
30 October 2020
344b6f0
Added module based checkers! Now you can write custom checkers to check any thing.
30 October 2020
5d614eb
Added endpoints, Added postman docs, Fixed bugs and more!
f6f9a56
added process tile
14 September 2020
505209a
Update README.nbs
14 September 2020