【发布时间】:2015-01-31 23:49:27
【问题描述】:
我正在尝试设置一个运行 freeSWITCH 的 Docker 容器,以便我可以将它部署在 Debian 服务器上。
为了进行开发,我使用 Mac 在 boot2docker 中运行 freeSWITCH 容器。
我需要容器在这两种环境中工作。
我设法用软电话连接到 FS 服务器并拨打了电话,但 32 秒后,电话掉线了。
freeswitch@internal> version
FreeSWITCH Version 1.4.15-1~64bit (-1 64bit)
这是 FS 发送并期望得到答复的 SIP 200 OK 数据包:
14 0.029449000 192.168.59.103 192.168.59.3 SIP/SDP 1312 Status: 200 OK |
SIP/2.0 200 OK
Via: SIP/2.0/UDP 192.168.1.141:49822;rport=49822;branch=z9hG4bKPjFf3iaNQ0tDY1fySiz1zGSEXSVFpZeE2b;received=192.168.59.3
From: "1000" <sip:1000@192.168.59.103>;tag=tNpJHmkYg0ke5GYyvIhkdBSIMM.ujzXE
To: <sip:5000@192.168.59.103>;tag=6N3793jeayeUe
Call-ID: 4wWTcxr9Q4OqlgT2Fs-8SeOkLhVYXTLb
CSeq: 10007 INVITE
Contact: <sip:5000@172.17.0.6:5060;transport=udp>
User-Agent: FreeSWITCH-mod_sofia/1.4.15-1~64bit
Accept: application/sdp
Allow: INVITE, ACK, BYE, CANCEL, OPTIONS, MESSAGE, INFO, UPDATE, REGISTER, REFER, NOTIFY, PUBLISH, SUBSCRIBE
Supported: timer, path, replaces
Allow-Events: talk, hold, conference, presence, as-feature-event, dialog, line-seize, call-info, sla, include-session-description, presence.winfo, message-summary, refer
Content-Type: application/sdp
Content-Disposition: session
Content-Length: 333
Remote-Party-ID: "5000" <sip:5000@192.168.59.103>;party=calling;privacy=off;screen=no
v=0
o=FreeSWITCH 1422731206 1422731207 IN IP4 172.17.0.6
s=FreeSWITCH
c=IN IP4 172.17.0.6
t=0 0
m=audio 16386 RTP/SAVP 9 101
a=rtpmap:9 G722/8000
a=rtpmap:101 telephone-event/8000
a=fmtp:101 0-16
a=ptime:20
a=rtcp:16387 IN IP4 172.17.0.6
a=crypto:1 AES_CM_128_HMAC_SHA1_80 inline:/NTeSA7Od0+1Uo1/3wIclZwEiKJ+R4Mh8gyTx+5O
然后发生这种情况:
1745 32.031059000 192.168.59.103 192.168.59.3 SIP 664 Request: BYE sip:29716085@192.168.59.3:49822 |
BYE sip:29716085@192.168.59.3:49822 SIP/2.0
Via: SIP/2.0/UDP 172.17.0.6;rport;branch=z9hG4bK0m429X0ac150r
Max-Forwards: 70
From: <sip:5000@192.168.59.103>;tag=6N3793jeayeUe
To: "1000" <sip:1000@192.168.59.103>;tag=tNpJHmkYg0ke5GYyvIhkdBSIMM.ujzXE
Call-ID: 4wWTcxr9Q4OqlgT2Fs-8SeOkLhVYXTLb
CSeq: 71037748 BYE
Contact: <sip:5000@172.17.0.6:5060;transport=udp>
User-Agent: FreeSWITCH-mod_sofia/1.4.15-1~64bit
Allow: INVITE, ACK, BYE, CANCEL, OPTIONS, MESSAGE, INFO, UPDATE, REGISTER, REFER, NOTIFY, PUBLISH, SUBSCRIBE
Supported: timer, path, replaces
Reason: SIP;cause=408;text="ACK Timeout"
Content-Length: 0
我猜 FS 永远不会收到来自软电话的应答,因为有各种 NAT 层,并且假设它没有连接,就会挂断电话。
192.168.1.141 是我的 Mac 在 LAN 上的 IP 地址(如 200 OK 数据包的 VIA 所示)
192.168.59.103 是 boot2docker 虚拟机
192.168.59.3 是我在 boot2docker 虚拟网络上的 Mac
172.17.0.xxx 是 FS 服务器在 Docker 网络上的 IP 地址(这个 IP 会根据之前/之前运行的容器数量而变化)
这是我的 sip_profiles/internal.xml 中的内容
<param name="rtp-ip" value="$${local_ip_v4}"/>
<!-- ip address to bind to, DO NOT USE HOSTNAMES ONLY IP ADDRESSES -->
<param name="sip-ip" value="$${local_ip_v4}"/>
<param name="hold-music" value="$${hold_music}"/>
<param name="apply-nat-acl" value="nat.auto"/>
<!-- Docker NAT magic -->
<param name="ext-sip-ip" value="$${external_sip_ip}"/>
<param name="ext-rtp-ip" value="$${external_rtp_ip}"/>
在我的 vars.xml 中
<X-PRE-PROCESS cmd="set" data="external_rtp_ip=192.168.59.103"/>
<X-PRE-PROCESS cmd="set" data="external_sip_ip=192.168.59.103"/>
来自 fs_cli:
freeswitch@internal> eval ${external_rtp_ip}
192.168.59.103
freeswitch@internal> eval ${external_sip_ip}
192.168.59.103
freeswitch@internal> eval ${ext-rtp-ip}
-ERR no reply
freeswitch@internal> eval ${ext-sip-ip}
-ERR no reply
我已将端口 16384 设置为 16484 UDP 用于 RTP 流量,5060、5070、5080 UDP 和 TCP 用于 SIP,在 FS 和容器中。
回声测试表明音频是双向流动的。
知道发生了什么以及如何解决吗?
【问题讨论】:
-
您使用的是开箱即用的 vanilla sip 配置文件配置吗?外部配置文件配置为侦听端口 5080,尝试调用它。如果您调用端口 5060,那么您将被路由到未设置为执行 NAT 的内部配置文件。联系方式:<5000>5000>
标签: docker freeswitch boot2docker