Centos7 下安装freeswitch 1.9 +x264+odbc mysql

Centos7 下安装freeswitch 1.9 +x264+odbc mysql
前期准备
安装lua5.2及以上版本
安装mod_av支持的lib
安装odbc
安装php--为freeswitch后期扩展开发预备
编译freeswitch 1.9
configure中间出现的错误:
make中间出现的错误:
在fs上开启rport功能
设置rtp自动调整功能
防火墙和NAT设置
加载mod_av
连接MySQL数据库
支持视频通话
前期准备
yum install net-tools
关闭防火墙

//临时关闭
systemctl stop firewalld
//禁止开机启动
systemctl disable firewalld
setenforce 0
1
2
3
4
5
借用1.6版本的部分依赖库,懒得区分什么是刚需,copy一下直接贴过来了

yum install -y http://files.freeswitch.org/freeswitch-release-1-6.noarch.rpm epel-release

yum install -y git gcc-c++ autoconf automake libtool wget python ncurses-devel zlib-devel libjpeg-devel openssl-devel e2fsprogs-devel sqlite-devel libcurl-devel pcre-devel speex-devel ldns-devel libedit-devel libxml2-devel libyuv-devel opus-devel libvpx-devel libvpx2* libdb4* libidn-devel unbound-devel libuuid-devel lua-devel libsndfile-devel yasm-devel
1
2
3
安装lua5.2及以上版本
1.CentOS7默认已经安装了5.1.4 然并卵,freeswitch1.4以后就需要5.2以上lua来支持了,不然后期调试mysql lua会带来恶心的感觉。

①查看当前lua版本号:

lua -v

Lua 5.1.4 Copyright (C) 1994-2008 Lua.org, PUC-Rio
1
2
3
②查看lua和luac的位置:

which lua luac

/usr/bin/lua
/usr/bin/luac
1
2
3
4
2.编译Lua5.3版本

①下载lua-5.3.5.tar.gz

②make linux

出现错误:lua.c:80:31: fatal error: readline/readline.h: No such file or directory

表示需要安装依赖库:yum install readline-devel

③make install

cd src && mkdir -p /usr/local/bin /usr/local/include /usr/local/lib /usr/local/man/man1 /usr/local/share/lua/5.3 /usr/local/lib/lua/5.3
cd src && install -p -m 0755 lua luac /usr/local/bin
cd src && install -p -m 0644 lua.h luaconf.h lualib.h lauxlib.h lua.hpp /usr/local/include
cd src && install -p -m 0644 liblua.a /usr/local/lib
cd doc && install -p -m 0644 lua.1 luac.1 /usr/local/man/man1
1
2
3
4
5
可以看到,lua和luac被安装到了/usr/local/bin中

④lua -v查看版本,发现还是旧的版本,那我们就将/usr/bin中的lua和luac删除,然后将/usr/local/bin中的lua和luac创建一个ln到/usr/bin中即可

cd /usr/bin

rm -rf lua luac

ln -s /usr/local/bin/lua /usr/bin/lua

ln -s /usr/local/bin/luac /usr/bin/luac

lua -v

Lua 5.3.3 Copyright (C) 1994-2016 Lua.org, PUC-Rio
1
2
3
4
5
6
7
8
9
10
11
安装mod_av支持的lib
要支持h264视频通话,所以需要单独安装
mod_av 依赖libav, libav需要 x264 lib才能支持h264。

先下载源码
https://libav.org/
https://download.videolan.org/pub/videolan/x264/snapshots/

cd /usr/loca/src
git clone https://git.videolan.org/git/x264.git
wget https://libav.org/releases/libav-12.3.tar.gz
tar -zxvf libav-12.3.tar.gz
1
2
3
4
因为编译x264会提示
Found no assembler
Minimum version is nasm-2.13
所以需要手动安装 nasm 因为centos7自带的版本不够,
下载一个顺眼的版本 来三部曲安装吧
https://www.nasm.us/pub/nasm/releasebuilds/

