添加网络诊断和重试机制

- 在 sync_repos.py 中添加Git fetch重试机制(最多3次)
- 优化错误处理和超时管理
- 在 workflow中添加网络连通性诊断步骤
- 提供更详细的错误诊断信息

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
This commit is contained in:
2025-11-20 22:18:52 +08:00
parent 19a8bf43ba
commit 059855c6e8
2 changed files with 60 additions and 7 deletions

View File

@@ -56,13 +56,35 @@ def sync_repository(repo_config):
return False
# 获取上游更改
print(f"[3/6] 获取上游更改...")
result = subprocess.run(
['git', 'fetch', 'upstream'],
capture_output=True, text=True, timeout=600
)
if result.returncode != 0:
print(f"❌ 获取上游更改失败:")
print(result.stderr)
max_retries = 3
for attempt in range(1, max_retries + 1):
try:
result = subprocess.run(
['git', 'fetch', 'upstream'],
capture_output=True, text=True, timeout=200
)
if result.returncode == 0:
break
print(f"❌ 获取上游更改失败 (尝试 {attempt}/{max_retries}):")
print(result.stderr)
except subprocess.TimeoutExpired:
print(f"❌ 获取上游更改超时 (尝试 {attempt}/{max_retries})200秒限制")
if attempt < max_retries:
print(f"⏳ 等待5秒后重试...")
time.sleep(5)
else:
# 所有尝试都失败
print(f"\n网络诊断信息:")
print(f"- 错误类型: DNS解析或网络连接失败")
print(f"- 可能原因:")
print(f" 1. Gitea Actions Runner的DNS配置问题")
print(f" 2. Runner容器无法访问外部网络")
print(f" 3. 上游仓库服务器防火墙限制")
print(f"- 解决方案:")
print(f" 1. 在workflow中添加hosts配置")
print(f" 2. 检查Runner的网络设置")
print(f" 3. 使用IP地址替代域名")
return False
# 检查目标分支是否存在
print(f"[4/6] 检查分支...")