概述

原本希望使用kamailio+rtpproxy来转发媒体,但是rtpproxy对于多网卡服务器的支持不好,无法正常转发多网卡之间的媒体流。

rtpengine没有官方的docker镜像可以直接使用,只能使用源码自己编一个。

环境

CentOS 7.9

rtpengine 13.1.1.6

下载

目录结构如下。

├── docker-compose.yml

├── Dockerfile

├── rtpengine.mr13.1.1.6

├── sources.list.bookworm

└── sources.list.bullseye

下载源代码,指定版本为13.1.1.6。

git clone https://github.com/sipwise/rtpengine.git rtpengine.mr13.1.1.6 -b mr13.1.1.6

sources.list.bookworm文件内容如下。

deb http://mirrors.aliyun.com/debian/ bookworm main contrib non-free

deb http://mirrors.aliyun.com/debian/ bookworm-updates main contrib non-free

deb http://mirrors.aliyun.com/debian-security bookworm-security main contrib non-free

dockerfile

dockerfile文件内容如下。

FROM debian:bookworm

COPY ./sources.list.bookworm /etc/apt/sources.list
COPY ./rtpengine.mr13.1.1.6 /usr/local/src/rtpengine RUN apt-get update \
&& apt-get -y --quiet upgrade curl iproute2 \
&& apt-get install -y --no-install-recommends ca-certificates gcc g++ make \
build-essential git libopus-dev libiptc-dev libavfilter-dev \
libevent-dev libpcap-dev libxmlrpc-core-c3-dev markdown libmnl-dev libnftnl-dev \
libjson-glib-dev default-libmysqlclient-dev libhiredis-dev libssl-dev pandoc \
libcurl4-openssl-dev libavcodec-extra gperf libspandsp-dev libwebsockets-dev \
&& cd /usr/local/src \
&& chmod -R 777 /usr/local/src/rtpengine \
&& cd rtpengine/daemon \
&& make && make install \
&& cp /usr/local/src/rtpengine/daemon/rtpengine /usr/local/bin/rtpengine \
&& rm -Rf /usr/local/src/rtpengine \
&& apt-get purge -y --quiet --force-yes --auto-remove ca-certificates gcc g++ make build-essential git markdown \
&& rm -rf /var/lib/apt/* \
&& rm -rf /var/lib/dpkg/* \
&& rm -rf /var/lib/cache/* \
&& rm -Rf /var/log/* \
&& rm -Rf /usr/local/src/* \
&& rm -Rf /var/lib/apt/lists/* CMD ["rtpengine"]

运行命令,创建docker镜像。

sudo docker build --no-cache -t 10.55.55.136:5000/zr/rtpengine:mr13.1.1.6-4 .

配置

kamailio和rtpengine的配置文件都映射到宿主机的/usr/local/kamailio/etc目录。

目录下的配置文件包括dispatcher.list kamailio.cfg rtpengine.conf。

配置内容略过。

启动

编写docker-compose.yml,启动docker容器。

docker-compose.yml内容如下。注意rtpengine启动的时候需要加-f参数,前台运行,否则docker容器会一直重启。

services:
rtpengine:
image: 10.55.55.136:5000/zr/rtpengine:mr13.1.1.6-4
container_name: rtpengine
volumes:
- /usr/local/kamailio/etc:/etc/rtpengine
command: >
/usr/local/bin/rtpengine -f
restart: unless-stopped
environment:
- TZ=Asia/Shanghai
network_mode: "host"
privileged: true
logging:
driver: json-file
options:
max-size: "100m"
max-file: "10"
ulimits:
nproc: 65535
nofile:
soft: 40000
hard: 40000 # Kamailio Service
kamailio:
image: 10.55.55.136:5000/zr/kamailio:5.8.3-bullseye
container_name: kamailio
volumes:
- /usr/local/kamailio/etc:/etc/kamailio
environment:
- TZ=Asia/Shanghai
command: >
-m64 -M8
restart: unless-stopped
network_mode: "host"
logging:
driver: json-file
options:
max-size: "100m"
max-file: "10"
ulimits:
nproc: 65535
nofile:
soft: 40000
hard: 40000
depends_on:
- rtpengine

启动命令。

sudo docker-compose up -d

查看进程和端口,运行正常。

总结

rtpproxy相对rtpengine更容易上手,但是功能也更简单。

kamailio+rtpengine的组合还有很多配置方案,需要慢慢熟悉。

空空如常

求真得真

rtpengine的docker化的更多相关文章

  1. CI Weekly #9 | 揭秘阿里 Docker 化实践之路

    2017年悄然而至,对 flow.ci 你有什么新的期待呢?新的一年,flow.ci会越来越强大好用,希望继续得到你的支持与反馈.最近,我们做了如下的「功能优化」与「问题修复」,看看有没有你想要的: ...

  2. Docker化运维方式讲解

    应用迁移需求 应用运维需要考虑的一个重要问题就是迁移, 在不同机器.机房.环境间迁移.迁移的原因有很多, 比如硬件过保(硬件故障), 机房迁移, 应用扩缩容等. 应用迁移的核心需求是: 简单.迁移操作 ...

  3. 老司机实战Windows Server Docker:2 docker化现有iis应用的正确姿势

    前言 上一篇老司机实战Windows Server Docker:1 初体验之各种填坑介绍了安装docker服务过程中的一些小坑.这一篇,我们来填一些稍大一些的坑:如何docker化一个现有的iis应 ...

  4. Docker化tomcat 并且使用maven热部署

    今天没事干 就把自己的tomcat  docker化并且使用maven实现热部署 特别记录一下~ 1.首先进行centos7的安装 就不在记录了 注意的是最好使用centos7 因为docker 依赖 ...

  5. DCOS实践分享(2):基于Docker Compose和Swarm的Docker化之路

    2016 年1 月 23 日,北京史上气温最低的一天. 在下午 1 点半的时候,由 DaoCloud 赞助的 2016 年度首次 Docker Meetup 准时开始. 在这次Meetup中,我分享了 ...

  6. FastDfs集群docker化部署

    初识分布式文件系统FastDFS- 1.分布式与集群的区别 区别:集群是个物理形态,分布式是个工作方式.只要是一堆机器,就可以叫集群,他们是不是一起协作着干活,这个谁也不知道:一个程序或系统,只要运行 ...

  7. 从头认识一下docker-附带asp.net core程序的docker化部署

    从头认识一下docker-附带asp.net core程序的docker化部署 简介 在计算机技术日新月异的今天, Docker 在国内发展的如火如荼,特别是在一线互联网公司, Docker 的使用是 ...

  8. docker化java web应用

    一.简介 Docker是一个使用Go语言开发的开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的机器上.Docker的发展速度和火爆程度着实令人惊叹,一 ...

  9. 部门sonarque代码扫描测试服务器docker化

    部门内部的服务器太多了,打算将对应的测试环境docker化. 转成docker后,以后不管是升级调研还是定制化开发测试都方便,就是事情太多,一直没有抽出身来做,今天处理下并把过程记录下来跟大家分享下. ...

  10. 一步步创建第一个Docker App —— 2. 创建 Docker化 主机

    原文:https://docs.docker.com/engine/getstarted-voting-app/node-setup/ 部署voting app的第一步,是为集群节点(swarm no ...

随机推荐

  1. 鸿蒙NEXT实践(二):公共事件通信实践-智能节电案例

    @charset "UTF-8"; .markdown-body { line-height: 1.75; font-weight: 400; font-size: 15px; o ...

  2. Alexander ——2024年报

    Alexander --2024年报 小总结 知己知彼,百战不殆.2024下半年找到了自己学习的方向,也认识很多的师傅,深入领域学习,无时不刻不在CTF的路上,逐渐建立一个完整的知识库体系. 今年的成 ...

  3. 玩转C++11多线程:让你的程序飞起来的std::thread终极指南

    大家好,我是小康. 你还在为 C++ 多线程编程发愁吗?别担心,今天咱们就用大白话彻底搞定std::thread!看完这篇,保证你对C++11多线程的理解从"一脸懵逼"变成&quo ...

  4. 探秘Transformer系列之(35)--- 大模型量化基础

    探秘Transformer系列之(35)--- 大模型量化基础 目录 探秘Transformer系列之(35)--- 大模型量化基础 0x00 概述 0x01 outlier 1.1 定义 1.2 特 ...

  5. [Python] 开发一个lychee相册命令行客户端以及python库pychee6

    有一段时间收集了不少的写真集和漫画,但是一直苦于没有很好的组织和储存的方法,直到我找到了LycheeOrg/Lychee ,它的图片组织形式非常适合存放写真集或者漫画,于是我尝试把图片都放上去.体验很 ...

  6. 2023人形全能赛v831代码(包括YOLOv2识别和扫码以及颜色识别)

    v831 import time, math from maix import nn, camera, display, image import serial class YOLOv2: def _ ...

  7. .NET SDK样式项目打包时如何将引用项目打进同一个包

    此篇为上一篇[<.NET SDK样式项目打包时如何将项目引用转为包依赖>](https://www.cnblogs.com/cnsharp/p/18819771 ")的姊妹篇. ...

  8. 【转载】Indexer 源码分析

    Indexer 源码分析 介绍 我们知道DeltaFIFO 中的元素通过 Pop 函数弹出后,在指定的回调函数中将元素添加到了 Indexer 中. Indexer 是什么?字面意思是索引器,它就是 ...

  9. Kubernetes控制器-Deployment

    Kubernetes控制器-Deployment 我们已经知道ReplicaSet控制器是用来维护集群中运行的Pod数量的,但是往往在实际操作时候,我们反而不去直接使用RS,而是使用更上层的控制器,比 ...

  10. 动手学深度学习v2——第六章predict_ch6

    在QA环节,有位同学问了第六章的predict函数在哪,书中没有给出,使用predict_ch3稍作更改可得. def predict_ch6(net, test_iter, device, n=6) ...