最简单的 Go Dockerfile 编写姿式,没有之一!

  1. Dockerfile 一些额外注意点

选择最简单的镜像linux

好比 alpine,整个镜像 5M 左右git

设置镜像时区github

RUN apk add --no-cache tzdata
ENV TZ Asia/Shanghaigolang

  1. 多阶段构建

第一阶段构建出可执行文件,确保构建过程独立于宿主机docker

第二阶段将第一阶段的输出做为输入,构建出最终的极简镜像json

  1. 完整 Dockerfile 编写过程

首先安装 goctl 工具api

GO111MODULE=on GOPROXY=https://goproxy.cn/,direct go get -u github.com/tal-tech/go-zero/tools/goctlapp

在 greet 项目下建立一个 hello 服务curl

goctl api new hello
文件结构以下:
greet
├── go.mod
├── go.sum
└── service工具

└── hello
    ├── etc
    │   └── hello-api.yaml
    ├── hello.api
    ├── hello.go
    └── internal
        ├── config
        │   └── config.go
        ├── handler
        │   ├── hellohandler.go
        │   └── routes.go
        ├── logic
        │   └── hellologic.go
        ├── svc
        │   └── servicecontext.go
        └── types
            └── types.go

在 hello 目录下一键生成 Dockerfile,命令以下

goctl docker -go greet.go
Dockerfile 内容以下:
FROM golang:alpine AS builder

LABEL stage=gobuilder

ENV CGO_ENABLED 0
ENV GOOS linux
ENV GOPROXY https://goproxy.cn,direct

WORKDIR /build/zero

ADD go.mod .
ADD go.sum .
RUN go mod download
COPY . .
COPY service/hello/etc /app/etc
RUN go build -ldflags="-s -w" -o /app/hello service/hello/hello.go

FROM alpine

RUN apk update --no-cache && apk add --no-cache ca-certificates tzdata
ENV TZ Asia/Shanghai

WORKDIR /app
COPY --from=builder /app/hello /app/hello
COPY --from=builder /app/etc /app/etc

CMD ["./hello", "-f", "etc/hello-api.yaml"]

在 greet 目录下 build 镜像

docker build -t hello:v1 -f service/hello/Dockerfile .

查看镜像

hello v1 5455f2eaea6b 7 minutes ago 18.1MB
能够看出镜像大小约为 18M。

启动服务

docker run --rm -it -p 8888:8888 hello:v1

测试服务

$ curl -i :8888/from/you
HTTP/1.1 200 OK
Content-Type: application/json
Date: Thu, 10 Dec 2020 06:03:02 GMT
Content-Length: 14

{"message":""}

  1. 总结

goctl 工具极大简化了 Dockerfile 文件的编写,提供了开箱即用的最佳实践,而且流量交易支持了模板自定义。若是以为工具备帮助,欢迎 star 

相关文章
相关标签/搜索