Commit a0b46495 by xiongziliang

优化rtp重发列队性能

parent 6707b134
...@@ -15,12 +15,17 @@ using namespace toolkit; ...@@ -15,12 +15,17 @@ using namespace toolkit;
using namespace mediakit; using namespace mediakit;
static constexpr uint32_t kMaxNackMS = 5 * 1000; static constexpr uint32_t kMaxNackMS = 5 * 1000;
static constexpr uint32_t kRtpCacheCheckInterval = 100;
void NackList::pushBack(RtpPacket::Ptr rtp) { void NackList::pushBack(RtpPacket::Ptr rtp) {
auto seq = rtp->getSeq(); auto seq = rtp->getSeq();
_nack_cache_seq.emplace_back(seq); _nack_cache_seq.emplace_back(seq);
_nack_cache_pkt.emplace(seq, std::move(rtp)); _nack_cache_pkt.emplace(seq, std::move(rtp));
while (getCacheMS() > kMaxNackMS) { if (++_cache_ms_check < kRtpCacheCheckInterval) {
return;
}
_cache_ms_check = 0;
while (getCacheMS() >= kMaxNackMS) {
//需要清除部分nack缓存 //需要清除部分nack缓存
popFront(); popFront();
} }
...@@ -57,23 +62,26 @@ RtpPacket::Ptr *NackList::getRtp(uint16_t seq) { ...@@ -57,23 +62,26 @@ RtpPacket::Ptr *NackList::getRtp(uint16_t seq) {
} }
uint32_t NackList::getCacheMS() { uint32_t NackList::getCacheMS() {
auto back_stamp = getRtpStamp(_nack_cache_seq.back()); while (_nack_cache_seq.size() > 2) {
if (back_stamp == -1) { auto back_stamp = getRtpStamp(_nack_cache_seq.back());
_nack_cache_seq.pop_back(); if (back_stamp == -1) {
return 0; _nack_cache_seq.pop_back();
} continue;
}
auto front_stamp = getRtpStamp(_nack_cache_seq.front()); auto front_stamp = getRtpStamp(_nack_cache_seq.front());
if (front_stamp == -1) { if (front_stamp == -1) {
_nack_cache_seq.pop_front(); _nack_cache_seq.pop_front();
return 0; continue;
} }
if (back_stamp >= front_stamp) { if (back_stamp >= front_stamp) {
return back_stamp - front_stamp; return back_stamp - front_stamp;
}
//很有可能回环了
return back_stamp + (UINT32_MAX - front_stamp);
} }
//很有可能回环了 return 0;
return back_stamp + (UINT32_MAX - front_stamp);
} }
int64_t NackList::getRtpStamp(uint16_t seq) { int64_t NackList::getRtpStamp(uint16_t seq) {
......
...@@ -30,6 +30,7 @@ private: ...@@ -30,6 +30,7 @@ private:
mediakit::RtpPacket::Ptr *getRtp(uint16_t seq); mediakit::RtpPacket::Ptr *getRtp(uint16_t seq);
private: private:
int _cache_ms_check = 0;
std::deque<uint16_t> _nack_cache_seq; std::deque<uint16_t> _nack_cache_seq;
std::unordered_map<uint16_t, mediakit::RtpPacket::Ptr> _nack_cache_pkt; std::unordered_map<uint16_t, mediakit::RtpPacket::Ptr> _nack_cache_pkt;
}; };
......
Markdown 格式
0%
您添加了 0 到此讨论。请谨慎行事。
请先完成此评论的编辑!
注册 或者 后发表评论