ffmpeg取rtsp流时av_read_frame阻塞的解决办法

来源:互联网 发布:appserv是什么软件 编辑:程序博客网 时间:2024/05/21 04:21

搜索关键词:ffmpeg 超时/timeout

方法一

方法是设置超时参数

AVFormatContext *pAVFormatContext = avformat_alloc_context();//申请一个AVFormatContext结构的内存,并进行简单初始化    AVDictionary* options = NULL;    av_dict_set(&options, "buffer_size", "102400", 0); //设置缓存大小,1080p可将值调大    av_dict_set(&options, "rtsp_transport", "tcp", 0); //以udp方式打开,如果以tcp方式打开将udp替换为tcp    av_dict_set(&options, "stimeout", "2000000", 0); //设置超时断开连接时间,单位微秒    av_dict_set(&options, "max_delay", "500000", 0); //设置最大时延

参考:ffmpeg播放RTSP的一点优化

方法二

注册回调函数,在回调函数中设置超时判断(这种方法我未成功)

pFormatCtx = avformat_alloc_context();    pFormatCtx->interrupt_callback.callback = interrupt_cb;--------注册回调函数    pFormatCtx->interrupt_callback.opaque = pFormatCtx;    AVDictionary* options = NULL;    av_dict_set(&options, "rtsp_transport", "tcp", 0);        //核心是超时返回1,正常等待返回0    static int interrupt_cb(void *ctx)//这个回调函数应该是用了博主内部的一些函数和变量    {        // do something        NSLog(@"%d",time_out);        time_out++;        if (time_out > 40) {            NSLog(@"------%d", firsttimeplay);            time_out=0;            if (firsttimeplay) {                firsttimeplay=0;                NSLog(@"++++++++");                return 1;//这个就是超时的返回            }        }        return 0;    }    //回调函数伪代码如下    int interruptCallBack(void *ctx){       //once your preferred time is out you can return 1 and exit from the loop       if(timeout){          //exit          return 1;        }           //continue        return 0;    }

麻烦点的实现,另建立了一个监视线程,参考文献3

参考:

  1. 使用ffmpeg的av_read_frame,如何控制连接超时
  2. timeout on av_read_frame()
  3. FFmpeg长时间无响应的解决方法