freeswitch的话单模块

概述
最近因为业务需要,在看freeswitch中话单相关的一些模块。
在voip的使用过程中,话单是重要的基础模块,涉及到计费和问题查找。
呼叫话单最重要的一点是稳定,不能有错误或遗漏。
本章对fs的话单模块做整体梳理和简单介绍。
环境
centos:CentOS release 7.0 (Final)或以上版本
freeswitch:v1.8.7
GCC:4.8.5
话单模块
freeswitch中CDR相关模块较多,粗略列一下。
mod_cdr_csv
mod_cdr_mongodb
mod_cdr_pg_csv
mod_cdr_sqlite
mod_format_cdr
mod_json_cdr
mod_odbc_cdr
mod_radius_cdr
mod_xml_cdr
其中,mod_cdr_csv模块是默认编译和启动加载的cdr模块,其他模块需要用户自己根据需要编译和加载。
上面列出的模块,大部分可以根据名字猜测出模块的主要功能,比如,“mod_cdr_csv”模块表示把CDR话单写入CSV文件,“mod_cdr_mongodb”模块表示把CDR话单写入mongodb数据库。
每个模块都有自己单独的配置文件。
根据项目需求,这里主要关注CDR话单写入文件的模块,其他写数据库的模块暂时先略过。
mod_cdr_csv
freeswitch默认CDR模块,自动编译、安装、加载。
模块对应配置文件为“/usr/local/freeswitch/autoload_configs/cdr_csv.conf.xml”。
配置文件中可以设置多个CDR模板,并根据通道变量“accountcode”的值来对应模板名出话单。
CDR模板中可以使用fs会话的所有通道变量,并根据需求设置模板格式。
修改配置文件“/usr/local/freeswitch/autoload_configs/cdr_csv.conf.xml”。
<template name="example">{"data":{"ACCOUNTCODE":"${ACCOUNTCODE}","channel_va_test":"${channel_va_test}","${caller_id_name}","${caller_id_number}","${destination_number}","${context}","${start_stamp}","${answer_stamp}","${end_stamp}","${duration}","${billsec}","${hangup_cause}","${uuid}","${bleg_uuid}","${accountcode}","${read_codec}","${write_codec}"}}</template>
<template name="snom">"${caller_id_name}","${caller_id_number}","${destination_number}","${context}","${start_stamp}","${answer_stamp}","${end_stamp}","${duration}","${billsec}","${hangup_cause}","${uuid}","${bleg_uuid}", "${accountcode}","${read_codec}","${write_codec}","${sip_user_agent}","${call_clientcode}","${sip_rtp_rxstat}","${sip_rtp_txstat}","${sofia_record_file}"</template>
设置通道变量“ACCOUNTCODE”为“snom”,呼叫测试。
呼叫结束之后,可以在“/usr/local/freeswitch/log/cdr-csv/Master.csv”文件中找到话单如下。
{"data":{"ACCOUNTCODE":"snom","channel_va_test":"","Outbound Call","1001","1001","ext_test","2022-06-23 14:36:25","2022-06-23 14:36:27","2022-06-23 14:36:33","8","6","ALLOTTED_TIMEOUT","cdbb0266-f2be-11ec-b928-a1f80b63cfc8","","snom","PCMA","PCMA"}}
同时,在“/usr/local/freeswitch/log/cdr-csv/snom.csv”文件中找到话单如下。
"Outbound Call","1001","1001","ext_test","2022-06-23 14:36:25","2022-06-23 14:36:27","2022-06-23 14:36:33","8","6","ALLOTTED_TIMEOUT","cdbb0266-f2be-11ec-b928-a1f80b63cfc8","", "snom","PCMA","PCMA","FreeSWITCH-mod_sofia/1.6.19+git~20220408T073647Z~f81cb238da~64bit","","","",""
mod_json_cdr
mod_json_cdr模块默认不编译,不安装,不加载。
进入“freeswitch-1.6.19_master/src/mod/event_handlers/mod_json_cdr”目录,编译安装。
make install
cd /usr/local/freeswitch/mod
ll -tr
-rwxr-xr-x. 1 root root 122096 Jul 6 16:00 mod_json_cdr.so
-rwxr-xr-x. 1 root root 1289 Jul 6 16:00 mod_json_cdr.la
cd /usr/local/freeswitch/mod/autoload_configs
vi modules.conf.xml
<load module="mod_json_cdr"/>
模块对应配置文件“/usr/local/freeswitch/conf/autoload_configs/json_cdr.conf.xml”。
呼叫测试。
呼叫结束之后,可以在“/usr/local/freeswitch/log/json_cdr/49704084-fd13-11ec-8158-19509e341d8a.cdr.json”文件中找到话单如下。
{
"core-uuid":"3e74f030-fd13-11ec-8155-19509e341d8a",
"switchname":"localhost.localdomain",
"channel_data":{
"state":"CS_REPORTING",
"direction":"outbound",
"state_number":"11",
"flags":"0=1;1=1;2=1;20=1;37=1;38=1;40=1;43=1;53=1;60=1;95=1;112=1;113=1;122=1",
"caps":"1=1;2=1;3=1;4=1;5=1;6=1"
},
"callStats":Object{...},
"variables":Object{...},
"app_log":Object{...},
"callflow":Array[2]
}
mod_format_cdr
mod_format_cdr模块默认不编译,不安装,不加载。
进入“freeswitch-1.6.19_master/src/mod/event_handlers/mod_format_cdr”目录,编译安装。
make install
cd /usr/local/freeswitch/mod
ll -tr
-rwxr-xr-x. 1 root root 122096 Jul 6 16:00 mod_format_cdr.so
-rwxr-xr-x. 1 root root 1289 Jul 6 16:00 mod_format_cdr.la
cd /usr/local/freeswitch/mod/autoload_configs
vi modules.conf.xml
<load module="mod_format_cdr"/>
模块对应配置文件“/usr/local/freeswitch/autoload_configs/format_cdr.conf.xml”
呼叫测试。
呼叫结束之后,可以在“/usr/local/freeswitch/log/format_cdr”目录找到俩个话单文件。
cat a_49704084-fd13-11ec-8158-19509e341d8a.cdr.json
{
"core-uuid":"3e74f030-fd13-11ec-8155-19509e341d8a",
"switchname":"localhost.localdomain",
"channel_data":Object{...},
"callStats":Object{...},
"variables":Object{...},
"app_log":Object{...},
"callflow":Array[2]
}
cat a_49704084-fd13-11ec-8158-19509e341d8a.cdr.xml
<?xml version="1.0"?>
<cdr core-uuid="3e74f030-fd13-11ec-8155-19509e341d8a" switchname="localhost.localdomain">
<channel_data>
...
</channel_data>
<call-stats>
...
</call-stats>
<variables>
...
</variables>
<app_log>
...
</app_log>
<callflow dialplan="XML" unique-id="4b39417c-fd13-11ec-815a-19509e341d8a" clone-of="4970484a-fd13-11ec-8159-19509e341d8a" profile_index="2">
...
</callflow>
</cdr>
总结
mod_cdr_csv模块是fs的基础话单模块。
mod_format_cdr模块的功能包含了mod_json_cdr和mod_xml_cdr俩个模块的功能,是后二者的超集,具有替换作用。
空空如常
求真得真
freeswitch的话单模块的更多相关文章
- FreeSWITCH 加载模块过程解读
今天来学习FreeSWITCH 加载模块过程. 哪些模块需要编译,是由源码下的 modules.conf 文件决定的. 哪些模块在程序启动时自动加载,是由 freeswitch/conf/autolo ...
- freeswitch插件式模块接口实现方式
概述 freeswitch的外围模块是插件式的,可以动态的加载和卸载,使用起来非常的灵活和方便. 如果我们自己来设计一个开源的代码框架,相信这种插件式的模块结构是非常适合多人合作的模式. 本文对fs的 ...
- freeswitch的mod_curl模块
概述 有时候,我们需要在呼叫的过程中,或过程后调用web api接口. freeswitch的mod_curl模块可以很方便的实现web api的接口调用. mod_curl模块默认不安装,需要进入模 ...
- freeswitch使用mod_shout模块播放mp3
概述 freeswitch 在对VOIP语音通话中,可以通过playback命令播放IVR语音文件. 默认情况下,freeswitch支持wav文件,也可以直接播放VOIP中常见编解码的G711文件. ...
- layui---form表单模块
虽然对layui比较熟悉了,但是今天有时间还是将layui的form表单模块重新看一下. https://www.layui.com/doc/modules/form.html 一.更新渲染 layu ...
- freeswitch编译mod_av模块
需要先编译libav库 编译libav下载:git clone https://freeswitch.org/stash/scm/sd/libav.git cd libav ./configure - ...
- getFieldDecorator用法(二)——封装表单模块
后台管理系统经常用到表单查询,因此做了个封装 myorder.js import React from 'react'; import { Card, Button, Table, Form, Sel ...
- coding++ :Layui-form 表单模块
虽然对layui比较熟悉了,但是今天有时间还是将layui的form表单模块重新看一下. https://www.layui.com/doc/modules/form.html 1):更新渲染 lay ...
- 表单模块 layui-form
使用 layui针对各种表单元素做了比较全面的Ui支持,在Ui渲染只要求一点.,在表单体所在父元素加上class="layui-form" 监听事件 提交按钮监听,注意需要加·la ...
随机推荐
- IP地址的格式和分类,你都清楚吗?
一个执着于技术的公众号 在网际层中,利用 IP 地址将数据传输到目的地.为了能够使数据正确地发送到目标主机上,网络上的 IP 地址必须有一定的规则来识别主机的位置. IP地址的基本构成 为了便于寻址, ...
- CentOS 8 重启不能DHCP获取IP的解决方法
一个执着于技术的公众号 今天遇到一个神奇的现象,我对CentOS 8系统做初始化之后再重启系统,发现系统不能通过NetworkManager获取DHCP IP了 查了系统日志发现是: Apr 30 0 ...
- Docker容器网络-基础篇
开源Linux 一个执着于技术的公众号 Docker的技术依赖于Linux内核的虚拟化技术的发展,Docker使用到的网络技术有Network Namespace.Veth设备对.Iptables/N ...
- 一个程序的自我修养「GitHub 热点速览 v.22.19」
一个程序要诞生涉及前后端技术,比如,你可以用可视化网页搭建工具 tmagic-editor 完成前端部分,而后端部分的数据库以及数据处理可能就要用到 jsonhero-web 和 directus.知 ...
- Mac 手动安装 bee工具
前因: 1.go升级到1.16以后,bee官网给的安装方法(go get XXX)不好使,需要指定version. 2.指定 go get XXX@v2.0.0 可以下载,但是bee工具还是用不了:c ...
- 111_Power Pivot 24小时维度:累计、同比、环比相关
博客:www.jiaopengzi.com 焦棚子的文章目录 请点击下载附件 一.背景 今天有朋友讨论怎么做每天24小时维度的工作量计算(运营类企业,每天24小时都在运营)需求如下: 1.从0时到23 ...
- Redis系列:深刻理解高性能Redis的本质
1 背景 分布式系统绕不开的核心之一的就是数据缓存,有了缓存的支撑,系统的整体吞吐量会有很大的提升.通过使用缓存,我们把频繁查询的数据由磁盘调度到缓存中,保证数据的高效率读写. 当然,除了在内存内运行 ...
- 【SSM框架】Spring笔记 --- 事务详解
1.Spring的事务管理: 事务原本是数据库中的概念,在实际项目的开发中,进行事务的处理一般是在业务逻辑层, 即 Service 层.这样做是为了能够使用事务的特性来管理关联操作的业务. 在 Spr ...
- nazo.io 通关记录
游戏网址 说在前面 答案错误页面 nazo.io/wrong 攻略 第0关 谜.io 纯粹是欢迎你来游戏. 所以他给你的start就是答案. 第1关 欢迎 它用灰体字写了key: welcome 直接 ...
- 33个非常实用的JavaScript一行代码
33个非常实用的JavaScript一行代码 一.日期处理 1. 检察日期是否有效 该方法用于检测给出的日期是否有效: const isDateValid = (...val) => !Numb ...