Running on Koyeb

Koyeb is a developer-friendly serverless platform to deploy apps globally. The platform lets you seamlessly run Docker containers, web apps, and APIs with git-based deployment, native autoscaling, free SSL, a global edge network, and built-in service mesh and discovery.

Setup

In this guide, you need to have a PostgreSQL database server running and accepting remote connections. If you do not already have a database, you can check out the Managed database section under Hosting.

You will need to set up the database tables by following the Create database tables section of the Install docs.

To deploy Umami, we use the Koyeb CLI, you can also perform the setup using the Koyeb control panel.

Create Koyeb Secrets

Create two Koyeb secrets to securely store your DATABASE_URL and the HASH_SALT. In the terminal execute the following command:

$ koyeb secret create umami-database-url
Enter your secret: postgres://<user>:<password>@<host>:<port>/<db-name>?sslmode=require

$ openssl rand -hex 32 | koyeb secret create umami-hash-salt --value-from-stdin

Deploy Umami

Once you’ve created the secrets, you can deploy Umami. In your terminal run the following command to create a new Koyeb App and deploy the Umami service:

koyeb app init umami --docker ghcr.io/umami-software/umami:postgresql-latest --ports 3000:http --routes /:3000 --env DATABASE_URL=@umami-database-url --env HASH_SALT=@umami-hash-salt

Your Umami service is being deployed. To retrieve the Umami URL run:

$ koyeb app get umami
ID                                      NAME        DOMAINS                             UPDATED AT
30de8301-05b1-4131-a842-28e608900000    umami       umami-<YOUR_KOYEB_ORG>.koyeb.app    2021-07-06 11:58:01.143967 +0000 UTC

Open the URL to access umami and follow the Getting started guide starting from the Login step.