Springboot3.5.x版本引入javaCv相关库版本问题以及精简引入包

背景

最近公司有个项目需要用到ffempeg,公司项目比较新,用的是最新的Springboot3.5.x版本,一开始在网上找了篇教程,引入了javacv-platform依赖,顺利完成了工作。但是后来打包之后发现jar包的内存从原本的100M变成了900多M,所以就在网上找了很多精简引入的教程,可按照他们的做法,很多都无法正常使用,就算可以使用,也都是针对Springboot2.x版本的,很容易出现版本冲突的情况,导致项目其它很多包直接爆红,很少见到有SpringBoot3.x版本的教程,特此写了这篇文章。

⚠️ 问题根源:为什么 javacv-platform 如此"臃肿"?

要解决问题,必先究其根源。javacv-platform 的设计初衷是为了方便开发者,它是一个"聚合包",通过 Maven 的 <dependencyManagement> 帮你一次性引入所有可能用到的组件和平台。

它默认包含了:

  • 所有平台:Windows (x86, x86_64), macOS (x86_64, arm64), Linux (x86, x86_64, arm64, etc.)...
  • 所有预编译库:FFmpeg, OpenCV, FlyCapture, etc...

这就好比你只想做一道番茄炒蛋,却直接买下了整个超市。打包时,Maven 会把这些所有平台的本地库文件(如 .dll, .so, .dylib)全部塞进你的 JAR 包里。你的应用明明只需要在 Linux 服务器上运行,却带着 Windows 和 macOS 的"行李",体积能不大吗?

依赖

基础依赖: Springboot3.5.5、jdk17

我们希望:开发时只加载 Windows 依赖,打包部署到 Linux 服务器时只加载 Linux 依赖。

Maven 的 Profile 功能就是为此而生!

我们可以将平台依赖分别放到不同的 Profile 中,通过激活不同的 Profile 来动态加载依赖。

xml 复制代码
<properties>
    <javacv.version>1.5.8</javacv.version>
    <javacv.ffmpeg.version>5.1.2-1.5.8</javacv.version>
</properties>

<dependencies>
    <!-- 核心JavaCV API,所有环境都需要 -->
    <dependency>
        <groupId>org.bytedeco</groupId>
        <artifactId>javacv</artifactId>
        <version>${javacv.version}</version>
    </dependency>
</dependencies>

<profiles>
    <!-- 开发环境 (Windows) -->
    <profile>
        <id>dev</id>
        <activation>
            <activeByDefault>true</activeByDefault> <!-- 默认激活dev环境 -->
        </activation>
        <dependencies>
            <dependency>
                <groupId>org.bytedeco</groupId>
                <artifactId>javacpp</artifactId>
                <version>${javacv.version}</version>
                <classifier>windows-x86_64</classifier>
            </dependency>
            <dependency>
                <groupId>org.bytedeco</groupId>
                <artifactId>ffmpeg</artifactId>
                <version>${javacv.ffmpeg.version}</version>
                <classifier>windows-x86_64</classifier>
            </dependency>
        </dependencies>
    </profile>

    <!-- 生产环境 (Linux) -->
    <profile>
        <id>prod</id>
        <dependencies>
            <dependency>
                <groupId>org.bytedeco</groupId>
                <artifactId>javacpp</artifactId>
                <version>${javacv.version}</version>
                <classifier>linux-x86_64</classifier>
            </dependency>
            <dependency>
                <groupId>org.bytedeco</groupId>
                <artifactId>ffmpeg</artifactId>
                <version>${javacv.ffmpeg.version}</version>
                <classifier>linux-x86_64</classifier>
            </dependency>
        </dependencies>
    </profile>

    <!-- macOS 环境 (可选) -->
    <profile>
        <id>mac</id>
        <dependencies>
            <dependency>
                <groupId>org.bytedeco</groupId>
                <artifactId>javacpp</artifactId>
                <version>${javacv.version}</version>
                <classifier>macosx-x86_64</classifier>
            </dependency>
            <dependency>
                <groupId>org.bytedeco</groupId>
                <artifactId>ffmpeg</artifactId>
                <version>${javacv.ffmpeg.version}</version>
                <classifier>macosx-x86_64</classifier>
            </dependency>
        </dependencies>
    </profile>
</profiles>
  • 本地开发 :默认激活 dev profile,直接运行或打包即可,只会包含 Windows 依赖。
  • Linux 服务器打包 :在打包命令中指定 prod profile。
go 复制代码
    mvn clean package -Pprod
  • macOS 用户打包
go 复制代码
    mvn clean package -Pmac

这样,最终产出的 JAR 包就只包含了对应环境的本地库,体积大幅缩减,完美解决问题!

🤔 关于版本选择的说明

你可能会问,为什么不用最新的 JavaCV 版本?

在我的实践中,JavaCV 1.5.8 和 FFmpeg 5.1.2-1.5.8 这个组合在 Spring Boot 3.x + JDK 17 环境下表现得非常稳定。尝试升级到 JavaCV 1.5.9 或更高版本时,曾遇到过其传递依赖与 Spring Boot 自带的某些库(如 jakarta.servlet-api 等)产生细微冲突的情况。

相关推荐
独自破碎E11 小时前
【双指针+字符串】字符串变形
android·java
weixin_4624462312 小时前
一键安装 Hadoop 3.3.6 自动化脚本详解 |(含 JAVA_HOME 自动配置)
java·hadoop·自动化
张柏慈19 小时前
Java性能优化:实战技巧与案例解析
java
天“码”行空19 小时前
简化Lambda——方法引用
java·开发语言
带刺的坐椅19 小时前
MCP 进化:让静态 Tool 进化为具备“上下文感知”的远程 Skills
java·ai·llm·agent·solon·mcp·tool-call·skills
java1234_小锋20 小时前
Java线程之间是如何通信的?
java·开发语言
张张努力变强20 小时前
C++ Date日期类的设计与实现全解析
java·开发语言·c++·算法
while(1){yan}20 小时前
Spring事务
java·数据库·spring boot·后端·java-ee·mybatis
毕设源码-赖学姐21 小时前
【开题答辩全过程】以 高校社团管理平台为例,包含答辩的问题和答案
java
余瑜鱼鱼鱼21 小时前
线程和进程的区别和联系
java·开发语言·jvm