ffmpeg转换使用process.waitFor()会卡死问题解决

本文介绍了在Java中使用FFmpeg进行视频格式转换时遇到的阻塞问题,通过设置日志级别为quiet和实时读取并处理FFmpeg输出流,解决了process.waitFor()卡顿的问题。
摘要由CSDN通过智能技术生成

代码描述

一下代码是部分代码,仅作展示。场景为将指定路径的视频文件转为统一格式,然后将转化后的文件覆盖掉原本的文件。

List<String> commandList = new ArrayList<>();
commandList.add("cmd");
commandList.add("/c");
commandList.add("ffmpeg -i "+ mp4FilePath +" -c:v h264 -c:a aac -strict -2 -y "+ tempFilePath +" && move /y "+ tempFilePath + " " + mp4FilePath);
ProcessBuilder pb = new ProcessBuilder(commandList);
pb.redirectErrorStream(true);
logger.info("视频编码格式化准备命令:"  + "ffmpeg -i "+ mp4FilePath +" -c:v h264 -c:a aac -strict -2 -y "+ tempFilePath +" && move /y "+ tempFilePath + " " + mp4FilePath);
logger.info("视频编码格式化开始执行");
try {
    process = pb.start();
    process.waitFor();
} catch (Exception e) {
    logger.info("视频编码格式化异常:FFmpeg命令报错" + JSON.toJSONString(e));
    try{
        if (process != null) {
            process.getErrorStream().close();
            process.getInputStream().close();
            process.getOutputStream().close();
        }
    }
    catch(Exception ee){}

    return false;
}
logger.info("视频编码格式化执行完成");

结果发现在process.waitFor();这里卡住不往下执行,通过查阅各位前辈的文章,总结出两种方法。

方法一:设置ffmpeg进程不向窗口写入数据,也就是不打印日志

将上面的ffmpeg命令

"ffmpeg -i "+ mp4FilePath +" -c:v h264 -c:a aac -strict -2 -y "+ tempFilePath +" && move /y "+ tempFilePath + " " + mp4FilePath);

改为,就是加了-loglevel quiet

"ffmpeg -loglevel quiet -i "+ mp4FilePath +" -c:v h264 -c:a aac -strict -2 -y "+ tempFilePath +" && move /y "+ tempFilePath + " " + mp4FilePath);

方法二:将ffmpeg的日志逐行打印出来,打印完了就结束了

增加了获取输出流以及读取输出信息的代码,结束后就完成了。

List<String> commandList = new ArrayList<>();
commandList.add("cmd");
commandList.add("/c");
commandList.add("ffmpeg -i "+ mp4FilePath +" -c:v h264 -c:a aac -strict -2 -y "+ tempFilePath +" && move /y "+ tempFilePath + " " + mp4FilePath);
ProcessBuilder pb = new ProcessBuilder(commandList);
pb.redirectErrorStream(true);
logger.info("视频编码格式化准备命令:"  + "ffmpeg -i "+ mp4FilePath +" -c:v h264 -c:a aac -strict -2 -y "+ tempFilePath +" && move /y "+ tempFilePath + " " + mp4FilePath);
try {
    process = pb.start();
} catch (Exception e) {
    logger.info("视频编码格式化异常:FFmpeg命令报错" + JSON.toJSONString(e));
    try{
        if (process != null) {
            process.getErrorStream().close();
            process.getInputStream().close();
            process.getOutputStream().close();
        }
    }
    catch(Exception ee){}

    return false;
}
logger.info("视频编码格式化开始执行");
// 获取输出流
InputStream is = process.getInputStream();
InputStreamReader isr = new InputStreamReader(is);
BufferedReader br = new BufferedReader(isr);

// 读取输出信息
String line;
while (true) {
    try {
        if ((line = br.readLine()) == null) break;
    } catch (IOException e) {
        logger.info("视频编码格式化异常:FFmpeg读取输出信息报错" + JSON.toJSONString(e));
        return false;
    }
//  System.out.println(line);
}
try {
    is.close();
    isr.close();
    br.close();
} catch (IOException e) {
    logger.info("视频编码格式化异常:关闭流报错" + JSON.toJSONString(e));
    return false;
}
logger.info("视频编码格式化执行完成");
  • 11
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

叶落_无秋

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值