mediasoup源码走读(十二)——router

十二、router


12.1、Router 核心定位与模块交互

Router 是 Mediasoup 的"媒体流中枢",其核心价值体现在:

  • 媒体路由:管理 Producer 与 Consumer 之间的 RTP 包交换
  • 房间管理:作为多方会议的逻辑容器
  • 资源协调:协调 Transport、Producer、Consumer 的生命周期
  • 动态策略:支持 Simulcast/SVC 编码层切换

模块交互全景图
创建/管理 注册/管理 订阅/管理 网络通道 进程通信 媒体流发布 媒体流接收 网络传输 Router Worker Producer Consumer Transport Network


12.2、端到端工作流程

应用层 Mediasoup Router Producer Consumer Transport Worker进程 createRouter(mediaCodecs) 创建Router实例 注册到Worker管理 createProducer(transport) 创建Producer实例 注册到Router管理 createConsumer(producer) 创建Consumer实例 注册到Router管理 SendRtpPacket(packet) ForwardRtpPacket(packet) 触发track事件 loop [媒体流转发] close() 通知关闭 确认关闭 通知关闭 确认关闭 通知关闭 确认关闭 应用层 Mediasoup Router Producer Consumer Transport Worker进程


12.3、关键模块交互代码

12.3.1 Router 与 Worker 的进程通信

Worker 创建 Router

cpp 复制代码
// mediasoup/src/Worker.cpp
Router* Worker::CreateRouter(
  const std::vector<MediaCodec>& mediaCodecs
) {
  // 1. 生成唯一ID
  std::string id = GenerateId("router");
  
  // 2. 创建Router实例
  Router* router = new Router(
    this, id, mediaCodecs
  );
  
  // 3. 注册到Worker管理
  routers_.insert({id, router});
  
  return router;
}

Router 与 Worker 的 IPC 通信

cpp 复制代码
// mediasoup/src/Router.cpp
void Router::SendToWorker(const std::string& method, const json& data) {
  worker_->SendRequest(method, data);
}
12.3.2 Router 与 Producer 的媒体路由

Router 创建 Producer

cpp 复制代码
// mediasoup/src/Router.cpp
Producer* Router::CreateProducer(
  Transport* transport,
  const std::string& trackId,
  const std::string& trackKind,
  const std::string& codec,
  const std::string& codecOptions,
  const std::vector<Encoding>& encodings
) {
  // 1. 生成唯一ID
  std::string id = GenerateId("producer");
  
  // 2. 创建Producer实例
  Producer* producer = new Producer(
    this, id, transport, trackId, trackKind, codec, 
    codecOptions, encodings
  );
  
  // 3. 注册到Router管理
  producers_.insert({id, producer});
  
  // 4. 通知Worker
  SendToWorker("producer-created", producer->ToJson());
  
  return producer;
}

Producer 关闭时通知 Router

cpp 复制代码
// mediasoup/src/Producer.cpp
void Producer::Close() {
  if (isClosed) return;
  
  isClosed = true;
  Emit("close");
  
  // 通知Router
  router->OnProducerClosed(this);
}

Router 处理 Producer 关闭

cpp 复制代码
// mediasoup/src/Router.cpp
void Router::OnProducerClosed(Producer* producer) {
  producers_.erase(producer->id);
  SendToWorker("producer-closed", {{"id", producer->id}});
}
12.3.3 Router 与 Consumer 的媒体订阅

Router 创建 Consumer

cpp 复制代码
// mediasoup/src/Router.cpp
Consumer* Router::CreateConsumer(
  Transport* transport,
  Producer* producer,
  const std::string& trackId,
  const std::string& trackKind
) {
  // 1. 生成唯一ID
  std::string id = GenerateId("consumer");
  
  // 2. 创建Consumer实例
  Consumer* consumer = new Consumer(
    this, id, transport, producer, trackId, trackKind
  );
  
  // 3. 注册到Router管理
  consumers_.insert({id, consumer});
  
  // 4. 通知Producer
  producer->OnConsumerCreated(consumer);
  
  return consumer;
}

Consumer 关闭时通知 Router

cpp 复制代码
// mediasoup/src/Consumer.cpp
void Consumer::Close() {
  if (isClosed) return;
  
  isClosed = true;
  Emit("close");
  
  // 通知Router
  router->OnConsumerClosed(this);
}

Router 处理 Consumer 关闭

