A Kubernetes/Openshift controller to watch ingresses/routes and create liveness alerts for your apps/microservices in Uptime checkers.
We want to monitor ingresses in a kubernetes cluster and routes in openshift cluster via any uptime checker but the problem is having to manually check for new ingresses or routes / removed ingresses or routes and add them to the checker or remove them.
This controller will continuously watch ingresses/routes in specific or all namespaces, and automatically add / remove monitors in any of the uptime checkers. With the help of this solution, you can keep a check on your services and see whether they're up and running and live, without worrying about manually registering them on the Uptime checker.
Currently we support the following monitors:
- UptimeRobot (Additional Config)
- Pingdom (Additional Config) (Not fully tested)
- StatusCake (Additional Config)
- Uptime (Additional Config)
- Updown(Additional Config)
- Application Insights(Additional Config)
- gcloud (Additional Config)
The following quickstart let's you set up Ingress Monitor Controller to register uptime monitors for ingresses/routes in all namespaces:
-
Download the manifest file
-
Open the downloaded file in a text editor. Configure the uptime checker in the
config.yaml
data for the ConfigMap resource, and set the following propertiesKey Description name Name of the provider (e.g. UptimeRobot) apiKey ApiKey of the provider apiURL Base url of the ApiProvider with trailing slash (e.g. https://api.uptimerobot.com/v2/) alertContacts A -
separated list of contact id's inside double quotes that you want to add to the monitors (e.g. "1234567_8_9-9876543_2_1" )creationDelay A duration string (e.g., "300ms", "1h50s") to delay the creation of a monitor. (default: 0) Note: Follow this guide to see how to fetch
alertContacts
from UptimeRobot.Note 1: See the section
Using Secrets
here if you do not want to use ConfigMap (because API-Key in plain text) and want to use Secrets to hide API keys
-
Enable for your Ingress/Route
You will need to add the following annotation on your ingresses/routes so that the controller is able to recognize and monitor it.
"monitor.stakater.com/enabled": "true"
-
Deploy the controller by running the following command:
For Kubernetes Cluster
kubectl apply -f ingressmonitorcontroller.yaml -n default
For Openshift Cluster
oc create -f ingressmonitorcontroller.yaml -n default
Alternatively if you have configured helm on your cluster, you can install ingressmonitorcontroller from stakater's public chart repository and deploy it via helm using below mentioned commands
helm repo add stakater https://stakater.github.io/stakater-charts
helm repo update
helm install stakater/ingressmonitorcontroller
You can find more detailed documentation for configuration, extension, and support for other Uptime checkers etc. here
If you'd like to contribute any fixes or enhancements, please refer to the documentation here
File a GitHub issue, or send us an email.
Join and talk to us on the #tools-ingressmonitor channel for discussing the Ingress Monitor Controller
Apache2 © Stakater
The IngressMonitorController
is maintained by Stakater. Like it? Please let us know at [email protected]
See our other projects or contact us in case of professional services and queries on [email protected]
The Google Cloud test infrastructure is sponsored by [JOSHMARTIN])(https://github.com/jshmrtn).
Stakater Team and the Open Source community! 🏆