mediasoup udp端口分配策略

mediasoup-worker多进程启动时,rtcMinPort/rtcMaxPort可以使用相同的配置。

for (let i = 0; i < numWorkers; i++) {

let worker = await mediasoup.createWorker({

logLevel: config.mediasoup.worker.logLevel,

logTags: config.mediasoup.worker.logTags,

rtcMinPort: minPort,

rtcMaxPort: maxPort

})

}

如何避免port冲突呢?答案是mediasoup的node主进程来处理的。

async function createWorker({ logLevel = 'error', logTags, rtcMinPort = 10000, rtcMaxPort = 59999, dtlsCertificateFile, dtlsPrivateKeyFile, libwebrtcFieldTrials, appData } = {}) {

const worker = new Worker_1.Worker({

logLevel,

logTags,

rtcMinPort,

rtcMaxPort,

dtlsCertificateFile,

dtlsPrivateKeyFile,

libwebrtcFieldTrials,

appData

});

return new Promise((resolve, reject) => {

worker.on('@success', () => {

observer.safeEmit('newworker', worker);

resolve(worker);

});

worker.on('@failure', reject);

});

}

class Worker extends EnhancedEventEmitter_1.EnhancedEventEmitter {

// mediasoup-worker child process. mediasoup-worker是node.js的子进程。

// const child_process_1 = require("child_process"); //

#child;

let spawnBin = workerBin;

let spawnArgs = [];

if (typeof rtcMinPort === 'number' && !Number.isNaN(rtcMinPort)) {

spawnArgs.push(`--rtcMinPort=${rtcMinPort}`);

}

if (typeof rtcMaxPort === 'number' && !Number.isNaN(rtcMaxPort)) {

spawnArgs.push(`--rtcMaxPort=${rtcMaxPort}`);

}

spawnArgs.join(' '));

this.#child = (0, child_process_1.spawn)(

spawnBin,

spawnArgs,

}

//这个webrtcServer是属于node.js的

async createWebRtcServer({ listenInfos, appData }) {

const webRtcServer = new WebRtcServer_1.WebRtcServer({

internal: { webRtcServerId: reqData.webRtcServerId },

channel: this.#channel,

appData

});

this.#webRtcServers.add(webRtcServer);

return webRtcServer;

}

}

node.js的webRtcServer是c++ mediasoup-worker的封装。

关于RTP port,包括组成medsoup-cluster的pipeToRemoteRouter的RTP转发port,

是由node.js主进程统一管理使用的,在各个子进程间不会有冲突。

相关推荐
Nimsolax7 小时前
Linux网络传输层协议UDP
linux·网络·udp
zymill11 小时前
hysAnalyser --- 支持UDP实时流分析和录制功能
udp·音视频·实时音视频·ts流分析·mpegts录制
卷卷的小趴菜学编程11 小时前
Linux系统之----UDP、TCP详解
网络·tcp/ip·udp·滑动窗口·流量控制·拥塞避免·超时重传快重传
NiKo_W13 小时前
Linux TcpSocket编程
linux·服务器·网络·udp·socket·多线程·tcp
报错小能手2 天前
计算机网络自顶向下方法21——运输层 详解无连接运输:UDP (报文段结构、检验和)
网络协议·计算机网络·udp
打不了嗝 ᥬ᭄2 天前
传输层协议UDP
linux·网络·网络协议·udp
周杰伦_Jay3 天前
【网络核心协议全景解析】IP、TCP、UDP与HTTP(多表格深度对比)
网络·tcp/ip·udp
在坚持一下我可没意见3 天前
Java 网络编程:TCP 与 UDP 的「通信江湖」(基于UDP回显服务器)
java·服务器·开发语言·tcp/ip·udp·java-ee
刘孬孬沉迷学习3 天前
5G网络gNB与核心网(5GC)连接架构及传输协议
网络·网络协议·tcp/ip·5g·架构·udp·信息与通信
在坚持一下我可没意见3 天前
Java 网络编程:TCP 与 UDP 的「通信江湖」(基于TCP回显服务器)
java·服务器·开发语言·笔记·tcp/ip·udp·java-ee