对镜像精简

dive工具,用来优化镜像大小

ENV命令合并

复制代码
ENV DEBUG_PORT=8777 \
    HTTP_PORT=12080 \
    PROGRAM_FILE_HOME_UPORTAL_CONF=/home/zenap/uportal/conf

WORKDIR usr/src/app,会切换到这个目录

使用COPY --chown 修改属主,不要使用RUN chown

容器内非root运行业务,要对目录和文件chown,增加镜像大小。构建镜像时,使用COPY --chown,使用 buildkit 或docker v17.x及以上版本。

由于PaaS使用docker v1.12.6,使用高于v1.12.6的docker版本,构建镜像有可能出现不兼容的问题。

错误示例:

COPY data /home/conf

RUN addgroup -g 1340 -S app

&& adduser app -D -s /sbin/nologin -G app -u 1340

&& mkdir /home/conf

&& chown -R app:app /home/conf

正确示例:

RUN addgroup -g 1340 -S app

&& adduser app -D -h /home/app -s /sbin/nologin -G app -u 1340

COPY --chown=app:app data /home/app/conf

相关推荐
_Djhhh7 小时前
【Go】1、Go语言基础
golang
fashia14 小时前
Java转Go日记(五十六):gin 渲染
开发语言·后端·golang·go·gin
Spring-wind15 小时前
【Kafka】编写消费者开发模式时遇到‘未解析的引用‘SIGUSR1’’
分布式·中间件·golang·kafka
c无序18 小时前
【Go-4】函数
开发语言·后端·golang
Clown9519 小时前
Go语言爬虫系列教程(二) HTTP请求与响应处理详解
爬虫·http·golang
BUG制造机.1 天前
代码走读 Go 语言 Map 的实现
golang·哈希算法·散列表
白总Server1 天前
React-fiber架构
开发语言·网络·网络协议·golang·scala·核心·fiber
knan-阿樂1 天前
Golang 内存模型小结
golang
fashia1 天前
Java转Go日记(五十四):gin路由
开发语言·后端·golang·go·html·gin
FreeBuf_2 天前
基于Go语言的恶意软件通过Redis配置滥用向Linux主机部署XMRig挖矿程序
linux·redis·golang