概述

原本希望使用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中开发一个月历组件

    最近一直在出差,工作繁忙,很久没有时间更新文章了,连华为开发者大会也错过了.今天周末,忙里偷闲给大家分享一个鸿蒙月历组件. 这样的组件大家在工作中应该经常会遇到,而鸿蒙又没有提供一个这样的系统组件,今 ...

  2. Gin 实现基础 CRUD 接口

    前面2篇讲了关于 gin + mysql + jwt + rbac 等基础 web搭建操作, 主要目的还是学习 go 语言的一些应用工具, 然后本篇继续来实现一个名为 notice 的公告模块, 包含 ...

  3. C#/.NET/.NET Core技术前沿周刊 | 第 37 期(2025年5.1-5.11)

    前言 C#/.NET/.NET Core技术前沿周刊,你的每周技术指南针!记录.追踪C#/.NET/.NET Core领域.生态的每周最新.最实用.最有价值的技术文章.社区动态.优质项目和学习资源等. ...

  4. 应用间通信(一):详解Linux进程IPC

    进程之间是独立的.隔离的,使得应用程序之间绝对不可以互相"侵犯"各自的领地. 但,应用程序之间有时是需要互相通信,相互写作,才能完成相关的功能,这就不得不由操作系统介入,实现一种通 ...

  5. QPlainTextEdit获取鼠标选中内容

    QPlainTextEdit获取鼠标选中内容 m_plainTextEdit是一个 QPlainTextEdit * 获取选中内容 QString selectStr = m_plainTextEdi ...

  6. Spring AOP 面向切面编程之AOP是什么

    前言   软件工程有一个基本原则叫做"关注点分离"(Concern Separation),通俗的理解就是不同的问题交给不同的部分去解决,每部分专注于解决自己的问题.这年头互联网也 ...

  7. MySQL SQL语句书写顺序和执行顺序

    目录 SQL语句书写顺序和执行顺序 MySql执行顺序理解 实例 知识扩展 on和where的区别 limit 分页 结束语 Reference SQL语句书写顺序和执行顺序 (7) SELECT ( ...

  8. 洛谷 P1549 [NOIP1997 提高组] 棋盘问题

    洛谷 P1549 [NOIP1997 提高组] 棋盘问题 Problem 构造一个\(n\times n(n\le 10)\)的矩阵,在矩阵中填入\(1,2,\dots,n^2\),使得任意相邻的数之 ...

  9. 论文解读:Locating and Editing Factual Associations in GPT(ROME)

      本文发表在人工智能顶会NeurIPS上(原文链接),研究了GPT(Generative Pre-trained Transformer)中事实关联的存储和回忆,发现这些关联与局部化.可直接编辑的计 ...

  10. AWS学习笔记之Lambda执行权限

    最近在网上看到一道关于AWS Lambda的题,十分有意思: A developer has an application that uses an AWS Lambda function to up ...