使用go mod结合docker分层缓存进行自动CI/CD
本文地址:https://www.cnblogs.com/likeli/p/10521941.html
喜大奔的go mod
官方背书的go mod拯救了我的代码洁癖症!
环境
- go v1.12
- docker ce 18.09.0
- gitlab ce latest
godep
写go程序,若是仅仅是你一个人写,或者就是写个小工具玩儿玩儿,依赖管理对你来说可能没那么重要。
但是在商业的工程项目里,多人协同,go的依赖管理就尤为重要了,之前可选的其实不太多,社区提供的实现方式大多差不多的思路,比如我之前使用的godep
。所以项目中会有一个vendor
文件夹来存放外部的依赖,这样:
这样的实现方式,每次更新了外部依赖,其他人就得拉下来一大坨。。。
go mod
来看看使用官方的module来管理依赖的工程结构:
是不是,清爽无比,项目也整个瘦身了!
简单的说一下go mod help,至于开启go mod的步骤,其他网文一大堆,就不复制了。毕竟本文是说go工程CI/CD的。
在目前go v1.12
版本下,命令go mod help
结果如下:
The commands are:
download download modules to local cache
edit edit go.mod from tools or scripts
graph print module requirement graph
init initialize new module in current directory
tidy add missing and remove unused modules
vendor make vendored copy of dependencies
verify verify dependencies have expected content
why explain why packages or modules are needed
后面CI/CD需要用到的是download
指令。
dockerfile
来看看我这个工程的dockerfile:
FROM golang:1.12 as build
ENV GOPROXY https://go.likeli.top
ENV GO111MODULE on
WORKDIR /go/cache
ADD go.mod .
ADD go.sum .
RUN go mod download
WORKDIR /go/release
ADD . .
RUN GOOS=linux CGO_ENABLED=0 go build -ldflags="-s -w" -installsuffix cgo -o app main.go
FROM scratch as prod
COPY --from=build /etc/localtime /etc/localtime
COPY --from=build /etc/ssl/certs/ca-certificates.crt /etc/ssl/certs/ca-certificates.crt
COPY --from=build /go/release/app /
COPY --from=build /go/release/conf.yaml /
CMD ["/app"]
我这个项目有一些外部依赖,在本地开发的时候都已调整好,并且编译通过,在本地开发环境已经生成了两个文件go.mod
、go.sum
在dockerfile的第一步骤中,先启动module模式,且配置代理,因为有些墙外的包服务没有梯子的情况下也是无法下载回来的,这里的代理域名是我自己的,有需要的也可以用。
指令RUN go mod download
执行的时候,会构建一层缓存,包含了该项所有的依赖。之后再次提交的代码中,若是go.mod
、go.sum
没有变化,就会直接使用该缓存,起到加速构建的作用,也不用重复的去外网下载依赖
了。若是这两个文件发生了变化,就会重新构建这个缓存分层。
使用缓存构建的效果:
这个加速效果是很明显的。
减小体积
go构建命令使用-ldflags="-s -w"
在官方文档:Command_Line里面说名了-s -w
参数的意义,按需选择即可。
-
-s
: 省略符号表和调试信息 -
-w
: 省略DWARF符号表
看起来效果不错