操作系统 :CentOS 7.6_x64
FreeSWITCH版本 :1.10.9
Docker版本:23.0.6
 
使用docker打包FreeSWITCH可以极大简化部署环节,但针对高可用场景的故障恢复来说,仅实现docker打包是不够的,打包的docker镜像需要支持”根据提供的参数动态启动FreeSWITCH实例“,至少完成如下动作:
  • 根据提供的IP、端口等信息启动服务
  • 访问指定的数据库,获取信息并进行通话恢复
今天记录下CentOS 7环境下使用docker构建可动态启动FreeSWITCH实例的过程。本文涉及源码和文件,可以从如下途径获取:
关注微信公众号(聊聊博文,文末可扫码)后回复 20230716 获取。 
如何使用docker构建FreeSWITCH编译环境及打包,可以参考我之前的文章:

一、整体结构

这里提供一个FreeSWICH高可用实例的结构图,其中数据库使用的是MySQL数据库,整体结构如下:

说明:
1)打包的docker镜像具备通用性,可根据不同的参数启动不同的FreeSWITCH实例,其中启动参数存储在环境参数里面;
2)主机、备机通过VIP对外提供服务,VIP在同一时刻只在一台机器上,可通过keepalived等工具实现VIP漂移(也可自己写脚本实现,具体实现这里就不展开了);
3)主机、备机连接同一个MySQL库,共享数据库信息(配置数据、运行数据);
4)主机、备机具备同样的环境参数(fs-env文件);
5)主机、备机具备同样的配置文件(conf、scripts等);

二、具体实现

1、FreeSWICH支持MySQL

MySQL版本:5.7.38
1)安装odbc驱动
apt install unixodbc unixodbc-dev
 
找不到debian11的驱动,下载debian10的驱动实测也可以使用。

安装命令如下:

cd mysql-connector-odbc-5.3.14-linux-debian10-x86-64bit/lib
cp libmyodbc5* /usr/local/lib/
./myodbc-installer -d -a -n "MYSQL" -t "DRIVER=/usr/local/lib/libmyodbc5w.so;SETUP=/usr/lib/libmyodbc5w.so"
/ect/odbcinst.ini 内容如下:
[MYSQL]
Driver=/usr/local/lib/libmyodbc5w.so
SETUP=/usr/local/lib/libmyodbc5w.so
UsageCount=1
/ect/odbc.ini文件内容如下:
[fsdb]
Driver=MYSQL
Description=database for mysql
SERVER=192.168.137.1
CHARSET=UTF8
PORT=3306
USER=root
PASSWORD=123456
Database=fsdb
OPTION=67108864
2)配置odbc及测试连接
isql -v fsdb

3)编译、安装及配置odbc-dsn

 需要开启odbc支持:
./configure --enable-core-odbc-support
需要修改odbc-dsn信息:
对应变量:
odbc-dsn
core-db-dsn --- 仅switch.conf.xml
示例:
<param name="odbc-dsn” value=”fsdb:root:123456”/>
<param name="core-db-dsn” value=”fsdb:root:123456”/>
对应文件:
/usr/local/freeswitch/conf/autoload_configs/switch.conf.xml
/usr/local/freeswitch/conf/autoload_configs/db.conf.xml
/usr/local/freeswitch/conf/autoload_configs/callcenter.conf.xml
/usr/local/freeswitch/conf/autoload_configs/voicemail.conf.xml
/usr/local/freeswitch/conf/sip_profiles/internal.xml
/usr/local/freeswitch/conf/sip_profiles/external.xml
/usr/local/freeswitch/conf/autoload_configs/fifo.conf.xml
 
/usr/local/freeswitch/conf/vars.xml的配置: 
<X-PRE-PROCESS cmd="set" data="json_db_handle=odbc://fsdb:root:123456"/>

2、docker容器支持绑定非本机ip地址

vip同一时刻只能在一台机器上,docker容器所使用的vip可能没有漂过来,需要开启非本机绑定。
临时生效:
sysctl -w net.ipv4.ip_nonlocal_bind=1
永久生效:
echo net.ipv4.ip_nonlocal_bind=1 >> /etc/sysctl.conf
 
说明:
1)vip切换
可以使用keepalived等工具,具体细节这里不展开了。
2)arp广播
如果使用keepalived等工具,该部分忽略。
切换vip后,需要发送arp广播,以便vip实时生效
arping -U 192.168.137.201 -I eth0 -w 2

