FreeSWITCH跨NAT部署配置詳解
引言
本文僅討論FreeSWITCH部署在NAT之后(里面)這種場(chǎng)景,假設(shè)私網(wǎng)地址與公網(wǎng)地址有一個(gè)確定的映射關(guān)系。
這里只涉及mod_sofia(SIP信令及媒體)相關(guān)配置,其他模塊不在本文討論之列。
配置
mod_sofia默認(rèn)提供兩個(gè)profile,可以理解成是兩套配置,最主要的區(qū)別是監(jiān)聽端口不一樣,其他的區(qū)別包括是否啟用TLS加密,使用哪個(gè)撥號(hào)計(jì)劃等等。這里以internal profile為例。
1、配置預(yù)處理變量
FreeSWITCH的慣例是把預(yù)處理變量定義在vars.xml文件中,然后再由其他配置文件去引用。這里我們主要關(guān)注公網(wǎng)地址以及SIP監(jiān)聽端口。
etc/freeswitch/vars.xml
<include> <!-- 注意,X-PRE-PROCESS開頭的配置都是預(yù)處理配置,有點(diǎn)像是定義全局變量,但是變量的值可以在程序啟動(dòng)時(shí)動(dòng)態(tài)獲取到 --> <!-- 這兩個(gè)變量必須要設(shè)置成公網(wǎng)IP,有3種方法配置公網(wǎng)IP: --> <!-- 1、配一個(gè)固定的公網(wǎng)IP --> <X-PRE-PROCESS cmd="set" data="external_rtp_ip=172.21.221.137"/> <X-PRE-PROCESS cmd="set" data="external_sip_ip=172.21.221.137"/> <!-- 2、通過(guò)公網(wǎng)上的stun服務(wù)動(dòng)態(tài)獲取 --> <X-PRE-PROCESS cmd="stun-set" data="external_rtp_ip=stun:stun.freeswitch.org"/> <X-PRE-PROCESS cmd="stun-set" data="external_sip_ip=stun:stun.freeswitch.org"/> <!-- 3、通過(guò)域名解析動(dòng)態(tài)獲取 --> <X-PRE-PROCESS cmd="set" data="external_rtp_ip=host:host.server.com"/> <X-PRE-PROCESS cmd="set" data="external_sip_ip=host:host.server.com"/> <!-- 配置兩個(gè)profile所監(jiān)聽的SIP端口: --> <!-- Internal SIP Profile --> <X-PRE-PROCESS cmd="set" data="internal_auth_calls=true"/> <X-PRE-PROCESS cmd="set" data="internal_sip_port=5060"/> <X-PRE-PROCESS cmd="set" data="internal_tls_port=5061"/> <X-PRE-PROCESS cmd="set" data="internal_ssl_enable=false"/> <!-- External SIP Profile --> <X-PRE-PROCESS cmd="set" data="external_auth_calls=false"/> <X-PRE-PROCESS cmd="set" data="external_sip_port=5080"/> <X-PRE-PROCESS cmd="set" data="external_tls_port=5081"/> <X-PRE-PROCESS cmd="set" data="external_ssl_enable=false"/> </include>
2、配置sip profiles
這里才是mod_sofia真正會(huì)讀取的配置。這里以internal profile為例,external同理。
etc/freeswitch/sip_profiles/internal.xml
<profile name="internal">
<settings>
<!--
這里引用vars.xml里面配置的全局變量。注意,要以$${var}的形式引用!
注意,local_ip_v4這個(gè)全局變量是fs_core自動(dòng)設(shè)置的,每分鐘更新一次。如果機(jī)器有多個(gè)IP,需要手動(dòng)指定一個(gè),詳見官方文檔:
https://developer.signalwire.com/freeswitch/Channel-Variables-Catalog/local_ip_v4_16353556/
-->
<!-- 當(dāng)前這個(gè)profile所要監(jiān)聽的SIP端口。 -->
<param name="sip-port" value="$${internal_sip_port}"/>
<!-- 接收RTP流的端口要綁定在哪個(gè)地址上。只能是IP地址,不能是域名! -->
<param name="rtp-ip" value="$${local_ip_v4}"/>
<!-- 接收SIP請(qǐng)求的端口要綁定在哪個(gè)地址上。同上,只能是IP地址。 -->
<param name="sip-ip" value="$${local_ip_v4}"/>
<!-- 對(duì)外通告RTP消息時(shí)所用的地址。 -->
<param name="ext-rtp-ip" value="$${external_rtp_ip}"/>
<!-- SIP報(bào)文中Contact header的地址。 -->
<param name="ext-sip-ip" value="$${external_sip_ip}"/>
</settings>
</profile>3、配置媒體端口范圍
有些NAT或防火墻只能映射或允許一個(gè)范圍內(nèi)的端口,這就需要調(diào)整FreeSWITCH接收RTP媒體流所用的端口范圍。
注意:FreeSWITCH使用偶數(shù)端口接受RTP流,使用奇數(shù)端口收發(fā)RTCP消息。假如需要承載50路通話,則至少要映射100個(gè)端口!
etc/freeswitch/autoload_configs/switch.conf.xml
<configuration name="switch.conf" description="Core Configuration">
<settings>
<!-- RTP port range -->
<param name="rtp-start-port" value="40000"/>
<param name="rtp-end-port" value="40009"/>
</settings>
</configuration>驗(yàn)證
人為改一下ext-rtp-ip和ext-sip-ip,觀察它們的作用:

