Skip to main content

Command Palette

Search for a command to run...

伸手党的容器镜像加固流程

Updated
1 min read

人在江湖飘,哪能不挨刀

说了好几期 CIS 之类的运行时安全问题,K8s 在运行过程中,还有个常见的安全威胁就是镜像漏洞,不少同学都有在实施过程中因为镜像漏洞问题被吊打的经验,今天就结合个人经验,说说镜像漏洞修复的一般流程。

这里主要指的是第三方镜像的修复过程,Scratch 不在此列。

开局一张图:

修复任务分析

通常扫描报告会明确指明确切的问题源头、相关软件包、问题版本、修复版本等,首先要根据报告判断修复的目标。修复目标并不一定是固定的,有些情况下可能仅需要修复公开的高危漏洞,有些可能要求更多。

我们都知道,容器镜像是个分层结构,底层通常由操作系统(例如 debian:buster-slim)或者特定运行时(例如 openjdk:16)构成;另外可能构建应用程序,或者直接通过 COPY/ADD 的方式加入应用程序;另外还会通过 CMDENV 等指令设置运行环境等。软件漏洞多发于底层和应用程序层,因此这里需要根据扫描报告,确认我们的修复目标。

软件配置问题也可能造成漏洞,可以另行讲解。

应用层漏洞

如果要修复的问题是处于应用层,就要判断该镜像是否为官方镜像,如果答案是肯定的,则可以直接更新官方镜像,通常同一个大版本下的小版本更新,都是兼容的,可以更新之后直接进行测试和复查。

如果官方没有针对性的修复,或者镜像并未更新,就可能需要自己构建镜像了。

如果是开源软件,强烈建议提交 Issue 或者 PR

基础层漏洞

如果是基础层漏洞,除了可以像应用层修复一样,检查版本更新之外,还有另一个选项,就是更换不同的基础层,例如从 Debian 更换为 Ubuntu,这种方式对于 all-in-one 形式的应用(例如大多数用 golang 构建的应用)尤其有效,如果应用程序依赖众多,就不合适了。另外众所周知,Alpine 和我们常用的发行版差异较大,因此也不太合适直接切换。

镜像构建

是不是就一个 docker build 就可以了?多数时候是的。不过要分成几种情况。

  • Dockerfile 的情况

    • 官方已经发布二进制物料:这种情况通过修改 Dockerfile 加入更新的二进制文件之后,执行 docker build 即可。

    • 官方未发布二进制物料:这种就需要根据源码进行构建,然后再生成 Docker 镜像。

  • 没有 Dockerfile 的情况

    • 有的软件源码中通过 Makefile 等方式提供了从二进制到镜像的构建方法,通常需要在 README.md 或者 BUILD.md 中查找线索。

    • 更换底层的情况,通常需要自己照猫画虎,重新编写 Dockerfile。

    • 还有一种比较尴尬的情况——有二进制物料,但是没 Dockerfile,这种我通常会使用 docker cp->docker commit 的不入流方式。

    • 另外一种尴尬情况就是,官方只提供了 Docker 镜像,但是我们想要换掉基础层,这种情况和上面类似,用 docker cp 把官方镜像中的应用文件复制出来即可。

复测

在完成修复步骤之后,可以针对性地进行复测,查看修复情况,循环往复直到完成目标为止。

More from this blog

龙虾恐慌:AIOps 又要改名了?

ChatGPT 开始,把 AI 拉近到普罗大众的面前,让无数人感受到 AI 的亲民魅力。而龙虾,则把大模型驱动的自动化能力,突然间变得水灵灵、活泼泼地走进千家万户。它不只是“风口上的猪”,而是风口本身。热度高到让 Mac mini 一度断货,不知道这在不在库克的预料之内。 每代人都有每代人的鸡蛋,春节期间,我就领了我的鸡蛋。翻出古老的 MacBook Air M1,充值各种大模型。当然了,这个工具

Mar 9, 20261 min read

再见 2025

我猜不少人以为这个号废了吧?并没有,只是今年变化有点大,一直有种抄起键盘,无从说起的感觉,所以一直偷懒到今天,2025 的最后一天。 今年是我的第四个本命年,去年末一期播客里,大内说本命年不是灾年,是变化年,有危也有机。可是讲真啊,只看到危,没看到机。 各种因缘际会,从鹅厂跳槽到前东家,已经接近四年,第一个合同期已经进入尾声。除了前两年还在云原生领域嗷嗷叫,后两年基本都是些鸡零狗碎的东西了,用老东家的术语说是——偏离主航道,可谓是前景暗淡了。 一旦确定要滚蛋,反倒心思轻松起来,每天骑着我的小红车...

Jan 5, 20261 min read

辅助编程?dora 说:我知道你很急可是请你别急

从 OpenGPT 把大模型的火烧旺了之后,这三年来,相信很多组织或摩拳擦掌、或躬身入局,希望借助聪明能干的大模型,或想偿还技术宅,或想降本增效,或想弯道超车。一时间,沉寂许久的 AIxx 又活过来了,LLM Ops、Vibe Coding、中医大模型、GPT 算命等等,全都老树发新芽,焕发了勃勃生机。那么视角拉回从业者最关注的饭碗相关的领域之一——AI 辅助开发,产生了什么触动,应该如何拥抱呢? DORA 的年度报告中给出了很有意思的结论——强者恒强。 执行摘要部分总结了几个有趣的点: 问题...

Oct 6, 20251 min read

[译]dora:ai 辅助软件开发状态报告

执行摘要 在 2025 年,科技领导者面临的核心问题已不再是“是否要采用 AI”,而是“如何实现其价值”。 DORA 的研究基于超过 100 小时的定性访谈和来自全球近 5,000 名技术专业人士的问卷调查。研究揭示了一个关键事实:AI 在软件开发中的主要角色是“放大器”。它会放大高效能组织的优势,也会凸显组织的缺陷。 关键结论:AI 是放大器 AI 投资的最大回报并非来自工具本身,而是来自组织底层系统的战略性建设: 高质量的内部平台 清晰的工作流 团队的协同能力 缺少这些基础,AI ...

Oct 2, 202514 min read

僭越了,有人在用 Rust 写 Kubernetes

一个新语言问世,最爱做的事情之一,就是重写存量软件了。 云原生喝酒 SIG 重点扶持项目——rk8s(https://github.com/rk8s-dev/rk8s) 也可以归在这个范畴里,只不过这个项目重写的东西比较大,是 Kubernetes。 从 2025 年 1 月第一个 Commit 开始,到现在有了 200 多次 Commit,十几万行代码。当然距离 Kubernetes 的几百万行代码还差得远——老马就是喜欢整这种大无畏项目。 另外该项目也是国内第一个脱离 Cargo 转向使用 ...

Sep 27, 20253 min read

【伪】架构师

342 posts