3、配置文件动态获取运行参数

整体流程如下:
生成env文件及odbc文件 =》 docker设置env信息 -》 fs读取env配置

3.1 xml关键变量需要通过环境变量设置

可通过freeswitch提供的env-set命令获取linux系统环境变量,示例如下:

<X-PRE-PROCESS cmd="env-set" data="force_local_ip_v4=$docker_fs_local_ip_v4"/>

其中,docker_fs_local_ip_v4是Linux系统环境变量。

具体使用方法可参考freeswitch官方wiki:

var.xml是最先加载,可以在该文件设置全局参数,示例如下:

3.2 设置启动映射conf目录

可通过docker启动参数设置:
-v /app/conf:/usr/local/freeswitch/conf
其中, /app/conf 为宿主机的目录,/usr/local/freeswitch/conf 为docker容器的目录。

3.3 动态生成odbc配置信息

odbc.ini文件里面有mysql的ip地址等信息,该部分需要动态生成:
1)动态生成odbc.ini文件;
2)将odbc.ini文件放在freeswitch的conf目录;
3)将/etc/odbc.ini链接到 /usr/local/freeswitch/conf/odbc.ini
 
xml文件的odbc配置示例如下:

3.4、lua脚本动态获取全局变量

示例如下:
my_globalvar = freeswitch.getGlobalVariable("varname")
运行效果如下:

可参考wiki:

4、Dockerfile及启动脚本

1)需要在Dockefile中安装依赖文件并进行打包;

2)启动时需要指定docker的环境信息;

具体实现可以从如下途径获取:
关注微信公众号(聊聊博文,文末可扫码)后回复 20230716 获取。 

三、运行效果

需要设置env文件,示例如下:
docker_fs_local_ip_v4=192.168.137.201
docker_fs_external_ip_v4=192.168.137.201
docker_fs_internal_sip_port=15060
docker_fs_external_sip_port=15080
docker_fs_rtp_start_port=20000
docker_fs_rtp_end_port=30000
docker_fs_odbc_dsn=fsdb
docker_fs_odbc_dsn_full=fsdb:root:123456
docker_fs_odbc_ip=192.168.137.1
docker_fs_odbc_port=3306
docker_fs_switch_name=fstest1
需要映射目录,app目录结构如下:

启动效果如下:

运行效果视频可以从如下途径获取:

关注微信公众号(聊聊博文,文末可扫码)后回复 2023071601 获取。 

四、资源下载

 文涉及源码和文件,可以从如下途径获取:
关注微信公众号(聊聊博文,文末可扫码)后回复 20230716 获取。 

 

使用docker构建可动态启动的FreeSWITCH实例的更多相关文章

  1. docker挡板程序实现启动多个实例进程

    启动服务: docker-compose restart

  2. freeswitch的docker构建过程

    概述 Docker是一个开源的应用容器引擎,可以让开发者打包应用以及依赖包到一个轻量级.可移植的容器中,并在任何安装有Docker的机器上运行. Docker 使你能够将应用程序与基础架构分开,从而可 ...

  3. 使用Spring Cloud和Docker构建微服务架构

    原文:https://dzone.com/articles/microservice-architecture-with-spring-cloud-and-do 作者:Alexander Lukyan ...

  4. 使用 Spring Cloud 和 Docker 构建微服务架构

    如何使用Spring Boot.Spring Cloud.Docker和Netflix的一些开源工具来构建一个微服务架构. 本文通过使用Spring Boot.Spring Cloud和Docker构 ...

  5. 视频私有云实战:基于Docker构建点播私有云平台

    私有云是为一个客户单独使用而构建的,因而提供对数据.安全性和服务质量的最有效控制.前置条件是客户拥有基础设施,并可以使用基础设施在其上部署应用程序.其核心属性是专有的资源.本篇文章将会结合网易云信的实 ...

  6. angular 构建可以动态挂载的配置服务

    angular 构建可以动态挂载的配置服务 Intro 在 angular 中可以指定 environment 来区分不同环境下的配置,然而 environment 中的配置会在打包时是固定的,想要像 ...

  7. Spring Boot打包瘦身 Docker 使用全过程 动态配置、日志记录配置

    springBoot打包的时候代码和jar包打包在同一个jar包里面,会导致jar包非常庞大,在不能连接内网的时候调试代码,每次只改动了java代码就需要把所有的jar包一起上传,导致传输文件浪费了很 ...

  8. Docker构建Python Web环境

    出于寻找Docker对Python相关项目部署的学习,找到腾讯课堂NEXT公开课中[Docker构建Python Web环境]的课程,本文对其进行内容梳理及知识点汇总. 该课程总计6小时左右,是个适合 ...

  9. 基于 Docker 构建轻量级 CI 系统:Gitea 与 Woodpecker CI 集成

    WoodpeckerCI 是一个由社区维护的 DroneCI 分支,使用 Apache License 2.0 许可证发布.社区版进一步扩展了 pipeline 的功能特性.支持对文件路径设置 pip ...

  10. 使用Docker构建持续集成与自动部署的Docker集群

    为什么使用Docker " 从我个人使用的角度讲的话  部署来的更方便 只要构建过一次环境 推送到镜像仓库 迁移起来也是分分钟的事情 虚拟化让集群的管理和控制部署都更方便 hub.docke ...

