使用kamailio进行分机注册及互拨
操作系统版本:Debian 12.5_x64
kamailio版本:5.8.2
kamailio作为专业的SIP服务器,可承担注册服务器的角色。今天记录下kamailio作为注册服务器,承接分机注册,并实现相互拨打的过程。
我将从以下几个方面展开:
- 模块配置
- 分机账号添加
- 无rtp代理的分机互拨
- 带rtp代理的分机互拨
配套资源下载
一、模块加载
模块文档地址:
https://kamailio.org/docs/modules/5.8.x/modules/registrar.html
模块加载及配置(使用kamailio的默认配置即可):
loadmodule "registrar.so" # ----- registrar params -----
modparam("registrar", "method_filtering", 1)
/* uncomment the next line to disable parallel forking via location */
# modparam("registrar", "append_branches", 0)
/* uncomment the next line not to allow more than 10 contacts per AOR */
# modparam("registrar", "max_contacts", 10)
/* max value for expires of registrations */
modparam("registrar", "max_expires", 3600)
/* set it to 1 to enable GRUU */
modparam("registrar", "gruu_enabled", 0)
kamailio的安装可参考这篇文章:
二、添加分机
命令格式如下:
kamctl add <username> <password>
示例:
kamctl add 2001 123456
如果提示如下错误:
ERROR: domain unknown: use usernames with domain or set default domain in SIP_DOMAIN

则需要编辑kamctlrc文件,配置SIP_DOMAIN变量。

账号信息存储在subscriber表中,效果如下:

可使用软电话注册验证,效果如下:

可添加多个用户:
kamctl add 2001 123456
kamctl add 2002 123456
数据表效果如下:

三、分机互拨
这里以内网的场景进行模拟。
分机2001和分机2002注册地址:192.168.137.1
kamailio地址:192.168.137.71
呼叫模型如下:

1、存储注册信息
配置相关模块,示例如下:
loadmodule "db_mysql.so"
loadmodule "usrloc.so" modparam("usrloc", "db_url", "mysql://root:test_123@192.168.137.1/kamailio71")
modparam("usrloc", "db_mode", 1)
modparam("usrloc", "use_domain", MULTIDOMAIN)
这里db_mode用1,直接写数据库,也可以用2,定时刷新到数据库。

2、添加分机路由
可以使用默认的LOCATION路由,也可以自定义路由,这里以自定义路由为例进行演示。
配置相关模块,示例如下:
loadmodule "sqlops.so"
modparam("sqlops","sqlcon","db=>mysql://root:test_123@192.168.137.1/kamailio71")
sqlops是用于查询数据库的"db=>"是定义的标识,后续查询时用db标签。
添加路由,使用 sql_xquery 函数查询数据库;
route(EXTEN);
路由内容如下:
route[EXTEN] {
if(!is_method("INVITE"))
return;
xlog("L_INFO","rU is $rU \n");
if (!registered("location")) {
xlog("L_INFO","$rU not registered\n");
exit;
}
sql_xquery("db","SELECT contact FROM location WHERE username='$rU';","rb");
if ( $xavp(rb=>contact) == $null) {
xlog("L_INFO","contact is null \n");
} else {
xlog("L_INFO","contact is $xavp(rb=>contact) \n");
$du = $xavp(rb=>contact);
}
xlog("L_INFO","rU is $rU , du is $du\n");
route(RELAY);
exit;
}
配置截图如下:

3、呼叫测试
这里使用分机2002拨打分机2001,路由成功,效果如下:

配套配置文件可从如下渠道获取:
关注微信公众号(聊聊博文,文末可扫码)后回复 20240902 获取。
这里没有进行rtp代理,sdp里面写的是话机的ip地址:

配套的抓包文件可从如下渠道获取:
关注微信公众号(聊聊博文,文末可扫码)后回复 20240902 获取。
四、添加rtp代理
上述步骤中,实现了sip信令代理,如果要代理rtp数据,可以使用rtpproxy或rtpengine实现,这里以rtpengine为例进行示例。
呼叫模型如下:

1、安装rtpengine
可通过apt安装:
apt install rtpengine
也可通过源码安装,具体参考:
默认配置文件:
/etc/rtpengine/rtpengine.conf
启动rtpengine:
systemctl start rtpengine
效果如下:

2、配置kamailio
文件:kamailio.cfg
加载模块,并配置参数:
loadmodule "rtpengine.so"
modparam("rtpengine", "rtpengine_sock", "udp:127.0.0.1:2223")
如果使用默认配置文件的规则(kamailio.cfg),需要先定义变量:
#!define WITH_NAT
#!define WITH_RTPENGINE
配置效果如下:

配置路由(在NATMANAGE中,默认配置):
if(nat_uac_test("8")) {
rtpengine_manage("SIP-source-address replace-origin replace-session-connection");
} else {
rtpengine_manage("replace-origin replace-session-connection");
}
也可使用自定义路由(在NATMANAGE中):
if (has_body("application/sdp")) {
rtpengine_manage("trust-address replace-origin replace-session-connection");
}
这里以默认配置为例进行演示,配置如下:

重启kamailio服务生效:
systemctl restart kamailio
配套配置文件可从如下渠道获取:
关注微信公众号(聊聊博文,文末可扫码)后回复 20240902 获取。
3、使用rtpengine进行代理
使用2002呼叫2001,并在kamailio上进行抓包。
呼叫效果如下:

使用rtpengine进行rtp代理后,sdp里面写的是kamailio的ip地址:

可使用wireshark播放rtp音频流:

配套抓包文件可从文末提供的渠道获取。
五、资源下载
本文涉及源码及相关文件,可从如下途径获取:
关注微信公众号(聊聊博文,文末可扫码)后回复 20240902 获取。

