【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

相关推荐
皮皮林5513 小时前
Java性能调优黑科技!1行代码实现毫秒级耗时追踪,效率飙升300%!
java
冰_河4 小时前
QPS从300到3100:我靠一行代码让接口性能暴涨10倍,系统性能原地起飞!!
java·后端·性能优化
桦说编程6 小时前
从 ForkJoinPool 的 Compensate 看并发框架的线程补偿思想
java·后端·源码阅读
躺平大鹅8 小时前
Java面向对象入门(类与对象,新手秒懂)
java
初次攀爬者9 小时前
RocketMQ在Spring Boot上的基础使用
java·spring boot·rocketmq
花花无缺9 小时前
搞懂@Autowired 与@Resuorce
java·spring boot·后端
Derek_Smart10 小时前
从一次 OOM 事故说起:打造生产级的 JVM 健康检查组件
java·jvm·spring boot
NE_STOP11 小时前
MyBatis-mybatis入门与增删改查
java
孟陬15 小时前
国外技术周刊 #1:Paul Graham 重新分享最受欢迎的文章《创作者的品味》、本周被划线最多 YouTube《如何在 19 分钟内学会 AI》、为何我不
java·前端·后端