選擇最簡單的鏡像linux
好比 alpine,整個鏡像 5M 左右git
設置鏡像時區github
RUN apk add --no-cache tzdata
ENV TZ Asia/Shanghaigolang
第一階段構建出可執行文件,確保構建過程獨立於宿主機docker
第二階段將第一階段的輸出做爲輸入,構建出最終的極簡鏡像json
首先安裝 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":""}
goctl 工具極大簡化了 Dockerfile 文件的編寫,提供了開箱即用的最佳實踐,而且流量交易支持了模板自定義。若是以爲工具備幫助,歡迎 star