重构 Dockerfile 添加构建过程
This commit is contained in:
42
Dockerfile
42
Dockerfile
@@ -1,10 +1,44 @@
|
||||
FROM ubuntu:20.04
|
||||
# 第一阶段:构建
|
||||
FROM golang:1.24.0 AS builder
|
||||
|
||||
WORKDIR /build
|
||||
|
||||
# 复制Go模块文件
|
||||
COPY go.mod go.sum ./
|
||||
RUN go mod download
|
||||
|
||||
# 复制源代码
|
||||
COPY . .
|
||||
|
||||
# 编译
|
||||
RUN GOOS=linux GOARCH=amd64 go build -ldflags '-w -s' -o bin/platform_linux_amd64 cmd/main/main.go
|
||||
|
||||
# 第二阶段:运行环境
|
||||
FROM ubuntu:24.04
|
||||
|
||||
WORKDIR /app
|
||||
|
||||
COPY ./bin/platform_linux_amd64 /app/platform
|
||||
# 安装依赖包
|
||||
RUN apt-get update && apt-get install -y --no-install-recommends \
|
||||
ca-certificates \
|
||||
&& apt-get clean \
|
||||
&& rm -rf /var/lib/apt/lists/*
|
||||
|
||||
# 从构建阶段复制编译好的二进制文件
|
||||
COPY --from=builder /build/bin/platform_linux_amd64 /app/platform
|
||||
|
||||
# 设置可执行权限
|
||||
RUN chmod +x /app/platform
|
||||
|
||||
EXPOSE $APP_PORT
|
||||
# 创建存放密钥文件的目录
|
||||
RUN mkdir -p /app/certs
|
||||
|
||||
CMD ["/app/proxy"]
|
||||
# 声明暴露端口(实际端口通过环境变量传入)
|
||||
ENV APP_PORT=8080
|
||||
EXPOSE ${APP_PORT}
|
||||
|
||||
# 声明卷,用于在运行时挂载私密的证书文件
|
||||
VOLUME ["/app/certs"]
|
||||
|
||||
# 启动平台服务
|
||||
CMD ["/app/platform"]
|
||||
Reference in New Issue
Block a user