fix dockerfile
This commit is contained in:
38
Dockerfile
38
Dockerfile
@@ -1,37 +1,47 @@
|
||||
# 第一阶段:构建
|
||||
FROM golang:1.23-alpine AS builder
|
||||
FROM golang:1.24-alpine AS builder
|
||||
|
||||
# 设置工作目录
|
||||
WORKDIR /app
|
||||
|
||||
# 安装必要的构建工具
|
||||
# 安装编译依赖(仅用于 CGO,但你已禁用 CGO,其实可省略)
|
||||
# 如果确实不需要 CGO(如纯 Go 代码),可删除下一行以加速构建
|
||||
RUN apk add --no-cache gcc musl-dev
|
||||
|
||||
# 复制依赖文件并下载
|
||||
# 复制模块文件并下载依赖
|
||||
COPY go.mod go.sum ./
|
||||
RUN go mod download
|
||||
|
||||
# 复制源代码
|
||||
# 复制源码
|
||||
COPY . .
|
||||
|
||||
# 编译应用
|
||||
# CGO_ENABLED=0 用于生成静态二进制文件,适合在 alpine 运行
|
||||
RUN CGO_ENABLED=0 GOOS=linux go build -o server ./cmd/server/main.go
|
||||
# 编译静态二进制(CGO_ENABLED=0 确保无动态链接)
|
||||
RUN CGO_ENABLED=0 GOOS=linux go build -trimpath -ldflags="-s -w" -o server ./cmd/server/main.go
|
||||
|
||||
|
||||
# 第二阶段:运行
|
||||
FROM alpine:latest
|
||||
|
||||
# 安全加固:创建非 root 用户
|
||||
RUN addgroup -g 1001 -S app && \
|
||||
adduser -u 1001 -S app -G app
|
||||
|
||||
WORKDIR /app
|
||||
|
||||
# 从构建阶段复制二进制文件
|
||||
# 从构建阶段复制二进制和静态资源
|
||||
COPY --from=builder /app/server .
|
||||
|
||||
# 复制静态资源文件
|
||||
COPY --from=builder /app/web ./web
|
||||
|
||||
# 暴露端口(默认 2779)
|
||||
# 更改文件所有者(安全最佳实践)
|
||||
RUN chown -R app:app /app
|
||||
|
||||
# 切换到非 root 用户
|
||||
USER app
|
||||
|
||||
# 暴露端口
|
||||
EXPOSE 2779
|
||||
|
||||
# 运行应用(通过 PORT 环境变量可覆盖)
|
||||
# 设置默认端口(可通过 docker run -e PORT=... 覆盖)
|
||||
ENV PORT=2779
|
||||
CMD ["./server"]
|
||||
|
||||
# 启动应用
|
||||
CMD ["./server"]
|
||||
Reference in New Issue
Block a user