好,就这么多了,别忘了点赞哈!
使用kamailio进行分机注册及互拨的更多相关文章
- 基于OpenSIPS 实现分机注册服务服务器
呼叫中心平台中坐席是不可或缺的一环,而坐席打电话自然需要使用办公分机.通常情况下我们通过软交换平台FreeSWITCH.Asterisk即可搭建分机注册服务. 但单台FreeSWITCH或Asteri ...
- apply-register-acl 参数允许FreeSWITCH分机注册/拨打不验证密码
今天调试 发现 注册的分机 的 `Auth-User` 居然是 `unknown` !!! 怎么回事? 仔细对比检查 发现, internal profile 指定了 `apply-register- ...
- js两个数组去重后,绑定控件,并支持模糊搜索数组项以及数组互移
设计大概是这个样子的,很简单,两个div,两个互移按钮,一个搜索框,要求搜索框输入时,触发待选框的搜索项 <input class="form-control" placeh ...
- miniSipServer简单而不简单,轻松落地,实现电脑对固话、手机通讯
最近沉迷于SIP通讯,网内通讯全免费,落地也就几分钱,而且无漫游全国拨打,想想真是心动呢,只要有网落就ok!. 对于sipserver,现在的市场上软件很多,免费的.收费的应有尽有,这里不一一例举.综 ...
- FreeSWITCH 学习笔记
[1]FreeSWITCH学习笔记 1.Windows安装包下载地址:http://files.freeswitch.org/windows/installer/ 2.源码下载地址:http://fi ...
- 基站搭建与IMSI捕获
写在前面 : 实验目的是为了教学交流,坚决抵制违法行为. 一.实验目的 搭建基于OpenBTS的基站,手机接入该基站,进行短信.语音等测试. 二.所用仪器 USRP B210 1台,天线2根,PC机 ...
- freeswitch简介
freeswitch简介 freeswitch是开源的,免费的. freeswitch是一款非常好用的电话软交换框架,支持跨平台,扩展性良好,配置灵活. freeswitch可以在很多平台上运行,包括 ...
- 如何传递大文件(GB级别)
一.拆分:压缩工具,压缩并拆分为多个小文件. 二.QQ离线传输 QQ离线文件有限制条件: 1.离线传送的文件,为用户保存7天,逾期接收方不接收文件,系统将自动删除该文件: 2. 离线传送的文件,单个文 ...
- FreeSWITCH 处理Refer盲转时,UUI传递不对(没有将SIP 消息头Refer-To中的User-to-User传递给B-Leg)
运行环境: CentOS 7.6 FreeSWICH 1.6.18 一.问题场景: FreeSWITCH收到REFER命令后,重新发起的INVITE消息中的 "U ...
- GIF Movie Gear逆向实战+注册代码+补丁
GIF Movie Gear逆向实战+注册代码+补丁 准备 我是在windows 8.1 x64上进行的操作.有不足之处,还望大虾指出. 获取资源 网站下载:http://www.gamani.com ...
随机推荐
- Spark大数据集群日常开发过程遇到的异常及解决思路汇总
总结/朱季谦 一.出现java.lang.IllegalAccessError: tried to access method com.google.common.base.Stopwatch.()V ...
- .NET 9 预览版6发布
微软发布了 .NET 9 的第 6 个预览版,此版本包括对运行时.SDK..NET MAUI.ASP.NET Core 和 C# 的更新,预览版没有包含太多新的主要功能或特性,因为已接近 .NET 9 ...
- var 和 let 在 jQuery中的区别
下面通过代码案例来进一步解释 var 和 let 在 jQuery link 函数中的区别: (function ($) { $.fn.link = function () { // Example ...
- [oeasy]python0004_游乐场_和python一起玩耍_python解释器_数学运算
和python玩耍 Python 回忆 上次 了解shell环境中的命令 命令 作用 whoami 显示当前用户名 pwd 显示当前文件夹 ls 列出当前文件夹下的内容 python3 仿佛进入大于号 ...
- 【VUE】el-menu导航菜单过长、过多 超出窗口宽度 添加左右滚动按钮实现左右滚动效果
本文为原创文章,转载需注明出处~~ 效果图: 项目需求:如果一级菜单过多,需要出现滚动点击按钮. 准备工作:考虑到使用swiper插件,但swiper-slider必须是swiper-wrapper的 ...
- JWT浅了解
JWT通过数字签名的方式(让我想起了软考),以json对象为载体,在不同的服务终端之间安全传输信息 是一种授权认证 生成token的原理:通过header的加密方式,对payload进行加密.然后把h ...
- ipa文件上传到app store的构建版本的工具
打包好ipa文件后,可以使用mac电脑上的xcode将ipa上传到app store的构建版本中,假如没有mac电脑,可以使用香蕉云编来将ipa文件上传到构建版本. 这里我们来介绍下ipa文件上传到a ...
- GeoScene Enterprise 3.1 临时许可更新
Portal许可更新 portal 的许可更新很简单,直接打开Portal在线更新就好了 平台管理 -> 许可管理 -> 附加许可 -> 导入许可 -> 选择文件(选择授权的j ...
- 【RabbitMQ】06 Spring整合RabbitMQ
首先生产者和消费者需要的Maven依赖是一样的 <?xml version="1.0" encoding="UTF-8"?> <project ...
- python运行报错:ImportError: libcudnn_cnn_infer.so.8: cannot open shared object file
运行报错: 解决方法: conda install cudatoolkit==11.8.0 python3 -m pip install nvidia-cudnn-cu11==8.7.0.84 成功解 ...