对镜像精简

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

相关推荐
geovindu10 分钟前
go: Facade Pattern
设计模式·golang·外观模式
小众AI10 分钟前
Go 多账户 WebDAV 服务实现
golang
念何架构之路1 小时前
图解defer
开发语言·后端·golang
我喜欢山,也喜欢海3 小时前
Java和go在并发上的表现为什么不一样
java·python·golang
geovindu4 小时前
go: Flyweight Pattern
开发语言·设计模式·golang·享元模式
不会写DN13 小时前
Golang中的map的key可以是哪些类型?可以嵌套map吗?
后端·golang·go
止语Lab17 小时前
Go vs Java GC:同一场延迟战争的两条路
java·开发语言·golang
MmeD UCIZ20 小时前
GO 快速升级Go版本
开发语言·redis·golang
mOok ONSC21 小时前
对基因列表中批量的基因进行GO和KEGG注释
开发语言·数据库·golang
Achou.Wang1 天前
go语言中类型别名和定义类型之间的区别
服务器·golang