随机推荐

  1. Django框架简单搭建增删改查页面 Django请求生命周期流程图

    目录 Django框架简单搭建增删改查页面 一.前期的配置文件以及连接MySQL的基本准备 二.在数据库中准备好数据 三.将MySQL的数据展示到页面(简单认识HTML模板语法 for循环) 在Dja ...

  2. [C++核心编程] 2、引用

    文章目录 2 引用 2.1 引用的基本使用 2.2 引用注意事项 2.3 引用做函数参数 2.4 引用做函数返回值 2.5 引用的本质 2.6 常量引用 2 引用 2.1 引用的基本使用 **作用: ...

  3. Gusfield算法学习

    算法详解 等价流树正如其名,树上两点间的路径上的边权最小值为图上两点间的最小割. Gusfield算法就是建等价流树的一种算法.设当前正在处理的集合为 \(S(|S|\ge 2)\),从 \(S\) ...

  4. git与github(结合clion操作)

    对自己学习git的一个记录,由于刚开始接触git,所以没有对于git做深入解释和说明,仅供参考,如有理解不对的地方或者需要改进的地方敬请指出.   用到的git命令: git init //初始化 g ...

  5. java优先队列PriorityQueue

    文章目录 前言 PriorityQueue 优先队列 java中优先队列的声明 按优先级排序 常见方法 private void grow(int minCapacity) public boolea ...

  6. P8936 月下缭乱 Sol

    考虑对操作的区间 \([l_i,r_i]\) 的下标进行扫描线而不是对操作的值扫.用 \(m\) 个 set 动态维护 \(x_i\) 对应的操作的下标集合,再用一个可删堆来维护当前所有操作 \(x_ ...

  7. Linux运维实战项⽬进阶

    项⽬描述 项⽬需求 近年来为适应业务发展的需求,世界500强XX企业准备进⾏⼤规模的电⼦商务建设, 同时,希望能通过Linux平台,利⽤开源技术,来实现⼤型互联⽹电⼦商务⽹站架构建设和业务⽀撑,现要求 ...

  8. 2020-10-11:一条sql语句执行时间过长,应该如何优化?从哪些方面进行优化?

    福哥答案2020-10-11:#福大大架构师每日一题# 简单回答:执行计划调优.语句调优.索引调优.设计调优.业务调优. 中级回答:时间有限,回答得不全面.1.执行计划调优熟读执行计划,十大参数. 2 ...

  9. 这是一道非常有争议的题,我的分析如下: TCP/IP在多个层引入了安全机制,其中TLS协议位于______。 A.数据链路层 B.网络层 C.传输层 D.应用层

    这是一道非常有争议的题,我的分析如下: TCP/IP在多个层引入了安全机制,其中TLS协议位于______. A.数据链路层 B.网络层 C.传输层 D.应用层 这道题选D吗?因为tls协议在osi七 ...

  10. 2022-07-28:以下go语言代码输出什么?A:AA;B:AB;C:BA;D:BB。 package main import ( “fmt“ ) func main() { f

    2022-07-28:以下go语言代码输出什么?A:AA:B:AB:C:BA:D:BB. package main import ( "fmt" ) func main() { f ...