我正在开发一个与 Asterisk SIP 服务器通信的基于 JavaScript 的 Web SIP 客户端。
SIP 客户端使用的是 JSSIP 3.4.2,我正在 Chrome 版本 80 上进行测试。
SIP 客户端和 SIP 服务器都位于防火墙后面。我正在使用 STUN 服务器stun.l.google.com:19302。
呼叫建立良好,但在调用“call”方法和建立呼叫(开始 RTP 会话)之间有40 秒的延迟。
这是SIP UA注册的代码:
// SIP UA registration
var currentUserSipAccount = {
uri: '211',
pwd: 'secret'
};
var sipDomain = 'sip.my-domain.com';
var sipServerUrl = 'wss://' + sipDomain + ':8089/ws';
var socket = new JsSIP.WebSocketInterface(sipServerUrl);
var connectionParams = {};
connectionParams.sockets = [socket];
connectionParams.register = true;
connectionParams.uri = 'sip:' + currentUserSipAccount.uri + '@' + sipDomain;
connectionParams.password = currentUserSipAccount.pwd;
var bwPhone = new JsSIP.UA(connectionParams);
这是调用发起的代码:
// SIP call
var callNumber = 'sip:233@' + sipDomain;
var callOptions = {
mediaConstraints: {
audio: true, // only audio calls
video: false
},
pcConfig: {
iceServers: [
{'urls': ['stun:stun.l.google.com:19302']}
]
}
};
bwPhone.call(callNumber, callOptions);
我已经设置了每个 SIP 事件的日志记录,发现延迟与onicegatheringstatechange和onicecandidate事件有关。
这是 Wireshark 日志:
每 10 秒发送一次 STUN 请求,然后是即时响应。这种情况发生 4 次。
这是我得到的浏览器控制台日志:
我打电话的电脑有多个网络接口。我看到icecandidate事件包含两个 IP 地址,其中一个 (169.254.128.100) 与以太网有关且未使用,另一个 (192.168.1.33) 与 WiFi 有关并用于连接到 Internet。
我还在浏览器控制台日志中看到,在启动呼叫后的几毫秒内收到了 STUN 响应。但在那之后,JSSIP 会等待 40 秒!
如何避免这 40 秒的延迟?