fix: use file-bind-mount for DB to allow local WAL files
All checks were successful
Build and Push Docker Image / build-and-push (push) Successful in 43s
All checks were successful
Build and Push Docker Image / build-and-push (push) Successful in 43s
This commit is contained in:
@@ -81,7 +81,6 @@ start_app() {
|
|||||||
mkdir -p /shared_data/plugins /shared_data/cache /shared_data/backup /shared_data/artist_images /shared_data/artwork
|
mkdir -p /shared_data/plugins /shared_data/cache /shared_data/backup /shared_data/artist_images /shared_data/artwork
|
||||||
|
|
||||||
# SEEDING LOGIC: If DB doesn't exist in cluster, restore from backup
|
# SEEDING LOGIC: If DB doesn't exist in cluster, restore from backup
|
||||||
# LiteFS 0.5.x: check if DB file exists in FUSE mount
|
|
||||||
if [ ! -f /data/navidrome.db ]; then
|
if [ ! -f /data/navidrome.db ]; then
|
||||||
echo "Database /data/navidrome.db not found. Looking for backups to seed..."
|
echo "Database /data/navidrome.db not found. Looking for backups to seed..."
|
||||||
local latest_backup=$(ls -t /shared_data/backup/navidrome.db_*.bak 2>/dev/null | head -n 1)
|
local latest_backup=$(ls -t /shared_data/backup/navidrome.db_*.bak 2>/dev/null | head -n 1)
|
||||||
@@ -102,28 +101,25 @@ start_app() {
|
|||||||
db_count=$((db_count + 1))
|
db_count=$((db_count + 1))
|
||||||
done
|
done
|
||||||
|
|
||||||
# Setup local data folder with symlinks
|
# Setup local data folder with BIND MOUNT for the DB
|
||||||
# This avoids "mkdir /data/artwork: operation not permitted"
|
# This allows SQLite to create -wal/-shm files in the local writable directory
|
||||||
# and avoids SMB symlink/mount issues
|
# while the main DB file is managed by LiteFS.
|
||||||
rm -rf /local/navidrome_data
|
rm -rf /local/navidrome_data
|
||||||
mkdir -p /local/navidrome_data
|
mkdir -p /local/navidrome_data
|
||||||
|
|
||||||
ln -s /data/navidrome.db /local/navidrome_data/navidrome.db
|
touch /local/navidrome_data/navidrome.db
|
||||||
ln -s /shared_data/cache /local/navidrome_data/cache
|
mount --bind /data/navidrome.db /local/navidrome_data/navidrome.db
|
||||||
ln -s /shared_data/plugins /local/navidrome_data/plugins
|
|
||||||
ln -s /shared_data/artwork /local/navidrome_data/artwork
|
|
||||||
ln -s /shared_data/backup /local/navidrome_data/backup
|
|
||||||
|
|
||||||
# Configuration
|
# Configuration
|
||||||
export ND_DATAFOLDER="/local/navidrome_data"
|
export ND_DATAFOLDER="/local/navidrome_data"
|
||||||
export ND_CACHEFOLDER="/local/navidrome_data/cache"
|
export ND_CACHEFOLDER="/shared_data/cache"
|
||||||
export ND_BACKUP_PATH="/local/navidrome_data/backup"
|
export ND_BACKUP_PATH="/shared_data/backup"
|
||||||
export ND_PLUGINS_FOLDER="/local/navidrome_data/plugins"
|
export ND_PLUGINS_FOLDER="/shared_data/plugins"
|
||||||
export ND_ARTISTIMAGEFOLDER="artist_images"
|
export ND_ARTISTIMAGEFOLDER="artist_images"
|
||||||
|
|
||||||
/app/navidrome &
|
/app/navidrome &
|
||||||
NAVIDROME_PID=$!
|
NAVIDROME_PID=$!
|
||||||
echo "Navidrome running (PID: $NAVIDROME_PID) with DataFolder at /local/navidrome_data"
|
echo "Navidrome running (PID: $NAVIDROME_PID) with DataFolder at /local/navidrome_data (DB bind-mounted)"
|
||||||
}
|
}
|
||||||
|
|
||||||
# Stop Navidrome
|
# Stop Navidrome
|
||||||
@@ -133,6 +129,7 @@ stop_app() {
|
|||||||
kill -SIGTERM "${NAVIDROME_PID}"
|
kill -SIGTERM "${NAVIDROME_PID}"
|
||||||
wait "${NAVIDROME_PID}" 2>/dev/null || true
|
wait "${NAVIDROME_PID}" 2>/dev/null || true
|
||||||
NAVIDROME_PID=0
|
NAVIDROME_PID=0
|
||||||
|
umount /local/navidrome_data/navidrome.db 2>/dev/null || true
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -13,7 +13,7 @@ lease:
|
|||||||
advertise-url: "http://${ADVERTISE_IP}:20202"
|
advertise-url: "http://${ADVERTISE_IP}:20202"
|
||||||
consul:
|
consul:
|
||||||
url: "${CONSUL_URL}"
|
url: "${CONSUL_URL}"
|
||||||
key: "litefs/navidrome-v6"
|
key: "litefs/navidrome-v7"
|
||||||
ttl: "30s"
|
ttl: "30s"
|
||||||
lock-delay: "5s"
|
lock-delay: "5s"
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user