feat: 添加 Gitea webhook 自动部署功能

- 新增独立的 webhook 服务 (Go, 端口 9000)
- HMAC-SHA256 签名验证
- 零停机热更新部署
- 自动清理旧镜像
- 完整配置文档 WEBHOOK_SETUP.md
- 精简 README 版本历史为表格形式
This commit is contained in:
CHE LIANG ZHAO
2026-01-13 14:37:01 +08:00
parent 471bdeaf6b
commit 05ab270677
9 changed files with 1062 additions and 22 deletions

52
webhook/Dockerfile Normal file
View File

@@ -0,0 +1,52 @@
# Webhook 服务 Dockerfile
# 多阶段构建:编译阶段 + 运行阶段
# ===== 编译阶段 =====
FROM golang:1.21-alpine AS builder
WORKDIR /build
# 配置 Alpine 镜像源(国内)
RUN sed -i 's/dl-cdn.alpinelinux.org/mirrors.aliyun.com/g' /etc/apk/repositories
# 配置 Go 代理(国内镜像)
ENV GOPROXY=https://goproxy.cn,direct
# 安装编译依赖
RUN apk add --no-cache git
# 复制代码
COPY . .
# 构建二进制
RUN CGO_ENABLED=0 GOOS=linux go build -ldflags="-s -w" -o webhook .
# ===== 运行阶段 =====
FROM alpine:3.19
WORKDIR /app
# 配置 Alpine 镜像源(国内)
RUN sed -i 's/dl-cdn.alpinelinux.org/mirrors.aliyun.com/g' /etc/apk/repositories
# 安装必要工具
RUN apk add --no-cache bash curl git docker-cli docker-compose ca-certificates tzdata
# 设置时区
ENV TZ=Asia/Shanghai
# 从编译阶段复制二进制
COPY --from=builder /build/webhook /usr/local/bin/webhook
# 注意deploy.sh 通过 volume 挂载,不在构建时复制
# 因为 deploy.sh 在仓库根目录,而 Dockerfile 在 webhook 目录
# 暴露端口
EXPOSE 9000
# 健康检查
HEALTHCHECK --interval=10s --timeout=5s --retries=3 \
CMD curl -f http://localhost:9000/health || exit 1
# 启动服务
CMD ["webhook"]