auto-sync: 2026-03-25 23:50:25
This commit is contained in:
Executable
+74
@@ -0,0 +1,74 @@
|
||||
#!/bin/bash
|
||||
|
||||
# 自动双向同步脚本
|
||||
# 每分钟运行一次,双向同步本地和远程Gitee
|
||||
# 错误处理:失败了记录日志不继续错误扩散
|
||||
|
||||
PROJECT_DIR="/Users/chufeng/.openclaw/sanguo_projects/sanguo_quant_live"
|
||||
LOG_FILE="$PROJECT_DIR/auto-sync.log"
|
||||
MAX_RETRIES=2
|
||||
|
||||
# 确保目录存在
|
||||
cd "$PROJECT_DIR" || {
|
||||
echo "[$(date)] ERROR: Failed to cd into $PROJECT_DIR" >> "$LOG_FILE"
|
||||
exit 1
|
||||
}
|
||||
|
||||
echo "[$(date)] Starting auto sync..." >> "$LOG_FILE"
|
||||
|
||||
# 第一步:git pull 拉取远程变更
|
||||
echo "[$(date)] Step 1: git pull origin main" >> "$LOG_FILE"
|
||||
git pull origin main
|
||||
exit_code=$?
|
||||
|
||||
if [ $exit_code -ne 0 ]; then
|
||||
echo "[$(date)] WARNING: git pull failed with exit code $exit_code" >> "$LOG_FILE"
|
||||
# pull失败不推送,避免冲突
|
||||
exit 1
|
||||
fi
|
||||
|
||||
echo "[$(date)] git pull success" >> "$LOG_FILE"
|
||||
|
||||
# 第二步:检查本地是否有变更
|
||||
git diff --quiet
|
||||
exit_code=$?
|
||||
|
||||
if [ $exit_code -eq 0 ]; then
|
||||
# 没有变更,正常退出
|
||||
echo "[$(date)] No local changes, exiting." >> "$LOG_FILE"
|
||||
exit 0
|
||||
fi
|
||||
|
||||
# 有变更,进行提交
|
||||
echo "[$(date)] Step 2: Found local changes, committing..." >> "$LOG_FILE"
|
||||
|
||||
git add .
|
||||
exit_code=$?
|
||||
if [ $exit_code -ne 0 ]; then
|
||||
echo "[$(date)] ERROR: git add failed with exit code $exit_code" >> "$LOG_FILE"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
git commit -m "auto-sync: $(date '+%Y-%m-%d %H:%M:%S')"
|
||||
exit_code=$?
|
||||
if [ $exit_code -ne 0 ]; then
|
||||
echo "[$(date)] ERROR: git commit failed with exit code $exit_code" >> "$LOG_FILE"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# 推送到远程
|
||||
echo "[$(date)] Step 3: Pushing to origin/main..." >> "$LOG_FILE"
|
||||
|
||||
for i in $(seq 1 $MAX_RETRIES); do
|
||||
git push origin main
|
||||
exit_code=$?
|
||||
if [ $exit_code -eq 0 ]; then
|
||||
echo "[$(date)] Push success! Sync complete." >> "$LOG_FILE"
|
||||
exit 0
|
||||
fi
|
||||
echo "[$(date)] Push attempt $i failed, retrying..." >> "$LOG_FILE"
|
||||
sleep 2
|
||||
done
|
||||
|
||||
echo "[$(date)] ERROR: Push failed after $MAX_RETRIES attempts" >> "$LOG_FILE"
|
||||
exit 1
|
||||
Reference in New Issue
Block a user