Compare commits

...

4 Commits

Author SHA1 Message Date
xia-chu
57b5c82495 新增帧合并开关,优化国标流秒开速度
Some checks failed
Android / build (push) Has been cancelled
CodeQL / Analyze (cpp) (push) Has been cancelled
CodeQL / Analyze (javascript) (push) Has been cancelled
Docker / build (push) Has been cancelled
Linux / build (push) Has been cancelled
macOS / build (push) Has been cancelled
Windows / build (push) Has been cancelled
2025-04-21 12:38:26 +08:00
xia-chu
897d127099 提高某些国标流注册速度 2 2025-04-21 11:57:21 +08:00
xia-chu
f11467c2a8 提高某些国标流注册速度 2025-04-21 11:07:38 +08:00
xia-chu
1e14d296f5 rtp级联速度太慢时主动限制上游接收速度 3 2025-04-21 09:39:16 +08:00
6 changed files with 25 additions and 14 deletions

View File

@ -342,6 +342,8 @@ rtp_g711_dur_ms = 100
#udp接收数据socket buffer大小配置
#4*1024*1024=4196304
udp_recv_socket_buffer=4194304
#ps/ts解析后是否等待下一帧以判断本帧是否完整开启后提高兼容性但是可能增加延时
merge_frame=1
[rtc]
#rtc播放推流、播放超时时间

View File

@ -366,6 +366,7 @@ const string kOpusPT = RTP_PROXY_FIELD "opus_pt";
const string kGopCache = RTP_PROXY_FIELD "gop_cache";
const string kRtpG711DurMs = RTP_PROXY_FIELD "rtp_g711_dur_ms";
const string kUdpRecvSocketBuffer = RTP_PROXY_FIELD "udp_recv_socket_buffer";
const std::string kMergeFrame = RTP_PROXY_FIELD "merge_frame";
static onceToken token([]() {
mINI::Instance()[kDumpDir] = "";
@ -378,6 +379,7 @@ static onceToken token([]() {
mINI::Instance()[kGopCache] = 1;
mINI::Instance()[kRtpG711DurMs] = 100;
mINI::Instance()[kUdpRecvSocketBuffer] = 4 * 1024 * 1024;
mINI::Instance()[kMergeFrame] = 1;
});
} // namespace RtpProxy

View File

@ -563,6 +563,8 @@ extern const std::string kGopCache;
extern const std::string kRtpG711DurMs;
// udp recv socket buffer size
extern const std::string kUdpRecvSocketBuffer;
// ps/ts解析后是否等待下一帧以判断本帧是否完整开启后提高兼容性但是可能增加延时
extern const std::string kMergeFrame;
} // namespace RtpProxy
/**

View File

@ -11,6 +11,7 @@
#include "Decoder.h"
#include "PSDecoder.h"
#include "TSDecoder.h"
#include "Common/config.h"
#include "Extension/Factory.h"
#if defined(ENABLE_RTPPROXY) || defined(ENABLE_HLS)
@ -122,11 +123,18 @@ void DecoderImp::onDecode(int stream, int codecid, int flags, int64_t pts, int64
WarnL << "Unsupported codec :" << getCodecName(codec);
return;
}
GET_CONFIG(bool, merge_frame, RtpProxy::kMergeFrame)
auto frame = Factory::getFrameFromPtr(codec, (char *)data, bytes, dts, pts);
if (getTrackType(codec) != TrackVideo) {
if (getTrackType(codec) != TrackVideo || !merge_frame) {
onFrame(stream, frame);
if (_last_is_keyframe && _video_merge) {
// 上次是关键帧,收到音频后,说明帧收齐了
_video_merge->flush();
}
return;
}
_last_is_keyframe = frame->keyFrame() || frame->configFrame();
_video_merge = &ref.second;
ref.second.inputFrame(frame, [this, stream, codec](uint64_t dts, uint64_t pts, const Buffer::Ptr &buffer, bool) {
onFrame(stream, Factory::getFrameFromBuffer(codec, buffer, dts, pts));
});

View File

@ -59,13 +59,14 @@ private:
private:
bool _finished = false;
bool _have_video = false;
bool _last_is_keyframe = false;
Decoder::Ptr _decoder;
MediaSinkInterface *_sink;
class FrameMergerImp : public FrameMerger {
public:
FrameMergerImp() : FrameMerger(FrameMerger::none) {}
};
FrameMergerImp *_video_merge = nullptr;
std::unordered_map<int, std::pair<Track::Ptr, FrameMergerImp> > _tracks;
};

View File

@ -36,19 +36,15 @@ RtpSender::~RtpSender() {
}
void RtpSender::startSend(const MediaSource &sender, const MediaSourceEvent::SendRtpArgs &args, const function<void(uint16_t local_port, const SockException &ex)> &cb){
try {
_origin_socket = dynamic_pointer_cast<Socket>(sender.getOriginSock());
} catch (...) {
}
auto origin_socket = sender.getOriginSock();
_origin_socket = dynamic_pointer_cast<Socket>(origin_socket);
if (!_origin_socket) {
try {
auto process = dynamic_pointer_cast<RtpProcess>(sender.getOriginSock());
if (process) {
_origin_socket = process->getSock();
}
} catch (...) {
auto process = dynamic_pointer_cast<RtpProcess>(origin_socket);
if (process) {
_origin_socket = process->getSock();
}
}
_args = args;
if (!_interface) {
// 重连时不重新创建对象 [AUTO-TRANSLATED:b788cd5d]
@ -455,8 +451,8 @@ void RtpSender::onFlushRtpList(shared_ptr<List<Buffer::Ptr>> rtp_list) {
}
default: CHECK(0);
}
if (_socket_rtp->sockType() == toolkit::SockNum::Sock_TCP && _socket_rtp->isSocketBusy()) {
_socket_rtp->enableRecv(false);
if (_socket_rtp->sockType() == toolkit::SockNum::Sock_TCP && _socket_rtp->isSocketBusy() && _origin_socket) {
_origin_socket->enableRecv(false);
}
});
};