wget https://www.nasm.us/pub/nasm/releasebuilds/2.14/nasm-2.14.tar.gz
tar -zxvf nasm-2.14.tar.gz
cd nasm-2.14
./configure
make
make install
cd ../x264
./configure --enable-shared --enable-static --disable-opencl
make
make install
cp /usr/local/lib/pkgconfig/x2* /usr/lib64/pkgconfig #否则libav在configure时会提示ERROR:x264 not found
1
2
3
4
5
6
7
8
9
10
11
libav编译时出错:
libavcodec/libx264.c: In function ‘X264_frame’:
libavcodec/libx264.c:246:9: error: ‘x264_bit_depth’ undeclared (first use in this function)
if (x264_bit_depth > 8)
^
libavcodec/libx264.c:246:9: note: each undeclared identifier is reported only once for each function it appears in
libavcodec/libx264.c: In function ‘X264_init_static’:
libavcodec/libx264.c:707:9: error: ‘x264_bit_depth’ undeclared (first use in this function)
if (x264_bit_depth == 8)
看了一圈没几个正经解决方案,参考x264对ffmpeg的补丁解决 http://git.videolan.org/?p=ffmpeg.git;a=patch;h=2a111c99a60fdf4fe5eea2b073901630190c6c93

static av_cold void X264_init_static(AVCodec *codec)
{

  • if (x264_bit_depth == 8)
  • if (X264_BIT_DEPTH == 8)
    codec->pix_fmts = pix_fmts_8bit;
  • else if (x264_bit_depth == 9)
  • else if (X264_BIT_DEPTH == 9)
    codec->pix_fmts = pix_fmts_9bit;
  • else if (x264_bit_depth == 10)
  • else if (X264_BIT_DEPTH == 10)
    codec->pix_fmts = pix_fmts_10bit;
    }
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    cd ../libav-12.3
    ./configure --enable-shared --enable-libx264 --enable-gpl
    make
    make install
    cp /usr/local/lib/pkgconfig/.pc /usr/lib64/pkgconfig/
    cp -f /usr/local/lib/
    /usr/lib64/

1
2
3
4
5
6
7
增加mod_nuimrcp模块

编辑 vim ./build/modules.conf.in
修改 #applications/mod_av为applications/mod_av
修改 #asr_tts/mod_unimrcp 为 asr_tts/mod_unimrcp

安装odbc
因为后面会涉及到odbc的安装,所以先安装odbc

yum install -y unixODBC unixODBC-devel mysql-connector-odbc
1
安装完成后编辑/etc/odbcinst.ini

Example driver definitions

Driver from the postgresql-odbc package

Setup from the unixODBC package

[PostgreSQL]
Description = ODBC for PostgreSQL
Driver = /usr/lib/psqlodbcw.so
Setup = /usr/lib/libodbcpsqlS.so
Driver64 = /usr/lib64/psqlodbcw.so
Setup64 = /usr/lib64/libodbcpsqlS.so
FileUsage = 1

Driver from the mysql-connector-odbc package

Setup from the unixODBC package

[MySQL]
Description = ODBC for MySQL
Driver = /usr/lib64/libmyodbc5.so
Setup = /usr/lib64/libodbcmyS.so
Driver64 = /usr/lib64/libmyodbc5.so
Setup64 = /usr/lib64/libodbcmyS.so
FileUsage = 1
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
编辑/etc/odbc.ini

[freeswitch]
Description=MySQL realtime database
Driver=/usr/lib64/libmyodbc5.so
SERVER =数据库地址
PORT =3306
DATABASE = freeswitch
OPTION =67108864
CHARSET = UTF8
USER = 数据库账号
PASSWORD = 数据库密码
Threading = 0
1
2
3
4
5
6
7
8
9
10
11
输入:isql -v freeswitch测试是否能够连通

安装php–为freeswitch后期扩展开发预备
rpm -Uvh https://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm

