ffmpeg udp推流bind failed: Address already in use
Failed in FFMPEG use UDP already bind address
2023-09-14 09:12:46 时间
报错:
[udp @ 0x7f63780079c0] bind failed: Address already in useB f=0/0
udp://127.0.0.1:6016: Input/output error
用ffmpeg -re -i test_video.mp4 -f mpegts udp:127.0.0.1:6016推流
ffplay udp://127.0.0.1:6016拉流,没问题,能推能拉。
用自己写的代码程序推流,然后用ffplay拉流,报上面错误。
用ffmpeg命令推流时,用命令查看端口
lsof -i udp:6016
检索不到程序占用这个端口。
用自己的代码拉流时,再次查看端口,发现程序占用了6016端口。
用ffplay拉流时,查看端口,发现ffplay占用6016端口。
因此自己写的代码和ffplay都同时占领了这个端口,导致错误。
查看代码:
//打开输出文件
if (avio_open(&octx->pb, URL, AVIO_FLAG_READ_WRITE) < 0)//
{
cout << "Open output file failed!" << endl;
return 0;
}
发现在打开网口IO时,既占用了读又占用了写,因此AVIO_FLAG_READ_WRITE改为AVIO_FLAG_WRITE就好了。
用udp推流延时测试,见:rtmp改udp推流,并测试延时性能
![](https://img-blog.csdnimg.cn/32ebb60e13f9449496052c247d2ccf65.png)
![](https://img-blog.csdnimg.cn/1b3e3fc19f5f4837a6514769eabf4e10.png)
![](https://img-blog.csdnimg.cn/32ebb60e13f9449496052c247d2ccf65.png)
相关文章
- websocket 服务器上连接404 ,failed: Error during WebSocket handshake: Unexpected response code: 404
- Ubuntu 18.04 清华更新源 Certificate verification failed
- 【错误记录】Android Studio 向 GitHub 提交代码报错 ( Push failed: Failed with error: Could not read from remote )
- ORA-27083: waiting for async I/Os failed ORACLE 报错 故障修复 远程处理
- ORA-29919: failed in the execution of the ODCIINDEXUPDPARTMETADATA routine ORACLE 报错 故障修复 远程处理
- ORA-41252: Failed to switch to new session in SSCR ORACLE 报错 故障修复 远程处理
- ORA-56507: DRCP: Pool alter configuration failed ORACLE 报错 故障修复 远程处理
- ORA-56510: DRCP: Pool alter configuration failed ORACLE 报错 故障修复 远程处理
- MySQL Error number: MY-010401; Symbol: ER_NDB_INFO_FAILED_TO_INIT_NDBINFO; SQLSTATE: HY000 报错 故障修复 远程处理
- MySQL Error number: MY-010825; Symbol: ER_BINLOG_FAILED_TO_CLOSE_INDEX_FILE_WHILE_REBUILDING; SQLSTATE: HY000 报错 故障修复 远程处理
- MySQL Error number: MY-011009; Symbol: ER_DD_UPGRADE_FAILED_TO_CREATE_INDEX_STATS; SQLSTATE: HY000 报错 故障修复 远程处理
- MySQL Error number: MY-011388; Symbol: ER_KEYRING_OKV_CONNECTION_TO_SERVER_FAILED; SQLSTATE: HY000 报错 故障修复 远程处理
- ORA-06737: TLI Driver: connection failed ORACLE 报错 故障修复 远程处理
- ORA-06767: TLI Driver: alloc failed during release ORACLE 报错 故障修复 远程处理
- ORA-16754: failed to activate physical standby database ORACLE 报错 故障修复 远程处理
- MySQL Error number: MY-013266; Symbol: ER_IB_MSG_FAILED_TO_FINISH_TRUNCATE; SQLSTATE: HY000 报错 故障修复 远程处理
- MySQL删除IN操作: 简易指南(mysql删除in)
- MySQL OR和IN:比较和选择(mysqlor和in)
- 关键字使用Oracle中的Replace函数替代IN关键字(oracle替代in)
- 运算MySQL无法使用IN操作(mysql不能用in)
- MySQL使用IN运算符的查询实践(mysql使用in查询)
- 子查询MySQL联表IN子查询:实现跨表快速查询(mysql联表in)
- MySQL中IN操作符的用法与注意事项(mysql中in的写法)
- MySQL中使用IN操作符查询字符串(mysql中in字符串)
- MySQL中IN函数的使用及作用解析(mysql中in作用)
- MySQL查询语句中的不存在关键字NOT IN(mysql 不存在 in)
- 查询Oracle IN查询两个字段的精彩之处(oracle两个字段in)
- 使用Oracle IN多表进行联接查询(oracle in多表)