java关于ffmpeg推流停止的问题

问题描述

Java程序中使用Runtime.getRuntime().exec()执行ffmpeg推流命令,大约五分钟后,推流停止,ffplay无法接收到流,但推流进程仍存在。

解决方法

process的阻塞:
在runtime执行大点的命令中,输入流和错误流会不断有流进入存储在JVM的缓冲区中,如果缓冲区的流不被读取被填满时,就会造成runtime的阻塞。所以在进行比如:大文件复制等的操作时,我们还需要不断的去读取JVM中的缓冲区的流,来防止Runtime的死锁阻塞。
利用单独两个线程,分别处理process的getInputStream()和getErrorSteam(),防止缓冲区被撑满,导致阻塞;

public class DealProcessStream extends Thread {
    private InputStream inputStream;

    public DealProcessStream(InputStream inputStream) {
        this.inputStream = inputStream;
    }

    public void run() {
        InputStreamReader inputStreamReader = null;
        BufferedReader br = null;
        try {
            inputStreamReader = new InputStreamReader(
                    inputStream);
            br = new BufferedReader(inputStreamReader);
            // 打印信息
//            String line = null;
//            while ((line = br.readLine()) != null) {
//                System.out.println(line);
//            }
            // 不打印信息
           while (br.readLine() != null);
        } catch (IOException ioe) {
            ioe.printStackTrace();
        }finally {
            try {
                br.close();
                inputStreamReader.close();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }

    }
}

参考文章

https://www.cnblogs.com/tohxyblog/p/6501396.html
https://www.cnblogs.com/MacrossFT/p/12038479.html

  • 2
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
<h1>Video_Live_Stream</h1> 一个视频推流小工具 ---------- <h1>简介</h1> Video_Live_Stream是在Linux系统下基于python调用ffmpeg实现的简易推流工具,基本功能如下: * 读取播放列表,按列表顺序循环推流视频至rtmp服务器。 * 添加了`bilibili直播间弹幕模块`,可接收及发送弹幕。 * 可通过指令修改`视频播放模式`,结合弹幕模块可以直播间操作播放模式。 <h1>文件结构</h1> Video_Live_Stream * data * configure.json * <u>配置文件,存放推流参数</u> * filter_complex.txt * <u>存放滤镜参数</u> * loop_tag * <u>存放循环标识</u> * PID_keep_pipe * <u>存放keep_pipe的pid</u> * PID_push * <u>存放push进程ffmpeg进程的pid</u> * PID_send * <u>存放send进程ffmpeg进程的pid</u> * play_method * <u>存放播放模式</u> * play_skip * <u>存放指令</u> * font * msyh.ttc * <u>字体文件(修改后需要在data/filter_complex.txt中同步修改)</u> * log * log.log * <u>send进程输出日志,结合py/send_check.py使用</u> * pipe * keep1 * <u>管道文件,用于维持pipe/pipe_push开启</u> * keep2 * <u>管道文件,用于维持pipe/pipe_push开启</u> * pipe_push * <u>管道文件,用于推流</u> * playlist * playlist.txt * <u>当前播放列表</u> * playlist_memory.txt * <u>用于保存播放进度</u> * ... * <u>需自行创建的播放列表</u> * ... * py * bilibili_live * aiorequest.py * <u>网络请求模块</u> * live.py * <u>直播间连接模块</u> * utils * cmd_execute.py * <u>命令执行模块</u> * file_io.py * <u>文件读写模块</u> * LinkList.py * <u>链表模块</u> * play_enum.py * <u>自定义枚举模块</u> * change.py * <u>发送指令</u> * chat.py * <u>直播间连接,弹幕接收与发送</u> * keep_pipe.py * <u>维持管道</u> * stop_pipe.py * <u>取消维持管道</u> * push.py * <u>视频推流至管道</u> * send.py * <u>管道数据推流至rtmp服务器</u> * send_check.py * <u>检查send进程运作</u> * video * xxx文件夹 * 01.mp4 * <u>视频名称</u> * 02.mp4 * ... * ... * ... * ... ---------- <h1>准备工作</h1> 首先把压缩包下载到本地然后解压,做好以下准备。 -------- 该资源内项目源码是个人的毕设,代码都测试ok,都是运行成功后才上传资源,答辩评审平均分达到96分,放心下载使用! <项目介绍> 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。 下载后请首先打开README.md文件(如有),仅供学习参考, 切勿用于商业用途。 --------
Java结合FFmpeg推流,可以使用JavaCV库来实现。JavaCV是一个基于FFmpeg和OpenCV的Java接口,提供了访问视频、音频和图像处理的功能。下面是基于JavaCV实现的推流步骤: 1. 安装JavaCV库,并在代码中导入相关包。 2. 使用FFmpegFrameRecorder类创建一个推流器对象。 3. 设置推流器的参数,如推流地址、视频宽高、视频码率等。 4. 调用start()方法开始推流。 5. 使用Frame类读取视频数据,并将其通过推流器对象写入网络流中。 6. 调用stop()方法结束推流。 下面是Java结合FFmpeg推流的示例代码: ``` import org.bytedeco.javacv.FFmpegFrameRecorder; import org.bytedeco.javacv.Frame; import org.bytedeco.javacv.Java2DFrameConverter; import org.bytedeco.opencv.opencv_core.IplImage; import javax.imageio.ImageIO; import java.awt.image.BufferedImage; import java.io.File; public class PushStreamDemo { public static void main(String[] args) throws Exception { //创建推流器对象 FFmpegFrameRecorder recorder = new FFmpegFrameRecorder("rtmp://localhost:1935/live/test", 640, 480); //设置推流参数 recorder.setVideoCodec(avcodec.AV_CODEC_ID_H264); recorder.setFormat("flv"); recorder.setFrameRate(25); recorder.setVideoBitrate(2000000); recorder.setVideoQuality(0); //开始推流 recorder.start(); //读取视频数据并写入网络流中 for (int i = 0; i < 100; i++) { BufferedImage image = ImageIO.read(new File("test.jpg")); Java2DFrameConverter converter = new Java2DFrameConverter(); Frame frame = converter.convert(image); recorder.record(frame); Thread.sleep(40); } //停止推流 recorder.stop(); } } ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值