rpm -Uvh https://mirror.webtatic.com/yum/el7/webtatic-release.rpm

//查看
yum search php72w
//安装php以及扩展
yum install php72w php72w-fpm php72w-cli php72w-common php72w-devel php72w-gd php72w-pdo php72w-mysql php72w-mbstring php72w-bcmath
1
2
3
4
5
6
7
8
编译freeswitch 1.9
configure中间出现的错误:
configure: error: “Cannot build without libtiff (does your system require a libtiff-devel package?)”

yum install -y libtiff-devel
1
make中间出现的错误:
making all mod_signalwire
make[4]: Entering directory /usr/local/src/freeswitch/src/mod/applications/mod_signalwire' Makefile:916: *** You must install libks to build mod_signalwire. Stop. make[4]: Leaving directory/usr/local/src/freeswitch/src/mod/applications/mod_signalwire'
make[3]: *** [mod_signalwire-all] Error 1
1
2
3
4
5
本来想粗暴注释掉mod_signalwire解决,但逃避不是办法,解决一下吧
需要安装 libks 和 signalwire-c
https://github.com/signalwire/libks
https://github.com/signalwire/signalwire-c

libks需要cmake (Minimum version 3.6.2),比较坑,所以手动安装cmake
https://cmake.org/files/ 这里是编译安装,也可以自己下载编译好的直接用
https://cmake.org/files/v3.13/cmake-3.13.3-Linux-x86_64.tar.gz 建议直接下载编译好的,编译时间很恶心

yum install libatomic.x86_64 #libks还会提示少libatomic

cd /usr/local/src
wget https://cmake.org/files/v3.13/cmake-3.13.3.tar.gz
tar -zxvf cmake-3.13.3.tar.gz
cd cmake-3.13.3
./bootstrap
gmake
make install

cd /usr/local/src
git clone https://github.com/signalwire/libks.git
cd libks
cmake .
make
make install
cp /usr/lib/pkgconfig/libks.pc /usr/lib64/pkgconfig/ #这个比较坑爹,不然还是还找不到libks模块
cd /usr/local/src
git clone https://github.com/signalwire/signalwire-c.git
cd signalwire-c
cmake .
make
make install
cp /usr/local/lib/pkgconfig/.pc /usr/lib64/pkgconfig/
cp -f /usr/local/lib/
/usr/lib64/
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
cd /usr/local/freeswitch
./bootstrap.sh -j
./configure --enable-core-odbc-support #如果读者不想使用mysql管理,只需要执行./configure即可
make
make install

ln -sf /usr/local/freeswitch/bin/freeswitch /usr/local/bin/
ln -sf /usr/local/freeswitch/bin/fs_cli /usr/local/bin/

//安装声音文件
make cd-sounds-install
make cd-moh-install
1
2
3
4
5
6
7
8
9
10
11
12
在fs上开启rport功能
<paramname="NDLB-force-rport" value="true"/>
1
设置rtp自动调整功能
<paramname="disable-rtp-auto-adjust" value="false"/>
1
防火墙和NAT设置
云端映射/nat设置
需要打开的端口:

udp 16384:32768
udp 4569
udp 5060
tcp 5060
udp 5080
tcp 5080
tcp 8000
udp 8000
1
2
3
4
5
6
7
8
配置conf/autoload_configs/verto.conf.xml

<param name="ext-rtp-ip" data="外网ip">
1
配置conf/sip_profiles/internal.xml

<param name="aggressive-nat-detection" value="true"/>
<param name="multiple-registrations" value="true"/>
<param name="ext-rtp-ip" value="外网ip"/>
<param name="ext-sip-ip" value="外网ip"/>
<param name="NDLB-received-in-nat-reg-contact" value="true"/>
<param name="NDLB-force-rport" value="true"/>
<param name="NDLB-broken-auth-hash" value="true"/>
<param name="enable-timer" value="false"/>
<param name="auth-calls" value="true"/>
1
2
3
4
5
6
7
8
9
配置conf/sip_profiles/external.xml

