Kuma ingress watcher is a kubernetes controller designed to automatically monitor Kubernetes Ingress
and Traefik Ingressroutes
in a Kubernetes cluster and create corresponding monitors in Uptime Kuma
. It provides seamless integration between Kubernetes ingress resources and Uptime Kuma monitoring, allowing for easy and efficient monitoring of web services deployed on Kubernetes.
- Automatically creates, updates and deletes monitors in Uptime Kuma for
Kubernetes Ingress
andTraefik Ingressroutes
. - Supports both single and multiple routes per Ingress resource.
- Customizable monitors by annotate Ingressroutes and Ingress.
- Python 3.6+
- Kubernetes cluster
- Uptime Kuma instance
Before running the controller, make sure to configure the following environment variables:
UPTIME_KUMA_URL
: The URL of your Uptime Kuma instance.UPTIME_KUMA_USER
: The username for authenticating with Uptime Kuma.UPTIME_KUMA_PASSWORD
: The password for authenticating with Uptime Kuma.WATCH_INGRESSROUTES
: Set toTrue
to enable monitoring of Traefik IngressRoutes.WATCH_INGRESS
: Set toTrue
to enable monitoring of Kubernetes Ingress resources.WATCH_INTERVAL
: Interval in seconds between each check for changes in Ingress or IngressRoutes (default is10
seconds).USE_TRAEFIK_V3_CRD_GROUP
: Whether to use Traefik V3 API CRD group (traefik.io
); default toFalse
.
These annotations apply to both Kubernetes Ingress and Traefik Ingressroutes resources, allowing you to customize the behavior of Uptime Kuma monitors for each.:
-
uptime-kuma.autodiscovery.probe.interval
- Sets the probing interval in seconds for the monitor.
- Type: Integer
- Default:
60
- Example:
uptime-kuma.autodiscovery.probe.interval: 60
-
uptime-kuma.autodiscovery.probe.name
- Name of the monitor in Uptime Kuma.
- Type: String
- Default:
${name}-${namespace}
- Example:
uptime-kuma.autodiscovery.probe.name: my-monitor
-
uptime-kuma.autodiscovery.probe.enabled
- Enables or disables monitoring for this resource.
- Type: Boolean (accepted values: 'true' or 'false')
- Default:
true
- Example:
uptime-kuma.autodiscovery.probe.enabled: true
-
uptime-kuma.autodiscovery.probe.type
- Probe type for the monitor (e.g., HTTP, TCP, etc.).
- Type: String
- Default:
http
- Example:
uptime-kuma.autodiscovery.probe.type: http
-
uptime-kuma.autodiscovery.probe.headers
- Optional HTTP headers to include in the probe request.
- Type: String (HTTP headers format)
- Default:
null
(no headers) - Example:
uptime-kuma.autodiscovery.probe.headers: {"Authorization": "Bearer token"}
-
uptime-kuma.autodiscovery.probe.host
- force the host for the probe. WARNING: Be carefull with this paramter if you are using multiple hosts in a same Ingress object
- Type: String
- Default:
null
(host grep from ingress) - Example:
uptime-kuma.autodiscovery.probe.host: example.com
-
uptime-kuma.autodiscovery.probe.path
- url sub path for the probe.
- Type: String
- Default:
null
- Example:
uptime-kuma.autodiscovery.probe.path: /tintin
-
uptime-kuma.autodiscovery.probe.port
- Port to use for the probe.
- Type: Integer
- Default:
null
(default port for the protocol) - Example:
uptime-kuma.autodiscovery.probe.port: 8080
-
uptime-kuma.autodiscovery.probe.method
- HTTP method to use for the probe (GET, POST, etc.).
- Type: String
- Default:
GET
- Example:
uptime-kuma.autodiscovery.probe.method: GET
Here's an example of annotations configured in a Kubernetes Ingress Resource:
apiVersion: traefik.containo.us/v1alpha1
kind: IngressRoute
metadata:
name: example-ingressroute
namespace: my-namespace
annotations:
uptime-kuma.autodiscovery.probe.interval: 120
uptime-kuma.autodiscovery.probe.name: my-monitor
uptime-kuma.autodiscovery.probe.enabled: true
uptime-kuma.autodiscovery.probe.type: http
uptime-kuma.autodiscovery.probe.headers: '{"Authorization": "Bearer token"}'
uptime-kuma.autodiscovery.probe.host: 'example.com'
uptime-kuma.autodiscovery.probe.path: '/tintin'
uptime-kuma.autodiscovery.probe.port: 8080
uptime-kuma.autodiscovery.probe.method: GET
spec:
# Your Ingress route specification here
Once the controller is running, it will automatically monitor any changes to Ingress resources in your Kubernetes cluster and create/update corresponding monitors in Uptime Kuma. Simply deploy your applications using Kubernetes Ingress, and the controller will take care of the rest!
Currently, the addition of tags to monitors is not supported due to limitations in the Uptime Kuma API. Attempting to add tags through the controller may result in unexpected behavior or errors. Please refer to the Uptime Kuma documentation for updates on tag management capabilities.
The Kubernetes event watcher (watch
) does not provide specific details on creation, modification, or deletion events for IngressRoutes. To overcome this limitation, this controller implements a custom watcher mechanism that continuously monitors IngressRoutes and triggers appropriate actions based on changes detected. homemade watcher is used for Ingress objects too. This custom solution ensures accurate monitoring and synchronization with Uptime Kuma configurations.
Here’s the passage with the new Improvements section included:
- IngressRoute Version Selection: You can now choose which version of IngressRoutes to watch. This allows you to customize the controller's behavior based on the version of Traefik you're using.
- Tag Addition for Monitors: Currently, the addition of tags to monitors is not supported due to limitations in the Uptime Kuma API. Future updates may include support for this feature, allowing you to tag monitors directly through the controller.
Contributions are welcome! If you have any ideas, suggestions, or bug reports, please open an issue or submit a pull request on GitHub.
To run unit tests for this project:
- Python 3.12 or higher installed.
- Poetry installed.
poetry install
poetry run pytest
This project is licensed under the MIT License. See the LICENSE file for details.