rclon commited on
Commit
96645ff
·
verified ·
1 Parent(s): bd5bc0b

Create sync_data.sh

Browse files
Files changed (1) hide show
  1. sync_data.sh +110 -0
sync_data.sh ADDED
@@ -0,0 +1,110 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ set -e
2
+
3
+ # 检查必要的环境变量
4
+ if [ -z "$G_NAME" ] || [ -z "$G_TOKEN" ]; then
5
+ echo "缺少必要的环境变量 G_NAME 或 G_TOKEN"
6
+ exit 1
7
+ fi
8
+
9
+ # 解析仓库名和用户名
10
+ IFS='/' read -r GITHUB_USER GITHUB_REPO <<< "$G_NAME"
11
+
12
+ # 构建 GitHub 仓库的克隆 URL,包含令牌
13
+ REPO_URL="https://${G_TOKEN}@github.com/${G_NAME}.git"
14
+
15
+ # 检查并创建目录
16
+ mkdir -p ./data ./github_data
17
+
18
+ # 克隆仓库
19
+ echo "正在克隆仓库……"
20
+ git clone "$REPO_URL" ./github_data || {
21
+ echo "克隆失败,请检查 G_NAME 和 G_TOKEN 是否正确。"
22
+ exit 1
23
+ }
24
+
25
+ if [ -f ./github_data/webui.db ]; then
26
+ mv ./github_data/webui.db ./data/webui.db
27
+ echo "从 GitHub 仓库中拉取成功"
28
+ else
29
+ echo "GitHub 仓库中未找到 webui.db,将在同步时推送"
30
+ fi
31
+
32
+ # 定义同步函数
33
+ sync_data() {
34
+ while true; do
35
+ # 1. 同步到 GitHub
36
+ echo "正在开始同步"
37
+
38
+ # 进入仓库目录
39
+ cd ./github_data
40
+
41
+ # 配置 Git 用户信息
42
+ git config user.name "AutoSync Bot"
43
+ git config user.email "autosync@bot.com"
44
+
45
+ # 确保在正确的分支
46
+ git checkout main || git checkout master
47
+
48
+ # 复制最新的数据库文件
49
+ cp ../data/webui.db ./webui.db
50
+
51
+ # 检查是否有变化
52
+ if [[ -n $(git status -s) ]]; then
53
+ # 添加所有变更
54
+ git add webui.db
55
+
56
+ # 提交变更
57
+ git commit -m "Auto sync webui.db $(date '+%Y-%m-%d %H:%M:%S')"
58
+
59
+ # 推送到远程仓库
60
+ git push origin HEAD && {
61
+ echo "GitHub推送成功"
62
+ }|| {
63
+ echo "推送失败,等待重试..."
64
+ sleep 10
65
+ git push origin HEAD || {
66
+ echo "重试失败,放弃推送到Github。"
67
+ }
68
+ }
69
+ # 返回上级目录
70
+ cd ..
71
+
72
+ # 2. 同步到 WebDAV
73
+ if [ -z "$WEBDAV_URL" ] || [ -z "$WEBDAV_USERNAME" ] || [ -z "$WEBDAV_PASSWORD" ]; then
74
+ echo "WebDAV 环境变量缺失,跳过 WebDAV 同步。"
75
+ else
76
+ echo "同步到 WebDAV..."
77
+ FILENAME="webui_$(date +'%m_%d').db"
78
+ # 检查是否存在要上传的文件
79
+ if [ -f ./data/webui.db ]; then
80
+ # 使用 curl 进行文件上传
81
+ curl -T ./data/webui.db --user "$WEBDAV_USERNAME:$WEBDAV_PASSWORD" "$WEBDAV_URL/$FILENAME" && {
82
+ echo "WebDAV 上传成功"
83
+ } || {
84
+ echo "WebDAV 上传失败,等待重试..."
85
+ sleep 10
86
+ curl -T ./data/webui.db --user "$WEBDAV_USERNAME:$WEBDAV_PASSWORD" "$WEBDAV_URL/$FILENAME" || {
87
+ echo "重试失败,放弃webdav上传。"
88
+ }
89
+ }
90
+ else
91
+ echo "未找到 webui.db 文件,跳过 WebDAV 同步"
92
+ fi
93
+ fi
94
+
95
+
96
+ else
97
+ # 返回上级目录
98
+ cd ..
99
+ echo "GitHub: 没有检测到数据库变化"
100
+ fi
101
+ # 3. 等待统一的时间间隔
102
+ SYNC_INTERVAL=${SYNC_INTERVAL:-7200} # 默认间隔时间为 7200 秒
103
+ echo "等待 ${SYNC_INTERVAL} 秒后进行下一次同步..."
104
+ sleep $SYNC_INTERVAL
105
+
106
+ done
107
+ }
108
+
109
+ # 后台启动同步进程
110
+ sync_data &