<param name="aggressive-nat-detection" value="true"/>
<param name="ext-rtp-ip" value="外网ip"/>
<param name="ext-sip-ip" value="外网ip"/>
<param name="NDLB-force-rport" value="true"/>
1
2
3
4
配置conf/autoload_configs/switch.conf.xml

<param name="rtp-start-port" value="16384"/>
<param name="rtp-end-port" value="32768"/>
1
2
加载mod_av
启动freeswitch,在控制命令中输入:

load mod_av

或者修改/usr/local/freeswitch/conf/autoload_configs下的modules.conf.xml

取消掉mod_av的注释即可(该方法是修改启动时加载项,修改后重启FreeSwitch即可)

进入/usr/local/freeswitch/bin目录下

./freeswitch -nonat

连接MySQL数据库
FreeSwitch默认是使用的SQLite数据库,这里我们将使用MySQL数据库来管理FreeSwitch中的账户,并实现账户之间能够互相拨打电话。

首先进入到/usr/local/freeswitch/conf/autoload_configs目录下,编辑lua.conf.xml文件

在<setting> 标签下添加如下的代码:

<param name="xml-handler-script" value="gen_dir_user_xml.lua"/>
<param name="xml-handler-bindings" value="directory"/>

1
2
然后在/usr/local/freeswitch/scripts/下创建gen_dir_user_xml.lua文件

freeswitch.consoleLog("notice", "Debug from gen_dir_user_xml.lua, provided params:\n" .. params:serialize() .. "\n")

local req_domain = params:getHeader("domain")
local req_key = params:getHeader("key")
local req_user = params:getHeader("user")
local dbh = freeswitch.Dbh("freeswitch","sip","password")

if dbh:connected() == false then
freeswitch.consoleLog("notice", "gen_dir_user_xml.lua cannot connect to database" .. dsn .. "\n")
return
end
XML_STRING =
[[<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<document type=" freeswitch/xml">
<section name="directory">
<domain name="]] .. req_domain .. [[">
<user id="]] .. req_user .. [[">
<params>
<param name="password" value=" FreeSwitch+ysyhL9T"/>
<param name="dial-string" value="{sip_invite_domain={dialed_domain}, presence_id={dialed_user}@{dialed_domain}}{sofia_contact({dialed_user}@{dialed_domain})}"/>
</params>
<variables>
<variable name="user_context" value="default"/>
</variables>
</user>
</domain>
</section>
</document>]]
local my_query = string.format("select pass_word,user_context from users where sip_id='%s' limit 1", req_user)
assert (dbh:query(my_query, function(u) -- there will be only 0 or 1 iteration (limit 1)
freeswitch.consoleLog("NOTICE",u.pass_word.."\n")
XML_STRING =
[[<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<document type=" freeswitch/xml">
<section name="directory">
<domain name="]] .. req_domain .. [[">
<user id="]] .. req_user .. [[">
<params>
<param name="password" value="]] .. u.pass_word .. [["/>
<param name="dial-string" value="{sip_invite_domain={dialed_domain}, presence_id={dialed_user}@{dialed_domain}}{sofia_contact({dialed_user}@{dialed_domain})}"/>
</params>
<variables>
<variable name="user_context" value="]] .. u.user_context .. [["/>
</variables>
</user>
</domain>
</section>
</document>]]
end))
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
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
编辑/usr/local/freeswitch/conf/directory/default.xml
删除如下代码

<group name="default">
    <users>
      <X-PRE-PROCESS cmd="include" data="default/*.xml"/>
    </users>    
 </group>

1
2
3
4
5
6
MySQL数据库中,创建freeswitch数据库,添加如下的表,并插入元素:

CREATE DATABASE IF NOT EXISTS freeswitch default charset utf8 COLLATE utf8_general_ci;

drop table if exists users;

