0

0

使用 Spring Boot 3 bootBuildImage 构建 Golang 包?

PHPz

PHPz

发布时间:2024-02-06 08:33:13

|

1027人浏览过

|

来源于stackoverflow

转载

使用 spring boot 3 bootbuildimage 构建 golang 包?

问题内容

我正在使用 spring boot v3.1.5,并使用 bootBuildImage 构建我的映像。 扫描我的图像后,我发现了很多关于 golang 的 CVE。 据我了解,在镜像构建过程中使用了多个 golang 构建包。

有办法解决这个问题吗?我可以配置 spring 来避免使用这些包吗?

我尝试配置使用过的构建包,但没有成功。 我希望在我创建的映像中包含零个 golang 相关文件。


正确答案


非常好!

不,那是不正确的。当您构建 Java 应用程序时,它仅使用与 Java 相关的构建包。它不使用任何 Go 构建包。您可以在构建的输出中看到它使用的构建包列表。它看起来像这样。检测中列出的构建包是唯一被调用的构建包。

===> DETECTING
6 of 26 buildpacks participating
paketo-buildpacks/ca-certificates   3.6.6
paketo-buildpacks/bellsoft-liberica 10.4.2
paketo-buildpacks/syft              1.39.0
paketo-buildpacks/executable-jar    6.8.2
paketo-buildpacks/dist-zip          5.6.7
paketo-buildpacks/spring-boot       5.27.5

您可能会感到困惑的是,所有 Paketo 构建包本身都是用 Golang 编写的。因此,如果您要选择一个构建包映像,例如 gcr.io/paketo-buildpacks/bellsoft-liberica,您会看到 /cnb/buildpacks/paketo-buildpacks_bellsoft-liberica/10.4.2/bin 处有一个 Go 二进制文件/main.这是在检测和构建期间调用的内容,以及实际执行构建包的操作的内容。

立即学习go语言免费学习笔记(深入)”;

此外,构建包在应用程序运行时启动之前执行一些操作,例如配置 JVM 设置,这些操作由名为 helper 的单独二进制文件(构建包映像的同一目录)执行。与 main 不同,此二进制文件被复制到最终映像中,因此您的扫描仪正确地认为映像中存在 Go 二进制文件。它是 helper 二进制文件。如果您使用 dive 查看应用程序映像,您可以看到添加 helper 二进制文件的层并确认这一点。

您的扫描仪将看到此二进制文件并像其他任何东西一样扫描它。它能够从二进制文件中判断出哪个版本的 Golang 创建了该二进制文件,并从那里告诉您该二进制文件可能容易受到该版本 Go 或更高版本的任何已知 CVE 的攻击。

扫描程序对于二进制文件的用途或它是否实际上容易受到任何 CVE 的攻击的了解为零。我不知道您指的是什么 CVE,但我可以告诉您,鉴于 Paketo buildpack helper 二进制文件的上下文,大多数 CVE 将不适用。例如,与服务器、网络或 HTTP 相关的任何内容都是不相关的。 helper 二进制文件是一个 CLI,它运行并通常读取参数/环境变量,然后打印出一些结构化文本。就是这样,通常不需要服务器、网络或 HTTP。

笔启AI论文
笔启AI论文

专业高质量、低查重,免费论文大纲,在线AI生成原创论文,AI辅助生成论文的神器!

下载

如果您对 CVE 及其影响有具体疑问,您可以在 Paketo Slack 上提问,但不要只是将扫描仪中的 CVE 列表转储到那里并期望有人仔细检查所有内容为你。请注意,该项目是一个 OSS 项目,人们会出于善意做出回应,并且会在时间允许的情况下做出回应。如果您需要更多帮助或想要有保证的响应时间,那么您需要考虑与商业构建包供应商签订合同。

无法删除 Golang 文件,它们本质上是构建包。

你可以做什么:

  1. 保持您的构建器和构建包更新。 Paketo 项目每周都会削减新版本,我们会积极地保持 Go 的最新状态,以便新版本包含所有最新修复。

  2. 检查报告的 CVE,如果您及时更新,应该不会有很多。考虑到构建包二进制文件的上下文(见上文),它们很可能是无关紧要的,然后您可以告诉扫描仪忽略它们。他们应该很快就会离开,因为 1。)

  3. 由于您使用的是 Spring Boot 构建工具,因此请确保您已看到此公告并已应用所需的更改。如果您不这样做,您绝对会得到很多 CVE,因为您将拥有非常旧的构建包。

相关专题

更多
java
java

Java是一个通用术语,用于表示Java软件及其组件,包括“Java运行时环境 (JRE)”、“Java虚拟机 (JVM)”以及“插件”。php中文网还为大家带了Java相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

831

2023.06.15

java正则表达式语法
java正则表达式语法

java正则表达式语法是一种模式匹配工具,它非常有用,可以在处理文本和字符串时快速地查找、替换、验证和提取特定的模式和数据。本专题提供java正则表达式语法的相关文章、下载和专题,供大家免费下载体验。

737

2023.07.05

java自学难吗
java自学难吗

Java自学并不难。Java语言相对于其他一些编程语言而言,有着较为简洁和易读的语法,本专题为大家提供java自学难吗相关的文章,大家可以免费体验。

733

2023.07.31

java配置jdk环境变量
java配置jdk环境变量

Java是一种广泛使用的高级编程语言,用于开发各种类型的应用程序。为了能够在计算机上正确运行和编译Java代码,需要正确配置Java Development Kit(JDK)环境变量。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

397

2023.08.01

java保留两位小数
java保留两位小数

Java是一种广泛应用于编程领域的高级编程语言。在Java中,保留两位小数是指在进行数值计算或输出时,限制小数部分只有两位有效数字,并将多余的位数进行四舍五入或截取。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

398

2023.08.02

java基本数据类型
java基本数据类型

java基本数据类型有:1、byte;2、short;3、int;4、long;5、float;6、double;7、char;8、boolean。本专题为大家提供java基本数据类型的相关的文章、下载、课程内容,供大家免费下载体验。

446

2023.08.02

java有什么用
java有什么用

java可以开发应用程序、移动应用、Web应用、企业级应用、嵌入式系统等方面。本专题为大家提供java有什么用的相关的文章、下载、课程内容,供大家免费下载体验。

430

2023.08.02

java在线网站
java在线网站

Java在线网站是指提供Java编程学习、实践和交流平台的网络服务。近年来,随着Java语言在软件开发领域的广泛应用,越来越多的人对Java编程感兴趣,并希望能够通过在线网站来学习和提高自己的Java编程技能。php中文网给大家带来了相关的视频、教程以及文章,欢迎大家前来学习阅读和下载。

16925

2023.08.03

Java 项目构建与依赖管理(Maven / Gradle)
Java 项目构建与依赖管理(Maven / Gradle)

本专题系统讲解 Java 项目构建与依赖管理的完整体系,重点覆盖 Maven 与 Gradle 的核心概念、项目生命周期、依赖冲突解决、多模块项目管理、构建加速与版本发布规范。通过真实项目结构示例,帮助学习者掌握 从零搭建、维护到发布 Java 工程的标准化流程,提升在实际团队开发中的工程能力与协作效率。

10

2026.01.12

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号