# Updating How to update TREK to a newer version without losing data. ## Before You Update Back up your data first. Go to Admin Panel → Backups and create a manual backup, or copy your `./data` and `./uploads` directories to a safe location. See [Backups](Backups) for details. ## Docker Compose (Recommended) ```bash docker compose pull && docker compose up -d ``` This pulls the latest image and recreates the container with your existing volumes. Your data is untouched. ## Docker Run If you started TREK with `docker run`, pull the new image and replace the container: ```bash docker pull mauriceboe/trek docker rm -f trek docker run -d --name trek -p 3000:3000 \ -v ./data:/app/data \ -v ./uploads:/app/uploads \ -e ENCRYPTION_KEY= \ --restart unless-stopped \ mauriceboe/trek ``` > **Tip:** Not sure which volume paths you used? Check before removing: > ```bash > docker inspect trek --format '{{json .Mounts}}' > ``` ## Database Migrations TREK runs any pending database migrations automatically at startup. No manual migration steps are required after pulling a new image. ## Encryption Key Note If you are upgrading from a version that predates the dedicated `ENCRYPTION_KEY` (i.e. you have no `ENCRYPTION_KEY` environment variable set), TREK automatically falls back to `./data/.jwt_secret` on startup and immediately promotes it to `./data/.encryption_key`. No manual steps are required — the transition is handled at first boot after the upgrade. If you want to rotate to a new key at any point (not required for a normal update), see [Encryption-Key-Rotation](Encryption-Key-Rotation) for the full procedure. ## Proxmox VE (LXC) If you installed TREK via the [Proxmox VE Community Scripts](https://community-scripts.org/scripts/trek), run the following command inside the **LXC container** and select **Update** when prompted: ```bash bash -c "$(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main/ct/trek.sh)" ``` > **Tip:** Always check the [community-scripts TREK page](https://community-scripts.org/scripts/trek) to confirm the latest command before running. The script stops the service, backs up your data and uploads, applies the new release, restores the backup, and restarts. No manual steps required. To verify the update completed and check for errors: ```bash # Inside the container (pct enter from the Proxmox shell) journalctl -u trek -n 50 ``` ## Unraid In the Unraid Docker tab, click the TREK container and select **Update**. Unraid will pull the latest image and restart with the same volumes. ## Next Steps - [Backups](Backups) — schedule automatic backups so you always have a restore point before updates - [Encryption-Key-Rotation](Encryption-Key-Rotation) — if you need to rotate or migrate the encryption key - [Install-Docker-Compose](Install-Docker-Compose) — switch to Compose for easier future updates