CREATE TABLE IF NOT EXISTS users (
user_id int(11) NOT NULL AUTO_INCREMENT,
domain varchar(90) NOT NULL COMMENT '域',
sip_id varchar(90) NOT NULL COMMENT '音视频聊天ID',
mail_box varchar(90) NOT NULL COMMENT '邮箱',
number_alias varchar(90) NOT NULL COMMENT '',
pass_word varchar(255) NOT NULL COMMENT '密码',
dial_string varchar(90) NOT NULL COMMENT '',
user_context varchar(90) NOT NULL COMMENT '',
author_id int(11) NOT NULL COMMENT '作者',
create_time int(11) NOT NULL COMMENT '创建时间',
del_time int(11) NOT NULL COMMENT '删除时间',
handler_id int(11) NOT NULL COMMENT '处理人',
PRIMARY KEY (user_id),
KEY sip_id (sip_id),
KEY author_id (author_id),
KEY create_time (create_time),
KEY del_time (del_time),
KEY handler_id (handler_id)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC COMMENT='用户';

INSERT INTO users VALUES
(1, '', '8001', '', '', '2345', '', 'default', 0, unix_timestamp(now()), 0, 0),
(2, '', '8002', '', '', '2345', '', 'default', 0, unix_timestamp(now()), 0, 0),
(3, '', '8003', '', '', '2345', '', 'default', 0, unix_timestamp(now()), 0, 0),
(4, '', '8004', '', '', '2345', '', 'default', 0, unix_timestamp(now()), 0, 0);
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
修改拨号计划

编辑/usr/local/freeswitch/conf/dialplan/default.xml

<extension name="Local_Extension2">
    <condition field="destination_number" expression="^([0-9][0-9][0-9][0-9])$">
        <action application="export" data="dialed_extension=$1"/>
        <action application="set" data="call_timeout=10"/>
        <action application="set" data="hangup_after_bridge=true"/>
        <action application="set" data="continue_on_fail=false"/>
        <action application="bridge" data="user/${dialed_extension}@${domain_name}"/>
    </condition>
</extension>

1
2
3
4
5
6
7
8
9
PS:该行代码需要放在’<context name=“default”>’ 后面

在FreeSwitch控制台按F6或者输入reloadxml,此时可以使用X-Lite或者Zoiper进行测试:

账号1输入8003,密码12345,Domain输入虚拟机的IP地址

账号2输入8004,密码12345,Domain输入虚拟机的IP地址

测试互打是否能够通话。

支持视频通话
编辑/usr/local/freeswitch/conf/vars.xml

<X-PRE-PROCESS cmd="set" data="global_codec_prefs=OPUS,G722,PCMU,PCMA,VP8,H263,H264"/>
<X-PRE-PROCESS cmd="set" data="outbound_codec_prefs=OPUS,G722,PCMU,PCMA,VP8,H263,H264"/>

1
2
编辑/usr/local/freeswitch/conf/sip_profiles/internal.xml文件 如下:

<param name="inbound-proxy-media" value="true"/>     

1
2
fsctl shutdown 控制台退出并关闭
在FreeSwitch控制台按F6或者输入reloadxml即可支持视频通话功能。

测试时使用linphone,X-Lite或者Zoiper,通话时选择视频通话,即可。

参考文章:
https://blog.csdn.net/jiajiren11/article/details/79269031
https://blog.csdn.net/jiayangang/article/details/79367757
https://blog.csdn.net/u011745859/article/details/82150814
https://blog.csdn.net/u011745859/article/details/81941674

https://www.bbsmax.com/A/MAzAL8Med9/
https://blog.csdn.net/yeqiufeng/article/details/81838461

https://blog.csdn.net/Dreamcode/article/details/8458974

https://www.cnblogs.com/chevin/p/6229739.html

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,294评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,780评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,001评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,593评论 1 289
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,687评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,679评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,667评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,426评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,872评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,180评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,346评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,019评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,658评论 3 323
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,268评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,495评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,275评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,207评论 2 352

推荐阅读更多精彩内容