Notes from the Wired

My Homelab Part 7: UptimeKuma

January 20, 2024 | 450 words | 3min read

Maybe at some point you have encountered a situation where, while running all your current containers, you tried accessing one of your services only to realize that the service is not available because the container exited without your knowledge?

For such Issues, it’s beneficial to have a notification system that can automatically alert you whenever a container exits or is no longer available. To address this need, I use UptimeKuma, an easy-to-use self-hosted monitoring tool. UptimeKuma can monitor uptime over means like HTTP(s)/TCP/Ping/Docker/DNS and notify you via various channels such as Telegram, Discord, Gotify, Slack, Email, and more. Additionally, it provides a user-friendly web interface for managing and adding new monitors.

UptimeKuma Page

Installation

To install UptimeKuma, I utilized Docker Compose with the following configuration in the compose file(uptimeKuma-compose.yml):

 1version: '3.8'
 2
 3services:
 4  uptime-kuma:
 5    image: louislam/uptime-kuma:1
 6    container_name: uptime-kuma
 7    volumes:
 8      - /root/uptime-kuma/:/app/data
 9      -  /var/run/docker.sock:/var/run/docker.sock
10    ports:
11      - "3001:3001"  # <Host Port>:<Container Port>
12    restart: unless-stopped

To install and execute the container, I used the following command:

1docker compose -f uptimeKuma-compose.yml up -d

After this, the web UI becomes accessible via the URL: http://<Server_IP>:UptimeKuma_Port

Configuration

When configuring UptimeKuma, the first step is to change your login data. In order to do so, navigate to Settings -> Security -> Change Password.

To add a new monitor for one of your services, click the add new monitor button in the top right corner.

Select the monitor type based on how UptimeKuma should monitor your service. For Instance, for monitoring a Docker container, choose Docker Container. The Friendly Name field is the display name for your monitor.

Set the Container Name/ID to the name or ID of the Docker container you want to monitor. Retrieve this information from your Docker Compose file or using the command docker ps -a. Specify the Docker Host to indicate where UptimeKuma should listen for the Docker container.

The Heartbeat Interval determines how often UptimeKuma checks your service. After configuring, click save, and the monitor will appear on the UptimeKuma web UI, checking your service periodically.

To receive notifications when the status of your service changes, set up notifications by editing a service monitor and clicking Setup Notification.

For Telegram notifications, follow these steps:

  1. Contact the Telegram Bot BotFather to create a new bot. The /start command, will show you a guide on how to setup a bot. Alternatively, you can follow the steps below.
  2. Use the /newbot command to create a new bot, following BotFather’s guidance.

3. After creating the bot, copy the HTTP API token and enter it in UptimeKuma.
4. Test the configuration and save it. You can now enable Telegram notifications for all your site monitors.


References: