Noflux Installation with Docker

This document describes how to use the Docker images of Noflux.

Container Registries

Docker Registries:

Docker images are published to:

Docker Architectures:

Docker Tags Naming Convention:

The recommendation is to use a pinned version to avoid unexpected updates.

How to Run the Container Manually

Pull the image and run the container:

docker run -d \
  -p 80:8080 \
  --name noflux \
  -e "DATABASE_URL=postgres://noflux:*password*@*dbhost*/noflux?sslmode=disable" \
  -e "RUN_MIGRATIONS=1" \
  -e "CREATE_ADMIN=1" \
  -e "ADMIN_USERNAME=*username*" \
  -e "ADMIN_PASSWORD=*password*" \
  docker.io/noflux/noflux:latest

Running the command above will run the migrations and sets up a new admin account with the chosen username and password.

Once the container is started, you should be able to access the application on the exposed port which is port 80 in this example.

Docker Compose

Here is an example of a Docker Compose file:

services:
  noflux:
    image: noflux/noflux:latest
    ports:
      - "80:8080"
    depends_on:
      db:
        condition: service_healthy
    environment:
      - DATABASE_URL=postgres://noflux:secret@db/noflux?sslmode=disable
      - RUN_MIGRATIONS=1
      - CREATE_ADMIN=1
      - ADMIN_USERNAME=admin
      - ADMIN_PASSWORD=test123
  db:
    image: postgres:17-alpine
    environment:
      - POSTGRES_USER=noflux
      - POSTGRES_PASSWORD=secret
      - POSTGRES_DB=noflux
    volumes:
      - noflux-db:/var/lib/postgresql/data
    healthcheck:
      test: ["CMD", "pg_isready", "-U", "noflux"]
      interval: 10s
      start_period: 30s
volumes:
  noflux-db:

There are more examples in the Git repository with Traefik and Caddy: https://github.com/fiatjaf/noflux/tree/master/contrib/docker-compose

You could also configure an optional health check in your Docker Compose file:

noflux:
  image: noflux/noflux:latest
  healthcheck:
    test: ["CMD", "/usr/bin/noflux", "-healthcheck", "auto"]

Make sure to take a look a the list of configuration parameters to customize your installation.