背景
webrtc作为sip终端,freeswitch1.10.1版本作为sip注册服务器。打电话给webrtc,sip信令流程走完后,要过好几秒秒后才能听到声音。
抓包发现是dtls的握手过程持续了很长时间,webrtc一直发Client hello给freeswitch,而freeswitch要过数秒后才发送Server Hello给webrtc,之后dtls的握手过程会很快结束,双方才互相发送加密过的音频流数据。
经过不断增加日志追踪问题,最终定位到switch_rtp.c的1257行。
freeswitch会判断webrtc发送Client Hello的源地址是否正确,错误次数超过2次,也就是3次后,会放行走之后的逻辑。
解决方法
将switch_rtp.c的1257行 的"wrong_addrs > 2 " 改成 "wrong_addrs >= 0 ",然后重新编译安装freeswitch,问题解决