操作系统 :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. 【谷粒商城】(二)SpringCloudAlibaba分布式组件

    微服务 分布式组件 注册中心:每一个微服务上线都应该注册到注册中心.这样做的好处在于方便微服务之间的相互调用,比如订单服务想要调用商品服务,就可以通过注册中心查看有哪几台主机的商品服务进行了注册,然后 ...

  2. 【能力提升】SQL Server常见问题介绍及快速解决建议

    前言 本文旨在帮助SQL Server数据库的使用人员了解常见的问题,及快速解决这些问题.这些问题是数据库的常规管理问题,对于很多对数据库没有深入了解的朋友提供一个大概的常见问题框架. 下面一些问题是 ...

  3. HDCTF_2023

    pwnner 附件 有后门函数,seed是一个固定值, //伪随机数 #include <stdio.h> #include <stdlib.h> int main() { i ...

  4. 访问nginx报错502日志:failed (13: Permission denied) while connecting to upstream

    1.错误问题 nginx启动成功,但是访问nginx报错502.检查后台项目,使用IP+端口可以正常访问项目的,这说明项目启动成功了.那就是nginx的问题.检查了nginx.conf文件发现配置的反 ...

  5. [Pytorch框架] 2.1.4 数据的加载和预处理

    文章目录 PyTorch 基础 :数据的加载和预处理 Dataset Dataloader torchvision 包 torchvision.datasets torchvision.models ...

  6. Mac终端出现 brew command not found 解决

    MacOS 上您需要安装 unrar 以支持 PaddlePaddle,可以使用命令brew install unrar 执行命令后发现 brew 不存在 jimmy@MacBook-Pro ~ % ...

  7. Stream方法的介绍

    文章目录 前言 Lambda表达式 格式 函数式接口 Stream的方法介绍 forEach filter collect count sum limit 和skip groupingBy reduc ...

  8. Android JetPack~LiveData(二) 数据倒灌问题

    Android数据绑定技术一,企业级开发 Android数据绑定技术二,企业级开发 Android  JetPack~ DataBinding(数据绑定)(一)    集成与使用 Android  J ...

  9. 基于.NetCore开发博客项目 StarBlog - (27) 使用JWT保护接口

    前言 这是StarBlog系列在2023年的第二篇更新 这几个月都在忙,更新变得很不勤快,但是拖着不更新我的心里更慌,很久没写,要开头就变得很难 说回正题,之前的文章里,我们已经把博客关键的接口都开发 ...

  10. Prism Sample 5 View Injection

    这里稍微复杂了点,定义视图A的过程是一样的: <UserControl x:Class="ViewInjection.Views.ViewA" xmlns="htt ...