14 Migration From v1 To v2
Nelson Chan edited this page 2024-11-23 18:09:37 +08:00

Warning

It is a major version update. It contains some breaking changes. Please read the migration guide carefully if you want to upgrade from v1 to v2.

Warning

v2 is available in Beta only. You may encounter bugs and stability issues.

Before You Start

  • Stop your Uptime Kuma and:
    • Backup your data directory.
    • Make sure you have a backup of your data directory again.
    • Make sure you have a backup of your data directory again and again.
  • The migration process could take some time to complete, depending on the size of your database.
    • You should be able to view logs of the migration process in the console.
    • Do not interrupt the migration process.
    • FYI: My Uptime Kuma had 20 monitors and 90 days of data, and it took around 7 minutes to migrate.
  • Beta version is not stable and may contain bugs, especially for the first beta release.

Breaking Changes

  • The :duration of these badge endpoints now accept values 24, 24h, 30d, 1y only
    • <kuma-url>/api/badge/:monitorID/ping/:duration
    • <kuma-url>/api/badge/:monitorID/uptime/:duration
  • Dropped support for legacy browsers
  • Removed deprecated feature Backup/Restore from JSON. Backing up the data directory is currently the only supported backup method.
  • Removed deprecated feature DNS Cache for HTTP monitors. Consider using the bundled nscd for docker installation.
  • Updated default retries for NEWLY created monitors from 1 to 0 to prevent user confusion
  • Switched Email (SMTP) notification subject/body templating from a custom-regex to LiquidJS. In LiquidJS,
    • variables are now case-sensitive, and
    • all non-matching variables are ignored.
    • These are the supported variables: name, msg, status, heartbeatJSON, monitorJSON, hostnameOrUrl. We don't have documentation for these yet, but you can refer to the source code for the data structure.

Docker only

Non Docker

  • Dropped support for Node.js 14 and 16. The minimum supported version of Node.js is 18. Node.js 20 is recommended.

Docker Tags

Not available yet.

Unstable Tags

Beta Tags

Tag Description
beta The latest of Beta version of Uptime Kuma
beta-slim (Slim) The latest of Beta version of Uptime Kuma

Other Beta Tags

Tag Description
2.x.x-beta.x Pinned to a specific beta release
2.x.x-beta-slim.x (Slim) Pinned to a specific beta release

Beta Rootless Tags

Warning

Rootless images are not recommended for upgrading from v1 to v2, you will likely run into startup issues.

Warning

⚠️ Rootless images are for users who want to run Uptime Kuma without root privileges, but some features may not work as expected.

Tag Description
beta-rootless The latest of Beta version of Uptime Kuma (Rootless)
beta-slim-rootless (Slim) The latest of Beta version of Uptime Kuma (Rootless)
2.x.x-beta-rootless.x Pinned to a specific beta release (Rootless)
2.x.x-beta-slim-rootless.x (Slim) Pinned to a specific beta release (Rootless)

Nightly Tags

Tag Description
nightly2 Development build
nightly2-rootless Rootless development build

Slim vs Full?

Slim version has a smaller image size, it is about ~300MB to ~400MB smaller than the full version.

Full Version Slim Version
✔️ Embedded MariaDB - Can be used as a low-maintenance, durable and performant storage backend No embedded MariaDB - but you can still connect to an external MariaDB/MySQL database as storage backend
✔️ Embedded Chromium - Can be used for the "Browser Engine" monitor type. Some fonts are also included to improve rendering No embedded Chromium - for the "Browser Engine" monitor type, an external chromium instance or further setup is required

Any big dependencies in the future may be included in the full version only too.

If you don't need the above features, you can use the slim version.

Rootless vs Non-Rootless?

Rootless tags are for users who wants to run Uptime Kuma without root privileges, but some features may not work as expected.

Known issues:

  • ⚠️ Not recommended for upgrading from v1 to v2.
  • ⚠️ If file permission is not set correctly, Uptime Kuma will run into startup issues. You should make sure the ownership of the data directory is set to the node:node (1000:1000) user.
  • Docker monitor will not work without proper configuration, as by default it requires root privileges.
  • Embedded MariaDB doesn't seem to be working on Docker Desktop (Windows), if the data directory is mounted to a Windows folder.

Migration Steps (Docker)

  1. Stop your Uptime Kuma container.
docker stop uptime-kuma
  1. Backup your data directory.
  2. Change the image tag to louislam/uptime-kuma:beta.
docker run -d --restart=unless-stopped -p <YOUR_PORT>:3001 -v <YOUR_DIR OR VOLUME>:/app/data --name uptime-kuma louislam/uptime-kuma:beta
  1. Check the logs to see the migration process.
docker logs -f uptime-kuma

Migration Steps (Docker Compose)

  1. Stop your Uptime Kuma stack.
docker compose down
  1. Backup your data directory.

  2. Change the image tag to louislam/uptime-kuma:beta.

services:
  uptime-kuma:
    image: louislam/uptime-kuma:beta
    ....
  1. Start your Uptime Kuma stack.
docker compose up -d
  1. Check the logs to see the migration process.
docker compose logs -f

Migration Steps (Non-Docker)

Beta is not available for non-docker yet.

FAQ

Can I migrate my existing SQLite database to MariaDB?

Cannot be done directly. You will need to export your data from SQLite and import it into MariaDB using 3rd party tools.