随笔 - 272  文章 - 0  评论 - 283  阅读 - 142万

用SqlServer存储Asterisk的呼叫记录

将asterisk的呼叫记录存入mysql很简单,其实存入SqlServer也同样容易。

首先声明下环境:CentOS6.2 + Asterisk 1.8.7.1 + Freetds 0.91 + SqlServer 2008

1、安装rpmforge源和epel源

2、安装freetds:
yum install freetds*

3、配置并测试freetds
vi /etc/freetds.conf
示例如下:
ip:port模式:

[SQL2008]
host = 172.16.16.100
port = 1433
tds version = 8.0

测试如下:

tsql -S SQL2008 -U sa -P password

数据库实例模式:

[voipCdrSvr]
host = 172.16.16.101
instance = sqlexpress
tds version = 8.0

测试如下:

tsql -S voipCdrSvr -U sa -P password
4、配置Asterisk
清空cdr_odbc.conf
> /etc/asterisk/cdr_odbc.conf
编辑cdr_tds.conf
vi /etc/asterisk/cdr_tds.conf

[global]
connection=voipCdrSvr
port=1433
dbname=myDB
table=cdr
user=sa
password=myPasswd

5、创建Sqlserver数据表:

复制代码
CREATE TABLE cdr (
[accountcode] [varchar] (20) NULL ,
[src] [varchar] (80) NULL ,
[dst] [varchar] (80) NULL ,
[dcontext] [varchar] (80) NULL ,
[clid] [varchar] (80) NULL ,
[channel] [varchar] (80) NULL ,
[dstchannel] [varchar] (80) NULL ,
[lastapp] [varchar] (80) NULL ,
[lastdata] [varchar] (80) NULL ,
[start] [datetime] NULL ,
[answer] [datetime] NULL ,
[end] [datetime] NULL ,
[duration] [int] NULL ,
[billsec] [int] NULL ,
[disposition] [varchar] (20) NULL ,
[amaflags] [varchar] (16) NULL ,
[uniqueid] [varchar] (150) NULL ,
[userfield] [varchar] (256) NULL
)
复制代码

6、重启Asterisk生效:

asterisk -rx "core restart now"

好,就这些了,希望对你有帮助。

posted on   Mike_Zhang  阅读(1694)  评论(0编辑  收藏  举报
(评论功能已被禁用)
编辑推荐:
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
阅读排行:
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 上周热点回顾(2.24-3.2)
< 2012年4月 >
1 2 3 4 5 6 7
8 9 10 11 12 13 14
15 16 17 18 19 20 21
22 23 24 25 26 27 28
29 30 1 2 3 4 5
6 7 8 9 10 11 12

点击右上角即可分享
微信分享提示