Uptime-monitoring webhooks en integraties: bouw custom workflows
Verbind uptime-monitoring met je systemen via webhooks. Complete gids voor incident-automatisering, custom notificaties en workflow-integratiepatronen.
Waarom webhooks belangrijk zijn voor monitoring#
E-mailmeldingen bereiken je vroeg of laat. Slack-meldingen verschijnen in een kanaal. Maar webhooks laten je dingen doen wanneer incidenten gebeuren.
Zonder webhooks:
- Melding gaat af → Je maakt handmatig een Jira-ticket aan → Je update handmatig de statuspagina → Je belt handmatig de on-call engineer
- Reactietijd: 5-10 minuten
Met webhooks:
- Melding gaat af → Webhook triggert → Maakt automatisch een Jira-ticket aan → Update de statuspagina → Belt de on-call engineer
- Reactietijd: 10 seconden
Voor kritieke infrastructuur voorkomt dit verschil van 5 minuten klantimpact.
Hoe webhooks werken#
Wanneer je site uitvalt en monitoring het detecteert:
1. Nova Uptime monitoring service detects failure
2. Nova Uptime calls your webhook URL with incident data
3. Your server receives HTTP POST with:
- Domain
- Status
- Time detected
- Response time
- Previous check result
4. Your system decides what to do
- Create Jira ticket?
- Page on-call?
- Update status page?
- Post to Slack?
5. Actions execute automatically
Webhooks instellen#
Stap 1: bouw een webhook-receiver#
Je webhook-receiver is een eenvoudige HTTP-endpoint die incidentdata ontvangt.
Voorbeeld: Express.js webhook-receiver
const express = require('express');
const app = express();
app.use(express.json());
app.post('/webhooks/uptime-incident', async (req, res) => {
const { domain, status, detectedAt, responseTime } = req.body;
console.log(`Incident detected: ${domain} is ${status}`);
// Handle the incident
await handleIncident({
domain,
status,
detectedAt,
responseTime
});
// Respond with 200 OK to acknowledge receipt
res.json({ success: true });
});
app.listen(3000, () => {
console.log('Webhook receiver listening on port 3000');
});
Stap 2: configureer de webhook in Nova Uptime#
- Log in op go.novauptime.com
- Domeininstellingen → Webhooks
- Klik op "Add Webhook"
- Voer je endpoint-URL in:
https://yourdomain.com/webhooks/uptime-incident - Selecteer events om te triggeren:
- ✅ Site down
- ✅ Site recovered
- ✅ Response time warning
- Opslaan
Stap 3: test de webhook#
De meeste tools hebben een "Test Webhook"-knop:
- Klik op "Test" in de webhook-instellingen
- Je endpoint ontvangt testdata
- Verifieer dat je systeem reageert met 200 OK
Webhook-patronen in de praktijk#
Patroon 1: incidenttickets aanmaken#
Wanneer een site uitvalt, maak automatisch een Jira-ticket aan.
async function handleIncident({ domain, status, detectedAt }) {
if (status === 'down') {
// Create Jira ticket
const ticket = await createJiraTicket({
project: 'OPS',
issueType: 'Incident',
summary: `Production Incident: ${domain} is down`,
description: `
Domain: ${domain}
Detected: ${detectedAt}
Status: DOWN
Actions:
1. Check server status
2. Review recent deployments
3. Check error logs
`,
priority: 'Critical',
labels: ['incident', 'production']
});
console.log(`Created ticket: ${ticket.key}`);
}
}
Patroon 2: statuspagina updaten#
Wanneer een incident plaatsvindt, update automatisch je publieke statuspagina.
async function handleIncident({ domain, status, detectedAt }) {
if (status === 'down') {
// Create incident on status page
await createStatusPageIncident({
name: `${domain} is Down`,
status: 'investigating',
body: `We're investigating an issue with ${domain}. More info coming soon.`,
affectedComponents: [domain]
});
} else if (status === 'up') {
// Resolve incident on status page
await updateStatusPageIncident({
status: 'resolved',
body: `${domain} is now back online. We apologize for the inconvenience.`
});
}
}
Patroon 3: on-call engineer paging#
Stuur direct een SMS naar de on-call persoon bij kritieke incidenten.
async function handleIncident({ domain, status, detectedAt }) {
if (status === 'down') {
// Get current on-call engineer from PagerDuty
const oncall = await getOnCallEngineer();
// Send SMS
await sendSMS({
to: oncall.phone,
message: `CRITICAL: ${domain} is down. Incident ticket: JIRA-123`
});
// Also post to #incidents Slack channel
await postToSlack({
channel: '#incidents',
text: `@${oncall.slackHandle}: ${domain} is down. See JIRA-123`
});
}
}
Patroon 4: incidenthistorie opslaan#
Log alle incidenten naar je database voor analytics.
async function handleIncident({ domain, status, detectedAt, responseTime }) {
// Store in database
const incident = await Incident.create({
domain,
status,
detectedAt,
responseTime,
createdAt: new Date(),
handledAt: new Date(),
ticketCreated: false,
statusPageUpdated: false
});
console.log(`Stored incident: ${incident._id}`);
// Later: calculate MTTR, uptime %, etc.
await updateIncidentMetrics(domain);
}
Patroon 5: multi-service orkestratie#
Wanneer één service faalt, trigger acties over meerdere platforms.
async function handleIncident({ domain, status, detectedAt }) {
if (status === 'down') {
// Parallel actions: Don't wait for each to finish
await Promise.all([
createJiraTicket({ domain, status }),
createStatusPageIncident({ domain }),
pageOnCallEngineer({ domain }),
postSlackAlert({ domain }),
storeIncidentHistory({ domain, detectedAt }),
triggerPostmortemWorkflow({ domain })
]);
}
}
Geavanceerde patronen#
Patroon 6: voorwaardelijke logica op basis van severity#
Verschillende acties voor verschillende severity-niveaus.
async function handleIncident({ domain, status, severity }) {
if (severity === 'critical') {
// Critical: Page everyone
await pageOnCall({ priority: 'high' });
await updateStatusPage({ status: 'major_outage' });
await createJiraTicket({ priority: 'Critical' });
} else if (severity === 'warning') {
// Warning: Slack + Jira, no SMS
await postSlackAlert({ channel: '#alerts' });
await createJiraTicket({ priority: 'Medium' });
} else if (severity === 'info') {
// Info: Log only, no alert
await storeIncidentHistory({ domain });
}
}
Patroon 7: deduplicatie#
Voorkom dubbele tickets/meldingen als hetzelfde domein meerdere keren faalt.
async function handleIncident({ domain, status }) {
if (status === 'down') {
// Check if active incident already exists
const activeIncident = await Incident.findOne({
domain,
status: 'active',
createdAfter: new Date(Date.now() - 15 * 60 * 1000) // Last 15 mins
});
if (activeIncident) {
// Incident already reported, just update
activeIncident.lastSeen = new Date();
await activeIncident.save();
console.log(`Updated existing incident: ${activeIncident._id}`);
} else {
// New incident, create everything
await createJiraTicket({ domain });
await pageOnCall({ domain });
// ... etc
}
}
}
Patroon 8: gefaalde webhooks opnieuw proberen#
Als je webhook-receiver uitvalt, moet Nova Uptime opnieuw proberen.
Nova Uptime-configuratie:
- Domeininstellingen → Webhooks
- Klik op de webhook
- Geavanceerde instellingen → Retry Policy
- Schakel in: "Retry on failure"
- Max retries: 3
- Retry-vertraging: Exponentieel (5s, 10s, 20s)
Je webhook-receiver moet idempotent zijn (veilig om meerdere keren aan te roepen):
// Good: Idempotent
async function handleIncident({ domain, status, eventId }) {
// Check if already processed
const processed = await ProcessedEvents.findOne({ eventId });
if (processed) {
return res.json({ success: true, cached: true });
}
// Process incident
await doActualWork();
// Record as processed
await ProcessedEvents.create({ eventId, processedAt: new Date() });
res.json({ success: true });
}
Voorbeelden van webhook-integraties#
Integratie 1: Zapier#
Als je geen custom webhooks wilt bouwen, gebruik dan Zapier:
- Nova Uptime → Zapier → Slack/Jira/Email/etc.
- Geen code nodig
- Beperkingen: minder controle, voegt latency toe
Integratie 2: GitHub Actions#
Bij een incident, trigger een GitHub Action (bijv. auto-scaling, rollback):
async function handleIncident({ domain, status }) {
if (status === 'down') {
// Trigger GitHub Actions workflow
await triggerGitHubAction({
repo: 'mycompany/infrastructure',
workflow: 'incident-response.yml',
inputs: {
domain,
action: 'scale-up'
}
});
}
}
Integratie 3: AWS Lambda#
Gebruik Lambda voor serverless webhook-afhandeling:
# AWS Lambda function
import json
import boto3
def lambda_handler(event, context):
body = json.loads(event['body'])
domain = body['domain']
status = body['status']
if status == 'down':
# Auto-scale on AWS
ec2 = boto3.client('ec2')
ec2.start_instances(InstanceIds=['i-1234567890abcdef0'])
return {
'statusCode': 200,
'body': json.dumps({'success': True})
}
Webhook-beveiliging#
Webhook-handtekening verifiëren#
Nova Uptime ondertekent elke webhook met HMAC-SHA256. Verifieer voor verwerking:
const crypto = require('crypto');
app.post('/webhooks/uptime-incident', (req, res) => {
const signature = req.headers['x-gum-signature'];
const body = JSON.stringify(req.body);
const secret = process.env.NOVAUPTIME_WEBHOOK_SECRET;
// Compute expected signature
const expected = crypto
.createHmac('sha256', secret)
.update(body)
.digest('hex');
if (signature !== expected) {
console.error('Invalid webhook signature');
return res.status(401).json({ error: 'Unauthorized' });
}
// Process webhook
handleIncident(req.body);
res.json({ success: true });
});
Rate limiting#
Je webhook-receiver moet calls rate-limiten:
const rateLimit = require('express-rate-limit');
const limiter = rateLimit({
windowMs: 60 * 1000, // 1 minute
max: 100 // max 100 requests per minute
});
app.post('/webhooks/uptime-incident', limiter, (req, res) => {
// Handle webhook
});
Timeout-afhandeling#
De webhook-receiver moet snel reageren:
app.post('/webhooks/uptime-incident', async (req, res) => {
// Respond immediately
res.json({ success: true });
// Do real work in background
setTimeout(async () => {
await handleIncident(req.body);
}, 0);
});
Je webhooks testen#
Testmethode 1: lokaal testen met ngrok#
- Start de lokale webhook-receiver op localhost:3000
- Draai ngrok:
ngrok http 3000 - Krijg de publieke URL:
https://abc123.ngrok.io - Configureer in Nova Uptime:
https://abc123.ngrok.io/webhooks/uptime-incident - Klik op "Test" in Nova Uptime → Bekijk het verzoek in de lokale console
Testmethode 2: webhook tester#
Gebruik webhook.site voor gratis testen:
- Ga naar webhook.site
- Kopieer je unieke URL
- Configureer in Nova Uptime als webhook-receiver
- Test → Bekijk het verzoek in het dashboard van webhook.site
Je webhooks monitoren#
Volg de gezondheid van je webhooks:
async function monitorWebhookHealth() {
const stats = await WebhookEvent.aggregate([
{
$group: {
_id: null,
totalEvents: { $sum: 1 },
successCount: { $sum: { $cond: ['$success', 1, 0] } },
failureCount: { $sum: { $cond: ['$success', 0, 1] } },
avgResponseTime: { $avg: '$responseTime' }
}
}
]);
const successRate = stats[0].successCount / stats[0].totalEvents;
if (successRate < 0.95) {
// Alert: Webhook success rate below 95%
await alertSlack(`
Webhook health: ${(successRate * 100).toFixed(1)}% success rate
Failed events: ${stats[0].failureCount}
`);
}
}
Samenvatting: checklist voor webhook-integratie#
- ✅ Bouw webhook-receiver-endpoint
- ✅ Configureer de webhook in Nova Uptime-instellingen
- ✅ Test de webhook met sample-data
- ✅ Verifieer de webhook-handtekening (HMAC-SHA256)
- ✅ Implementeer retry-logica en idempotency
- ✅ Voeg rate limiting toe aan het webhook-endpoint
- ✅ Stel timeout-afhandeling in
- ✅ Maak een incidentworkflow (Jira + statuspagina + Slack)
- ✅ Test met een echt incident of geforceerde uitval
- ✅ Monitor de gezondheid van webhooks en het slagingspercentage
- ✅ Documenteer webhook-endpoints voor het team
Begin vandaag nog#
Webhooks transformeren monitoring van alleen-meldingen naar volledig geautomatiseerde incidentafhandeling.
Als je Nova Uptime gebruikt, ga dan naar de domeininstellingen en voeg je eerste webhook toe. Begin simpel: log incidenten alleen naar je database. Voeg daarna integraties één voor één toe.
Webhook-documentatie: Nova Uptime API-documentatie
Monitor Your Website Before It Goes Down
Get uptime monitoring, SSL tracking, domain expiry alerts, and email health checks. Free plan — no credit card required.
Start Monitoring FreeGerelateerde artikelen
Uptime-monitoring integreren met Slack: gids voor real-time alerts
Stel in 10 minuten Slack-alerts in voor website-downtime. Routeer incidenten naar #alerts en verlaag de responstijd van 30 minuten naar 60 seconden.
Websites monitoren met AI via de Nova Uptime MCP Server
Verbind Nova Uptime met AI-assistenten zoals Claude en Cursor via MCP. Stel AI-gestuurde monitoring en email health checks in binnen enkele minuten.
Custom e-mailalerts en escalaties: geavanceerde incident-routing
Ontwerp escalatie-workflows die de juiste persoon op het juiste moment paginen. Gids voor alert-routing, on-call integratie en escalatiebeleid.