說(shuō)明,筆者根據(jù)以前安裝流程來(lái)實(shí)現(xiàn)的OpenSIPS安裝配置,所以,默認(rèn)環(huán)境和以下使用的很多命令仍然是按照默認(rèn)環(huán)境來(lái)執(zhí)行的。用戶需要首先確保安裝環(huán)境更新,以便能夠順利安裝必要的支持包。具體配置說(shuō)明,請(qǐng)參考:
最完整快速的安裝方式安裝開(kāi)源OpenSIPS-3.1和CP控制界面-class 8
1安裝mysql數(shù)據(jù)庫(kù)和JSON
一般來(lái)說(shuō),SIP服務(wù)提供商或者企業(yè)電話系統(tǒng)的呼叫都需要經(jīng)過(guò)一定的數(shù)據(jù)庫(kù)安全認(rèn)證。OpenSIPS 的SIP用戶可以使用無(wú)密碼的呼叫設(shè)置,但是為了保證其安全,絕大部分的場(chǎng)景中仍然需要用戶密碼設(shè)置。用戶需要首先確認(rèn)支持包安裝成功,執(zhí)行以下命令檢查:
apt-get install opensips-mysql-module
ls /usr/lib/x86_64-linux-gnu/opensips/modules/db_mysql.so
安裝成功用戶,然后安裝JSON接口支持包(因?yàn)榻缑嫦到y(tǒng)需要通過(guò)此接口連接):
apt-get install opensips-http-modules
ls /usr/lib/x86_64-linux-gnu/opensips/modules/httpd.so
2創(chuàng)建數(shù)據(jù)庫(kù)相關(guān)表
用戶通過(guò)CLI命令安裝數(shù)據(jù)庫(kù)的表:
opensips-cli -x database create opensips_new
輸入DB URL:mysql://localhost。執(zhí)行數(shù)據(jù)庫(kù)創(chuàng)建流程。注意,這里的數(shù)據(jù)庫(kù)用戶名稱和密碼:opensips:opensipsrw,用戶也可以使用其他的用戶名稱,但是一定要注意在后續(xù)的其他配置中做相應(yīng)修改保證其安全性。
#mysql
> CREATE USER 'opensips'@'localhost' IDENTIFIED BY 'opensipsrw';
> GRANT ALL PRIVILEGES ON opensips.* TO 'opensips'@'localhost';
> FLUSH PRIVILEGES;
> QUIT
3修改cfg文件支持注冊(cè)和呼叫請(qǐng)求流程
數(shù)據(jù)庫(kù)和支持包安裝好以后,我們開(kāi)始配置和用戶注冊(cè),呼叫相關(guān)的流程。opensips的cfg文件需要增加一些必要的配置。首先,cfg文件需要加載支持模塊:
loadmodule "httpd.so"
modparam("httpd", "port", 8080) // GUI 端口
loadmodule "mi_http.so"
modparam("mi_http", "root", "json") // 支持json
加載mysql 數(shù)據(jù)庫(kù)模塊:
loadmodule "db_mysql.so"
設(shè)置相關(guān)模塊的參數(shù)設(shè)置,注意mysql數(shù)據(jù)庫(kù)用戶名稱和密碼
modparam("usrloc", "working_mode_preset", "single-instance-sql-write-back")
modparam("usrloc", "db_url",
"mysql://opensips:opensipsrw@localhost/opensips")
增加auth模塊對(duì)SIP用戶的支持,注意數(shù)據(jù)庫(kù)的用戶名稱和密碼
loadmodule "auth.so"
loadmodule "auth_db.so"
modparam("auth_db", "calculate_ha1", 1)
modparam("auth_db", "password_column", "password")
modparam("auth_db|uri", "db_url",
"mysql://opensips:opensipsrw@localhost/opensips")
modparam("auth_db", "load_credentials", "")
在相關(guān)auth的檢查腳本中增加檢測(cè):
if (!proxy_authorize("", "subscriber")) {
proxy_challenge("", "auth");
exit;
}
if (!$au==$fU) {
send_reply(403,"Forbidden auth ID");
exit;
}
consume_credentials();
if (!www_authorize("", "subscriber")) {
www_challenge("", "auth");
exit;
}
if (!$au==$tU) {
send_reply(403,"Forbidden auth ID");
exit;
}
配置文件修改以后,用戶保存配置文件,然后重新啟動(dòng)opensips服務(wù)器。
4在opensips-cli 添加必要參數(shù)支持
用戶編輯opensips-cli.cfg文件,添加數(shù)據(jù)庫(kù)的參數(shù)支持,注意數(shù)據(jù)庫(kù)用戶和密碼設(shè)置和創(chuàng)建數(shù)據(jù)庫(kù)時(shí)的匹配。
database_url: mysql://opensips:opensipsrw@localhost
database_name: opensips
database_modules: ALL
domain: sip.domain.com // 也可以是其他的domain,sip.freepbx.cn
plain_text_passwords: true
注意,如果還有opensips.org的話,要?jiǎng)h除。通過(guò)CLI命令添加兩個(gè)SIP用戶和密碼:
opensips-cli -x user add 1000 freepbx
opensips-cli -x user add 1001 freepbx
重新啟動(dòng)原來(lái)使用的兩個(gè)軟電話分機(jī),重新注冊(cè),測(cè)試雙方的呼叫。如果一切配置成功的話,雙方的呼叫是成功的。如果用戶想刪除注冊(cè)信息的話,也可以執(zhí)行以下命令:
opensips-cli -x mi ul_rm location XXXX // 刪除SIP賬號(hào) XXXX
或者使用dump命令檢查location的狀態(tài):
opensips-cli -x mi ul_dump
5OpenSIPS的多租戶配置支持
很多時(shí)候,如果運(yùn)營(yíng)商做IPPBX的運(yùn)營(yíng)的話,它們可能會(huì)在OpenSIPS平臺(tái)配置多租戶的SIP用戶帳戶支持不同的企業(yè)客戶。這里,一般的多租戶就是指對(duì)多個(gè)域名的支持,企業(yè)用戶通過(guò)自己的域名來(lái)定義用戶,用戶具有不同域名下的SIP賬號(hào)。例如,1000:@sip.A.com和1000@sip.B.com 是完全不同的兩個(gè)SIP賬號(hào),分別屬于兩個(gè)公司的SIP賬號(hào)。筆者這里不過(guò)多介紹關(guān)于多租戶運(yùn)營(yíng)的優(yōu)缺點(diǎn),用戶可以通過(guò)網(wǎng)上資料來(lái)獲得一些背景知識(shí)。通過(guò)界面設(shè)置多租戶的SIP用戶帳戶需要修改幾個(gè)必要的配置文件。首先需要修改GUI配置文件的環(huán)境支持密碼為明文的密碼設(shè)置:
通過(guò)vim 編輯以下文件:
/var/www/html/opensips-cp/config/tools/users/user_management/local.inc.php
Set $config->passwd_mode=0
保存此文件。然后用戶需要修改cfg配置文件,增加相關(guān)的模塊加載和測(cè)試配置。
loadmodule "domain.so"
modparam("domain", "db_url",
"mysql://opensips:opensipsrw@localhost/opensips") // 注意密碼
modparam("domain", "db_mode", 1) # 使用catching
modparam("auth_db|usrloc", "use_domain", 1)
在opensips.cfg中增加其他的判斷腳本:
## authenticate and authorize
#if(is_myself("$fd")) { /*no multidomain version*/
if(is_from_local()) { /*multidomain version*/
修改判斷設(shè)置:
##if (!is_myself("$rd")) {
if (!is_uri_host_local()) {
保存cfg配置文件,重新啟動(dòng)opensips,然后通過(guò)命令查看啟動(dòng)狀態(tài):
systemctl status opensips
如果有關(guān)于SIP賬號(hào)的domain錯(cuò)誤的話,用戶可能會(huì)注冊(cè)失敗。用戶可以刪除數(shù)據(jù)庫(kù)的location再次測(cè)試。如果前面的配置成功配置以后,用戶可以通過(guò)界面來(lái)添加不同的domain:

每次添加domain以后,因?yàn)槟K使用了catched設(shè)置,用戶需要點(diǎn)擊”Reload on Server“ 服務(wù)器來(lái)重新加載模塊數(shù)據(jù),從數(shù)據(jù)庫(kù)更新數(shù)據(jù)。
用戶添加了doamin以后,也可以通過(guò)界面添加此域名下的多租戶的SIP賬號(hào),例如1000,1001。

用戶在注冊(cè)成功以后,如果管理員想查看contact的信息,可以點(diǎn)擊Contacts查看SIP的狀態(tài)消息:


管理員也可以刪除contacts:

6OpenSIPS添加SIP賬號(hào)用戶別名
別名是SIP賬號(hào)中一種比較實(shí)用功能。在SIP平臺(tái)中,如果PSTN呼入以后,可以作為一個(gè)DID的轉(zhuǎn)發(fā)呼叫然后路由到SIP服務(wù)器的SIP賬號(hào)中。用戶也可以根據(jù)不同的業(yè)務(wù)組對(duì)SIP賬號(hào)定義不同的名稱。簡(jiǎn)單來(lái)說(shuō),呼叫方呼叫目的地號(hào)碼時(shí)可以使用不同的簡(jiǎn)化的號(hào)碼或者其他別名進(jìn)行呼叫,而不呼叫原號(hào)碼。SIP賬號(hào)使用別名可以方便呼叫方撥號(hào),也可以實(shí)現(xiàn)對(duì)呼入號(hào)碼的DID路由。在opensips的平臺(tái)環(huán)境中,別名的URL通過(guò)opensips轉(zhuǎn)譯成一個(gè)本地的SIP賬號(hào),通過(guò)數(shù)據(jù)庫(kù)dbaliases lookup的查詢方式實(shí)現(xiàn)Alias-URI 和原始Original-URI的處理。
如果需要通過(guò)opensips實(shí)現(xiàn)別名支持的話,我們需要加載dbaliases和其相關(guān)的參數(shù)配置選項(xiàng)。打開(kāi)opensips.cfg 配置文件,添加別名數(shù)據(jù)庫(kù)的參數(shù)配置:
loadmodule "alias_db.so"
modparam("alias_db", "db_url",
"mysql://opensips:opensipsrw@localhost/opensips") // 注意數(shù)據(jù)庫(kù)密碼
#apply DB based aliases (uncomment to enable)
alias_db_lookup("dbaliases");
保存cfg文件,重新啟動(dòng)opensips,然后對(duì)SIP賬號(hào)1000添加別名。這里的別名可以是任意的號(hào)碼,號(hào)碼格式也可以通過(guò)界面配置文件進(jìn)行自定義的格式支持。用戶可以根據(jù)自己的業(yè)務(wù)需求對(duì)SIP 1000賬號(hào)添加一個(gè)別名,例如186XXX或者其他的號(hào)碼,方便記憶,發(fā)布使用管理即可。


如果用戶需要對(duì)別名號(hào)碼實(shí)現(xiàn)號(hào)碼格式的驗(yàn)證支持的話,用戶可以修改php配置文件:
vim:opensips-cp/config/tools/users/alias_management/local.inc.php
$config->alias_format = "/^[0-9a-zA-Z]+/"; // 強(qiáng)制的號(hào)碼格式
保存php文件,重新刷新界面就可以實(shí)現(xiàn)別名號(hào)碼格式的強(qiáng)制設(shè)置。
修改了別名以后,我們使用另外一個(gè)SIP 賬號(hào),例如1001,呼叫設(shè)置了別名為其他號(hào)碼的,例如186123。如果配置成功的話,SIP 1000就會(huì)振鈴。說(shuō)明,SIP 1000支持的別名設(shè)置186123是成功的。
以上是opensips的多租戶的實(shí)現(xiàn)方式,當(dāng)然也可以通過(guò)SBC或者freesbc支持的不同的多租戶方式實(shí)現(xiàn)對(duì)內(nèi)網(wǎng)IPPBX的內(nèi)網(wǎng)管理方式。freesbc/prosbc作為一個(gè)多租戶的前端服務(wù)器,呼叫進(jìn)入以后,通過(guò)不同的域名路由到不同的內(nèi)網(wǎng)的IPPBX,IPPBX各自獨(dú)立。外網(wǎng)SIP賬號(hào)通過(guò)域名方式加FreeSBC地址來(lái)實(shí)現(xiàn)注冊(cè)。

freesbc多租戶IPPBX支持
7總結(jié)
本章節(jié)主要介紹了關(guān)于通過(guò)mysql數(shù)據(jù)庫(kù)實(shí)現(xiàn)SIP賬號(hào)認(rèn)證的配置,多租戶設(shè)置和別名設(shè)置。為了實(shí)現(xiàn)以上的配置,opensips需要首先安裝mysql數(shù)據(jù)庫(kù),創(chuàng)建數(shù)據(jù)庫(kù)和創(chuàng)建用戶表,并且需要在cfg文件中加載數(shù)據(jù)庫(kù)和相關(guān)的參數(shù)。為了實(shí)現(xiàn)多租戶的支持,opensips需要加載多租戶模塊,然后通過(guò)界面來(lái)創(chuàng)建一個(gè)多租戶,然后按照多租戶來(lái)創(chuàng)建一個(gè)SIP賬號(hào)。最后,筆者介紹了關(guān)于別名的使用和其配置方式以及測(cè)試結(jié)果。通過(guò)以上比較詳細(xì)的介紹,希望opensips用戶能夠熟悉關(guān)于多租戶的實(shí)現(xiàn)和SIP別名的管理。
參考資料:
https://docs.telcobridges.com/tbwiki/FreeSBC:_Multiple_Domains/Hosted_PBXs_Configuration
www.freesbc.cn
www.opensips.org
融合通信/IPPBX/FreePBX商業(yè)解決方案:www.hiastar.com
最新Asterisk完整中文用戶手冊(cè)詳解:www.asterisk.org.cn
Freepbx/FreeSBC技術(shù)文檔: www.freepbx.org.cn
如何使用免費(fèi)會(huì)話邊界控制器-FreeSBC,qq技術(shù)分享群:334023047
關(guān)注微信公眾號(hào):asterisk-cn,獲得有價(jià)值的通信行業(yè)技術(shù)分享