2026-02-03 23:45:27 +08:00
|
|
|
|
# 第一阶段:构建
|
2026-02-03 23:54:40 +08:00
|
|
|
|
FROM golang:1.24-alpine AS builder
|
2026-02-03 23:45:27 +08:00
|
|
|
|
|
|
|
|
|
|
WORKDIR /app
|
|
|
|
|
|
|
2026-02-03 23:54:40 +08:00
|
|
|
|
# 安装编译依赖(仅用于 CGO,但你已禁用 CGO,其实可省略)
|
|
|
|
|
|
# 如果确实不需要 CGO(如纯 Go 代码),可删除下一行以加速构建
|
2026-02-03 23:45:27 +08:00
|
|
|
|
RUN apk add --no-cache gcc musl-dev
|
|
|
|
|
|
|
2026-02-03 23:54:40 +08:00
|
|
|
|
# 复制模块文件并下载依赖
|
2026-02-03 23:45:27 +08:00
|
|
|
|
COPY go.mod go.sum ./
|
|
|
|
|
|
RUN go mod download
|
|
|
|
|
|
|
2026-02-03 23:54:40 +08:00
|
|
|
|
# 复制源码
|
2026-02-03 23:45:27 +08:00
|
|
|
|
COPY . .
|
|
|
|
|
|
|
2026-02-03 23:54:40 +08:00
|
|
|
|
# 编译静态二进制(CGO_ENABLED=0 确保无动态链接)
|
|
|
|
|
|
RUN CGO_ENABLED=0 GOOS=linux go build -trimpath -ldflags="-s -w" -o server ./cmd/server/main.go
|
|
|
|
|
|
|
2026-02-03 23:45:27 +08:00
|
|
|
|
|
|
|
|
|
|
# 第二阶段:运行
|
|
|
|
|
|
FROM alpine:latest
|
|
|
|
|
|
|
2026-02-03 23:54:40 +08:00
|
|
|
|
# 安全加固:创建非 root 用户
|
|
|
|
|
|
RUN addgroup -g 1001 -S app && \
|
|
|
|
|
|
adduser -u 1001 -S app -G app
|
|
|
|
|
|
|
2026-02-03 23:45:27 +08:00
|
|
|
|
WORKDIR /app
|
|
|
|
|
|
|
2026-02-03 23:54:40 +08:00
|
|
|
|
# 从构建阶段复制二进制和静态资源
|
2026-02-03 23:45:27 +08:00
|
|
|
|
COPY --from=builder /app/server .
|
|
|
|
|
|
COPY --from=builder /app/web ./web
|
|
|
|
|
|
|
2026-02-03 23:54:40 +08:00
|
|
|
|
# 更改文件所有者(安全最佳实践)
|
|
|
|
|
|
RUN chown -R app:app /app
|
|
|
|
|
|
|
|
|
|
|
|
# 切换到非 root 用户
|
|
|
|
|
|
USER app
|
|
|
|
|
|
|
|
|
|
|
|
# 暴露端口
|
2026-02-03 23:45:27 +08:00
|
|
|
|
EXPOSE 2779
|
|
|
|
|
|
|
2026-02-03 23:54:40 +08:00
|
|
|
|
# 设置默认端口(可通过 docker run -e PORT=... 覆盖)
|
2026-02-03 23:45:27 +08:00
|
|
|
|
ENV PORT=2779
|
2026-02-03 23:54:40 +08:00
|
|
|
|
|
|
|
|
|
|
# 启动应用
|
|
|
|
|
|
CMD ["./server"]
|