cpp 复制代码
// mediasoup/src/Router.cpp
void Router::OnConsumerClosed(Consumer* consumer) {
  consumers_.erase(consumer->id);
  SendToWorker("consumer-closed", {{"id", consumer->id}});
}
12.3.4 Router 与 Transport 的网络通道管理

Transport 注册到 Router

cpp 复制代码
// mediasoup/src/Transport.cpp
void Transport::RegisterWithRouter(Router* router) {
  router->AddTransport(this);
}

// mediasoup/src/Router.cpp
void Router::AddTransport(Transport* transport) {
  transports_.insert({transport->id, transport});
}

Transport 关闭时通知 Router

cpp 复制代码
// mediasoup/src/Transport.cpp
void Transport::Close() {
  if (isClosed) return;
  
  isClosed = true;
  Emit("close");
  
  // 通知Router
  if (router) {
    router->OnTransportClosed(this);
  }
}

Router 处理 Transport 关闭

cpp 复制代码
// mediasoup/src/Router.cpp
void Router::OnTransportClosed(Transport* transport) {
  transports_.erase(transport->id);
  SendToWorker("transport-closed", {{"id", transport->id}});
}

12.4、Router 的完整生命周期管理

12.4.1 生命流程图

Creating Active Closed

12.4.2 关键生命周期方法

创建

cpp 复制代码
// mediasoup/src/Router.cpp
Router::Router(
  Worker* worker,
  const std::vector<MediaCodec>& mediaCodecs
) : 
  worker(worker),
  id(GenerateId("router")),
  mediaCodecs(mediaCodecs),
  isClosed(false) {
  
  // 1. 注册到Worker
  worker->CreateRouter(this);
  
  // 2. 初始化媒体编解码器
  InitializeCodecs(mediaCodecs);
}

关闭

cpp 复制代码
// mediasoup/src/Router.cpp
void Router::Close() {
  if (isClosed) return;
  
  isClosed = true;
  Emit("close");
  
  // 1. 关闭所有Producer
  for (auto& producer : producers_) {
    producer->Close();
  }
  
  // 2. 关闭所有Consumer
  for (auto& consumer : consumers_) {
    consumer->Close();
  }
  
  // 3. 关闭所有Transport
  for (auto& transport : transports_) {
    transport->Close();
  }
  
  // 4. 通知Worker
  worker->OnRouterClosed(this);
}

12.5、Router 的模块交互与生命周期总结

模块交互核心价值

模块 交互方式 关键作用 交互点体现
Worker 创建/管理/通信 跨进程资源协调 worker->CreateRouter()
Producer 创建/管理/媒体转发 媒体流发布与路由 router->CreateProducer()
Consumer 创建/管理/媒体订阅 媒体流接收与路由 router->CreateConsumer()
Transport 注册/管理/网络通道 网络传输通道管理 router->AddTransport()

关键交互点分析

  1. 媒体路由:Router 作为中央枢纽,协调 Producer 与 Consumer 的媒体流转发
  2. 资源管理:统一管理 Transport、Producer、Consumer 的生命周期
  3. 进程通信:通过 IPC 与 Worker 进程保持同步,确保跨进程一致性
  4. 动态策略:支持 Simulcast/SVC 编码层切换,适应网络变化
相关推荐
WX13169518998几秒前
音频分析仪APX525 APX515 APX528 APX526测试参数
科技·音视频·信息与通信
北辰当尹8 分钟前
【实习之旅】Kali虚拟机桥接模式ping通百度
java·服务器·桥接模式
阿巴~阿巴~12 分钟前
从不可靠到100%可靠:TCP与网络设计的工程智慧全景解析
运维·服务器·网络·网络协议·tcp/ip·智能路由器
飞翔的小->子>弹->14 分钟前
CMK、CEK
服务器·数据库·oracle
Facechat19 分钟前
视频混剪-特效篇
音视频
散峰而望24 分钟前
【算法竞赛】顺序表和vector
c语言·开发语言·数据结构·c++·人工智能·算法·github
食咗未29 分钟前
Linux iptables工具的使用
linux·运维·服务器·驱动开发·网络协议·信息与通信
阿巴~阿巴~34 分钟前
从IP到MAC,从内网到公网:解密局域网通信与互联网连接的完整路径
服务器·网络·网络协议·架构·智能路由器·tcp·arp
de之梦-御风34 分钟前
【视频投屏】最小可用(MVP)局域网投屏”开源项目架构
架构·开源·音视频
cpp_250137 分钟前
B3927 [GESP202312 四级] 小杨的字典
数据结构·c++·算法·题解·洛谷