各位是如何在 k8s 中做镜像构建的? - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
Vraw5
V2EX    Kubernetes

各位是如何在 k8s 中做镜像构建的?

  •  
  •   Vraw5 165 天前 2984 次点击
    这是一个创建于 165 天前的主题,其中的信息可能已经有所发展或是发生改变。
    集群里有两台机器用作 jenkin kubernetes agent 做 CICD ,以前 k8s 在 1.24 以下时主机使用 docker engine ,我可以通过挂载 docker.sock 直接使用主机的 docker 做镜像,后来 k8s 升级后使用 kaniko 构建镜像,昨天看 kaniko 的 github 已经在两周前归档了,想换掉它,有没有 kaniko 的替代品。
    12 条回复    2025-06-18 08:11:34 +08:00
    beyondstars
        1
    beyondstars  
       165 天前
    lomtom
        2
    lomtom  
       165 天前
    @beyondstars 之前写过关于 buildkit 的使用,这个确实可以,可以参考一下 https://lomtom.cn/vrqlkpdd61y0
    justdoit123
        3
    justdoit123  
       165 天前
    什么? kaniko 这玩意归档了啊?

    https://github.com/GoogleContainerTools/kaniko/issues/3348#issuecomment-2935160773

    > This was never an official Google product. This is dead, time to move to buildkit or buildah.

    坐等一个替代品建议。求有用过大佬分享一下替代品的使用体验。
    anubu
        4
    anubu  
       165 天前
    变更最小的就是 dind ,以 ds 部署 docker ,然后挂载 docker.sock ,和原流程几乎没有变化。从挂载宿主机 sock 到 ds 容器的 sock ,可能要再调试认证、缓存、性能等问题。
    shakaraka
        5
    shakaraka  
    PRO
       165 天前
    我也在看在没有 docker 的情况下如何打包构建镜像,也是看到 kaniko 和 buildah 两个
    DreamSpace
        6
    DreamSpace  
       165 天前
    https://tekton.dev/
    我用 Tekton+K3S 做的 CI ,体验尚可,这个比较适合包装一下做成 CI/CD 平台
    DreamSpace
        7
    DreamSpace  
       165 天前
    不好意思没看清题目,我也用的 tekton 打包,竟然已经归档了
    Vraw5
        8
    Vraw5  
    OP
       164 天前
    kaniko 在 Readme 中有提到几个其他工具,可以参考。
    https://github.com/GoogleContainerTools/kaniko?tab=readme-ov-file#comparison-with-other-tools

    @wunonglin #5 或许 BuildKit 是最优解。img 已经停更很多年,Buildah 可能需要手动制作一个镜像,我没有找到官方镜像。Bazel rules_docker 不支持 RUN
    Rat3
        9
    Rat3  
       164 天前
    dind + buildkit
    Bromine0x23
        10
    Bromine0x23  
       164 天前
    buildah 的官方镜像是 `quay.io/buildah/stable` 这个?但是这个好像不会合并 ARG 和 ENV 之类的空层。

    buildkit 用 rootless 我这 air-gap 环境搞不定 FROM 的证书校验问题。
    Vraw5
        11
    Vraw5  
    OP
       164 天前
    @Bromine0x23 #10 镜像好像是官方的。明天把 buildah 和 buildkit 都试用试试。

    我看 buildkit 可以做 server-client 模式,是不是可以一直起着一个 Deployment ,做 CI 的时候直接指定 buildctl --addr kube-pod://buildkitd ,就是不清楚 server 能不能同时让多个 client 使用
    feifeizhou
        12
    feifeizhou  
       164 天前 via Android
    我用 podman
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     262 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 21ms UTC 04:10 PVG 12:10 LAX 20:10 JFK 23:10
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86