最簡單的Go Dockerfile編寫姿勢,沒有之一!
阿新 • • 發佈:2020-12-10
## 1. Dockerfile一些額外注意點
* 選擇最簡單的映象
比如alpine,整個映象5M左右
* 設定映象時區
```dockerfile
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` 內容如下:
```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`
* 測試服務
```shell
$ 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**