最簡單的 Go Dockerfile 編寫姿勢,沒有之一!

seven878發表於2021-02-01

1. Dockerfile 一些額外注意點

  • 選擇最簡單的映象

比如 alpine,整個映象 5M 左右

  • 設定映象時區
RUN apk add --no-cache tzdata
ENV TZ Asia/Shanghai

2. 多階段構建

  • 第一階段構建出可執行檔案,確保構建過程獨立於宿主機
  • 第二階段將第一階段的輸出作為輸入,構建出最終的極簡映象

3. 完整 Dockerfile 編寫過程

  • 首先安裝 goctl 工具

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

  • greet 專案下建立一個 hello 服務

goctl api new hello

檔案結構如下:

greet
├── go.mod
├── go.sum
└── service
    └── hello
        ├── Dockerfile
        ├── 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 http://localhost: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":""}

4. 總結

goctl 工具極大簡化了 Dockerfile 檔案的編寫,提供了開箱即用的最佳實踐,並且支援了模板自定義。

如果覺得工具有幫助,歡迎 star ?

5. 專案地址

https://github.com/tal-tech/go-zero

6. 微信交流群

最簡單的 Go Dockerfile 編寫姿勢,沒有之一!

更多原創文章乾貨分享,請關注公眾號
  • 最簡單的 Go Dockerfile 編寫姿勢,沒有之一!
  • 加微信實戰群請加微信(註明:實戰群):gocnio

相關文章