此時(shí)有一個(gè)到達(dá)internal profile的呼叫,從FreeSWITCH回復(fù)的200 OK中可以看到,Contact header中填的是ext-sip-ip,而SDP部分填的是ext-rtp-ip:

問(wèn)題
- 私網(wǎng)端口號(hào)與公網(wǎng)端口號(hào)不一樣怎么辦?比如:私網(wǎng):5060 <==> 公網(wǎng):8060
- 恐怕只能修改代碼了。mod_sofia可以支持監(jiān)聽I(yíng)P與通告IP不一致,但端口不能不一致。即它就只能在SIP報(bào)文中通告它自己本地監(jiān)聽的端口。
以上就是FreeSWITCH跨NAT部署配置詳解的詳細(xì)內(nèi)容,更多關(guān)于FreeSWITCH跨NAT部署的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Java實(shí)現(xiàn)SMS短信通發(fā)送手機(jī)驗(yàn)證碼案例講解
這篇文章主要介紹了Java實(shí)現(xiàn)SMS短信通發(fā)送手機(jī)驗(yàn)證碼案例講解,本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-08-08
SpringBoot中API接口參數(shù)獲取方式小結(jié)
在Spring Boot中,API接口參數(shù)可以通過(guò)多種方式獲取,具體取決于你定義的API接口參數(shù)類型(如路徑參數(shù)、查詢參數(shù)、請(qǐng)求體參數(shù)、請(qǐng)求頭等),本文給大家就介紹了一些常見的參數(shù)獲取方式,需要的朋友可以參考下2024-06-06
詳解Spring cloud使用Ribbon進(jìn)行Restful請(qǐng)求
這篇文章主要介紹了詳解Spring cloud使用Ribbon進(jìn)行Restful請(qǐng)求,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-04-04
解析iReport自定義行數(shù)分頁(yè)的操作方法
ireport默認(rèn)都是自動(dòng)分頁(yè)數(shù)據(jù)超出頁(yè)面長(zhǎng)度就會(huì)自動(dòng)分到下一頁(yè),但有時(shí)候業(yè)務(wù)需要一頁(yè)只顯示固定幾行這時(shí)候就需要自定義條數(shù)了。下面看具體操作吧2021-10-10
BeanUtils.copyProperties使用總結(jié)以及注意事項(xiàng)說(shuō)明
這篇文章主要介紹了BeanUtils.copyProperties使用總結(jié)以及注意事項(xiàng)說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-08-08
SpringBoot中的Redis?緩存問(wèn)題及操作方法
這篇文章主要介紹了SpringBoot中的Redis?緩存,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-10-10
Java并發(fā)系列之AbstractQueuedSynchronizer源碼分析(獨(dú)占模式)
這篇文章主要為大家詳細(xì)介紹了Java并發(fā)系列之AbstractQueuedSynchronizer源碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-02-02

