docker 部署freeswitch(非编译方式)

一:安装部署

1.拉取镜像

参考:https://hub.docker.com/r/safarov/freeswitch

复制代码
 docker pull safarov/freeswitch

2.启动镜像

复制代码
docker run --net=host --name freeswitch \
           -e SOUND_RATES=8000:16000 \
           -e SOUND_TYPES=music:en-us-callie \
           -v /home/xx/freeswitch-sounds:/usr/share/freeswitch/sounds \
           -v /etc/freeswitch/:/etc/freeswitch \
           safarov/freeswitch

启动后出错:

这里的错误影响不是很大,可以不用管,主要是把语音相关文件补回去,不然拨打后拿文件会出错

手动下载:freeswitch-sounds-en-us-callie-8000-1.0.51.tar 解压到/home/xx/freeswitch-sounds

操作后重启镜像

3.宿主机关防火墙

复制代码
  sudo systemctl stop firewalld
  sudo systemctl disable firewalld
  sudo systemctl status firewalld

4.至此基本能用了,使用方式

账号:1000到1019

密码:/etc/freeswitch/vars.xml

查找关键字:default_password,就能看到

服务器地址:宿主机ip:5060,例如:1.1.1.1:5060

二:添加账号

参考目录:/etc/freeswitch/directory/default

下面1000.xml,拷贝把文件名和内容的1000全部替换,例如1020

添加后进入容器

复制代码
  docker exec -it freeswitch  /bin/bash

执行

复制代码
fs_cli -x "reloadxml"

生效

三:拨打定制特定号码服务端的响应计划

举例:想要配置拨打10086的时候,先振铃5秒,再拨打一段语音,然后挂断

打开/etc/freeswitch/dialplan/default.xml

添加下面的配置

复制代码
  <extension name="zhauto_answer">
        <condition field="destination_number" expression="^10086$">
            <action application="ring_ready"/>
            <action application="sleep" data="5000"/>
            <action application="answer"/>
            <action application="sleep" data="1000"/>
            <action application="playback" data="/usr/share/freeswitch/sounds/partita-no-3-in-e-major-bwv-1006-1-preludio.wav"/>
            <action application="hangup"/>
        </condition>
    </extension>

重启容器即可

相关推荐
lee_yanyi27 分钟前
《一键式江湖:Docker Compose中间件部署108式》开篇:告别“配置地狱”,从此笑傲云原生武林!》
docker·云原生·中间件
weisian1511 小时前
云原生--核心组件-容器篇-1-Docker和云原生关系(Docker是云原生的基石)
docker·云原生·容器
David爱编程1 小时前
Service 与 Headless Service 全面对比与实战指南
docker·容器·kubernetes
巨懵2 小时前
不使用dockerfile的方式制作一个Ubuntu20.04的镜像
docker
DavidSoCool4 小时前
k8s生成StarRocks集群模版
云原生·容器·kubernetes
菠萝崽.6 小时前
安装docker,在docker上安装mysql,docker上安装nginx
java·mysql·nginx·docker·软件工程·springboot·开发
庸子7 小时前
当JIT遇见K8s
云原生·容器·kubernetes
roman_日积跬步-终至千里11 小时前
【K8s基础】K8s下的Helm和Operator:包管理器与运维程序化
运维·容器·kubernetes
leo·Thomas13 小时前
Rundeck 介绍及安装:自动化调度与执行工具
docker·自动化·运维工具·rundeck
技术liul14 小时前
Docker Compose和 Kubernetes(k8s)区别
docker·容器·kubernetes