WriteN, RTMP send error 32 (133 bytes)
WriteN, RTMP send error 32 (49 bytes)
WriteN, RTMP send error 9 (42 bytes)
現象:
推流失敗,srs服務出錯。
原因
視頻流較慢,音頻流較快。
復現
視頻解碼得到幀數據,用異步接口處理幀數據,在回調函數中取回處理完的幀數據再編碼推流,此時因為處理幀數據有一定的延時,10ms左右,所以在 write_frame 時,寫入了較多的音頻數據和少量的視頻數據,推流時報錯。
處理
將音頻幀數據存到一個隊列中,每一次異步接口返回時,從隊列中彈出適當的音頻幀數據。
ret = av_interleaved_write_frame(fmt_rtmp_ctx_, pkt);AVPacket* audio_packet = NULL;if (!audio_packets_queue_.empty()) {audio_packet = audio_packets_queue_.front();} else {return ret;}while(audio_packet->pts < video_pts_ + 200) {printf("audio pts: %ld dts: %ld duration: %ld\n", audio_packet->pts, audio_packet->dts, audio_packet->duration);av_interleaved_write_frame(fmt_rtmp_ctx_, audio_packet);mutex_.lock();audio_packets_queue_.pop();av_packet_free(&audio_packet);if (audio_packets_queue_.empty()) {mutex_.unlock();break;}audio_packet = audio_packets_queue_.front();mutex_.unlock();}av_packet_unref(pkt);