Spaces:
Running
Running
Create start.sh
Browse files
start.sh
ADDED
@@ -0,0 +1,101 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
#!/bin/bash
|
2 |
+
|
3 |
+
# 设置默认值
|
4 |
+
MUSIC_DIR=${MUSIC_DIR:-/music}
|
5 |
+
DATASET_MUSIC_NAME=${DATASET_MUSIC_NAME:-"your-username/music-dataset"}
|
6 |
+
MUSIC_TOKEN=${MUSIC_TOKEN:-""}
|
7 |
+
BACKUP_DATASET_ID=${BACKUP_DATASET_ID:-"your-username/navidrome-backup"}
|
8 |
+
BACKUP_INTERVAL=${BACKUP_INTERVAL:-3600} # 默认3600秒备份一次
|
9 |
+
|
10 |
+
echo "[INFO] Starting Navidrome setup"
|
11 |
+
|
12 |
+
# 确保目录存在并有正确权限
|
13 |
+
mkdir -p ${MUSIC_DIR}
|
14 |
+
mkdir -p /data/cache
|
15 |
+
mkdir -p /.cache
|
16 |
+
chmod -R 755 ${MUSIC_DIR}
|
17 |
+
chmod -R 755 /data
|
18 |
+
chmod -R 755 /.cache
|
19 |
+
|
20 |
+
# 激活Python虚拟环境
|
21 |
+
source /venv/bin/activate
|
22 |
+
|
23 |
+
# 恢复备份
|
24 |
+
if [ -n "$BACKUP_DATASET_ID" ] && [ -n "$MUSIC_TOKEN" ]; then
|
25 |
+
echo "[INFO] Attempting to restore from backup..."
|
26 |
+
python /backup.py download "$MUSIC_TOKEN" "$BACKUP_DATASET_ID" "/data"
|
27 |
+
fi
|
28 |
+
|
29 |
+
# 下载数据集中的音乐文件到音乐目录
|
30 |
+
if [ -n "$DATASET_MUSIC_NAME" ] && [ -n "$MUSIC_TOKEN" ]; then
|
31 |
+
echo "[INFO] Downloading music files from Hugging Face Dataset..."
|
32 |
+
python -c "
|
33 |
+
from huggingface_hub import snapshot_download
|
34 |
+
import os
|
35 |
+
import shutil
|
36 |
+
# 设置环境变量
|
37 |
+
os.environ['HF_TOKEN'] = '${MUSIC_TOKEN}'
|
38 |
+
music_dir = '${MUSIC_DIR}'
|
39 |
+
dataset_name = '${DATASET_MUSIC_NAME}'
|
40 |
+
try:
|
41 |
+
# 确保缓存目录存在并有正确权限
|
42 |
+
os.makedirs('/.cache', exist_ok=True)
|
43 |
+
|
44 |
+
# 下载数据集
|
45 |
+
print(f'Downloading dataset {dataset_name} to {music_dir}')
|
46 |
+
snapshot_download(
|
47 |
+
repo_id=dataset_name,
|
48 |
+
repo_type='dataset',
|
49 |
+
local_dir=music_dir,
|
50 |
+
token=os.environ['HF_TOKEN']
|
51 |
+
)
|
52 |
+
print('Download completed successfully')
|
53 |
+
except Exception as e:
|
54 |
+
print(f'Error downloading dataset: {str(e)}')
|
55 |
+
# 创建测试文件确保目录不为空
|
56 |
+
with open(os.path.join(music_dir, 'test.txt'), 'w') as f:
|
57 |
+
f.write('This is a test file')
|
58 |
+
"
|
59 |
+
fi
|
60 |
+
|
61 |
+
# 检查音乐目录
|
62 |
+
echo "[INFO] Checking music directory..."
|
63 |
+
ls -la ${MUSIC_DIR}
|
64 |
+
|
65 |
+
# 备份函数
|
66 |
+
backup_data() {
|
67 |
+
while true; do
|
68 |
+
echo "[INFO] Starting backup process $(date)"
|
69 |
+
|
70 |
+
if [ -d "/data" ]; then
|
71 |
+
echo "[INFO] Backing up Navidrome data to HuggingFace..."
|
72 |
+
python /backup.py upload "$MUSIC_TOKEN" "$BACKUP_DATASET_ID" "/data"
|
73 |
+
else
|
74 |
+
echo "[WARNING] Data directory does not exist, skipping backup..."
|
75 |
+
fi
|
76 |
+
|
77 |
+
echo "[INFO] Next backup in ${BACKUP_INTERVAL} seconds..."
|
78 |
+
sleep $BACKUP_INTERVAL
|
79 |
+
done
|
80 |
+
}
|
81 |
+
|
82 |
+
# 如果设置了备份数据集ID,则启动备份进程
|
83 |
+
if [ -n "$BACKUP_DATASET_ID" ] && [ -n "$MUSIC_TOKEN" ]; then
|
84 |
+
echo "[INFO] Starting backup process with dataset: ${BACKUP_DATASET_ID}"
|
85 |
+
backup_data &
|
86 |
+
else
|
87 |
+
echo "[WARNING] Backup disabled. Set BACKUP_DATASET_ID and MUSIC_TOKEN to enable."
|
88 |
+
fi
|
89 |
+
|
90 |
+
# 找到navidrome可执行文件的路径
|
91 |
+
NAVIDROME_PATH=$(which navidrome || find /app -name navidrome -type f 2>/dev/null | head -1)
|
92 |
+
|
93 |
+
if [ -z "$NAVIDROME_PATH" ]; then
|
94 |
+
echo "[ERROR] Could not find navidrome executable"
|
95 |
+
exit 1
|
96 |
+
else
|
97 |
+
echo "[INFO] Found navidrome at: $NAVIDROME_PATH"
|
98 |
+
# 启动Navidrome
|
99 |
+
echo "[INFO] Starting Navidrome..."
|
100 |
+
exec $NAVIDROME_PATH
|
101 |
+
fi
|