ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

ffmpeg拉流长时间堵塞解决方式

2020-07-17 14:00:32  阅读:445  来源: 互联网

标签:堵塞 ffmpeg time ctx st av 拉流 超时


由于网络堵塞或者推流端错误导致拉流端没有流数据,ffmpeg主要会堵塞两个函数,直到下次流数据的到来

  1. avformat_open_input()
    该函数是在打开流数据时,如果没有这个流的ip,http有自己的timeout,当链接失败,ffmpeg会自动断开.但是如果有这个ip,但是无法链接,就会堵塞,解决方式是添加超时控制.
    函数在ffmpeg源码的ffmpeg_opt.c文件中,

    我设置了3秒超时时间,添加如下代码
    av_dict_set(&o->g->format_opts, "rw_timeout", "3000000", 0);

  2. av_read_frame()
    该函数是链接成功后,由于网络堵塞或者其它问题导致packet丢失,无法读取,导致堵塞,
    函数在ffmpeg.c文件中,解决方式也是添加超时
    `f->ctx->interrupt_callback.callback = CheckInterrupt;

    f->ctx->interrupt_callback.opaque = (void*)f->ctx;

    time_t start_time;

    start_time = time(NULL);

    int l = time(&start_time);

    f->ctx->st = l;

    return av_read_frame(f->ctx, pkt);

`

下面是回调函数:

static int CheckInterrupt(void *ctx) { AVFormatContext *p = (AVFormatContext*)ctx; time_t et; et = time(NULL); int l = time(&et); av_log(NULL, AV_LOG_WARNING,"start time%d\n",p->st); av_log(NULL, AV_LOG_WARNING,"end time%d\n",l); return l - p->st >= 10 ? 1 : 0;//3秒超时 }
需要注意的是,我在f->ctx结构体中添加了st变量,由时间戳作为评判超时的依据,需要把变量类型统一,所以需要添加变量如下:
在avformat.h文件的AVFormatContext结构体中添加:
int st;

标签:堵塞,ffmpeg,time,ctx,st,av,拉流,超时
来源: https://www.cnblogs.com/vinic-xxm/p/13329591.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有