golang 一份漂亮的Dockerfile


当前第2页 返回上一页

此用户的信息是是需要拷到final中,作为应用程序的启动用户。这是为了避免使用container中的默认用户root,那可是有安全漏洞的,详细解释,可以参考这篇medium上的文章Processes In Containers Should Not Run As Root

再下面的四行,

ENV GOPROXY https://goproxy.cn
COPY go.mod .
COPY go.sum .
RUN go mod download
复制代码

是配置了国内的代理,安装依赖包了。这里用go mod download的好处是下次构建镜像文件时,当go.modgo.sum没有改变时,它是有缓存的,可以避免重复下载依赖包,加快构建。

builder的最后,就是把当前目录的文件拷过去,编译代码了。

COPY . .
RUN CGO_ENABLED=0 GOARCH=amd64 GOOS=linux go build -a -o your-application .
复制代码

final选择了alpine:3.10,一方面是体积小,只有5m;另一方面也是和构建镜像的alpine版本保持一致。

接下来几行没啥说的,就是把构建结果、配置文件(有的话)和用户的相关文件拷过去。

下面的这步一定不要忘记了,

USER app-runner
复制代码

没有它,container启动时就是用root用户启动了!!! 如果被攻击了,那黑客可是就有root权限了(不要问我为啥会被攻击)。

最后,设置一个ENTRYPOINT,完事!


本文来自:简书

感谢作者:陈光岚_强化班

查看原文:golang 一份漂亮的Dockerfile

返回前面的内容

相关阅读 >>

手撸Golang Go与微服务 chatserver之1

手撸Golang spring ioc/aop 之2

Go验证身份证号

Golang用什么开发工具?

Golang map有什么用

Golang 的command启动的进程如何关闭

Golang 是什么写的

Go引入外部依赖的三种方式介绍

Golang判断map中指定key是否存在

深入理解Go的interface

更多相关阅读请进入《Go》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...