av_interleaved_write_frame -32 broken pipe

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介: av_interleaved_write_frame -32 broken pipe

这个错误是底层socket传递给ffmpeg的,它是一个管道错误,意思是在管道两端,当一端不停的写,另一边却断开接收。那么就会出现:

broken pipe


这个时候有几个可排查的选项:

1.发送的码流是多少,网络带宽是否足够。

2.查看服务器的日志,比如srs流媒体,与推流端连接和断开时都会有日志,记录,看是否连接后,推流时又断开连接了。


解释一下两个函数:

avio_open(&octx->pb, URL, AVIO_FLAG_READ_WRITE)


如果URL是文件,这里就完成打开文件的操作,如果是URL,那么就完成了网络连接操作,比如URL是rtmp://192.168.100.109/live/yqw,rtmp底层是tcp协议,那么此时这个函数就是帮助建立好tcp连接,等待后面av_interleaved_write_frame发送数据。可以在srs日志中看到,当执行这个函数时,日志显示完成连接。

avformat_write_header(octx, NULL)
av_interleaved_write_frame(octx, &enc_pkt)


这两个函数是在avio_open建立好连接后,发送数据。


如果与服务器建立连接后,服务器主动断开连接,那么就要考虑是不是一些参数设置问题了,比如编码器的参数。

设置编码器参数可参考:

https://blog.csdn.net/weixin_43466192/article/details/121036001



相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
相关文章
已解决 BrokenPipeError: [Errno 32] Broken pipe
已解决 BrokenPipeError: [Errno 32] Broken pipe
6254 0
已解决 BrokenPipeError: [Errno 32] Broken pipe
nobuffer与av_read_frame的关系
nobuffer与av_read_frame的关系
92 0
|
索引
av_find_best_stream
av_find_best_stream
151 0
av_find_best_stream
|
缓存 编解码 Ubuntu
avcodec_send_frame和avcodec_receive_packet
avcodec_send_frame和avcodec_receive_packet
379 0
avcodec_send_frame和avcodec_receive_packet
|
编解码
av_read_frame返回值为-5 Input/output error
av_read_frame返回值为-5 Input/output error
170 0
解决办法:av_interleaved_write_frame()返回-22 错误
解决办法:av_interleaved_write_frame()返回-22 错误
136 0
error: ‘avcodec_alloc_frame’ was not declared in this scope
error: ‘avcodec_alloc_frame’ was not declared in this scope
383 0
OSError: cannot write mode P as JPEG
OSError: cannot write mode P as JPEG
585 0
OSError: image file is truncated (12 bytes not processed) Premature end of JPEG file
OSError: image file is truncated (12 bytes not processed) Premature end of JPEG file
526 0