【java-ffmpeg】java 内存测试和集成

内存监控

最近在用javacpp 挂ffmpeg来用,写完代码想监控一下内存,发现jprofile的内存监控不到jni的内存。在linux上想了一个土方法,监控进程的内存。用脚本循环读取。这里不像C++进程只读取VmRSS,即驻留内存。在JNI里VmRSS应该是指JVM的内存,JNI的内存属于动态库的内存,算在了虚拟内存VmSize里,具体原因没有去探究。

脚本如下

shell 复制代码
#!/bin/bash

nohup java -jar xxx.jar > nohup.log 2>&1 &

pid=$!

# 检查进程是否存在
if ! ps -p $pid > /dev/null; then
    echo "进程ID $pid 不存在"
    exit 1
fi

# 循环读取并打印内存信息,直到进程结束
while true; do
    # 读取/proc/pid/status中的VmSize和VmRSS字段
    vm_size=$(cat "/proc/$pid/status" | grep VmSize | awk '{print $2}')
    vm_rss=$(cat "/proc/$pid/status" | grep VmRSS | awk '{print $2}')

    # 打印内存信息
    echo "进程ID: $pid"
    echo "虚拟内存大小 (VmSize): $vm_size kB"
    echo "实际使用的物理内存 (VmRSS): $vm_rss kB"

    # 检查进程是否还在运行
    if ! ps -p $pid > /dev/null; then
        echo "进程ID $pid 已经结束"
        break
    fi

    # 等待一秒
    sleep 1
done

这样编译一个循环执行任务的测试程序,长期执行看内存有没有增长。

编译目标

maven 里引入ffmpeg-platform会把所有平台的包都拖下来,打包出来260M+,

参照 https://github.com/bytedeco/javacpp-presets 的readme,里面有一个链接指向了 https://github.com/bytedeco/javacpp-presets/wiki/Reducing-the-Number-of-Dependencies

执行

mvn -Djavacpp.platform.custom -Djavacpp.platform.host -Djavacpp.platform.macosx-x86_64 -Djavacpp.platform.windows-x86_64 package

在idea里使用 Execute Maven Goal 热编译![在这里插入图片描述](https://i-blog.csdnimg.cn/direct/94f933d94889456c840d090e03789a81.png

选择了三个平台,打包出来减小到69M

相关推荐
彭于晏Yan9 小时前
OkHttp 与 RestTemplate 技术选型对比
java·spring boot·后端·okhttp
金銀銅鐵9 小时前
[Java] 如何理解 class 文件中字段的 descriptor?
java·后端
500849 小时前
Graph Engine 是什么,为什么需要它
java·人工智能·性能优化·ocr·wpf
未若君雅裁9 小时前
服务雪崩、降级、熔断与服务保护
java·微服务
就叫_这个吧9 小时前
Java实现线程间的通讯--使用synchronized关键字和JUC方式实现
java·开发语言
Database_Cool_9 小时前
alibabacloud-polardb-ai-assistant:让大模型成为你的数据库运维搭档
ffmpeg
学习中.........9 小时前
JVM 垃圾回收核心技术、演进全景与生产调优规范
java·jvm·测试工具
小小编程路9 小时前
C++类作用域
java·jvm·c++
小江的记录本9 小时前
【Java并发编程】锁机制:volatile:JMM内存模型、可见性/禁止指令重排、内存屏障、单例模式中的应用(附《思维导图》+《面试高频考点清单》)
java·后端·python·mysql·单例模式·面试·职场和发展
zandy101110 小时前
2026嵌入式BI PaaS平台技术剖析与实现指南
java·运维·paas