Docker安装WebRTC下TURN服务

详细实现方式以及代码下载请前往 https://www.passerma.com/article/90

实现效果

一、手动构建镜像

1.新建Dockerfile文件

文件用于编译镜像

以alpine为基础镜像

添加coturn需要的依赖库

获取coturn并进行编译

通过start.sh启动turnserver服务

Dockerfile

复制代码
FROM alpine

RUN apk add make \
  gcc\
  g++ \
  wget \
  libevent-dev \
  openssl-dev \
  libffi-dev \
  curl

RUN wget https://github.com/coturn/coturn/archive/4.5.1.3.tar.gz \
  && tar -zxvf 4.5.1.3.tar.gz \
  && cd coturn-4.5.1.3 \
  && ./configure && make && make install && cd .. \
  && rm -rf coturn-4.5.1.3 4.5.1.3.tar.gz

COPY ./start.sh /start.sh

EXPOSE 3478 3478/udp

ENTRYPOINT ["/start.sh"]

2.新建start.sh文件

需要先给予start.sh文件可执行权限

复制代码
chmod +x start.sh

start.sh

复制代码
#!/bin/sh

createConf() {
  if [ -z "$EXTERNAL_IP" ]; then
    ip_tmp=$(curl http://icanhazip.com)
    if [ $? -eq 0 ]; then
      echo "获取 EXTERNAL_IP 成功: $ip_tmp"
      EXTERNAL_IP="$ip_tmp"
    else
      echo "获取 EXTERNAL_IP 失败,请手动修改"
      EXTERNAL_IP="0.0.0.0"
    fi
  else
    echo "EXTERNAL_IP 已经设置为: $EXTERNAL_IP"
  fi

  cat <<EOF >>/etc/turnserver.conf
listening-device=eth0
listening-port=3478
listening-ip=0.0.0.0
external-ip=$EXTERNAL_IP
fingerprint
lt-cred-mech
user=$user_tmp
realm=localhost
no-tlsv1
no-tlsv1_1
no-tlsv1_2
EOF
}

echo "====== 配置 turnserver ======"

user_tmp=${TURN_USERNAME:-"user"}:${TURN_PASSWORD:-"pass"}
if [ ! -f /etc/turnserver.conf ]; then
  echo "创建 /etc/turnserver.conf 配置文件"
  createConf
  echo "====== 启动 turnserver ======"
  echo "external-ip=$EXTERNAL_IP"
  echo "user=$user_tmp"
else
  echo "/etc/turnserver.conf 配置文件已存在"
  echo "====== 启动 turnserver ======"
fi

exec turnserver -v -c /etc/turnserver.conf

3.编译镜像

复制代码
docker build -t passerma/turnserver .

二、使用现有镜像

复制代码
docker pull passerma/turnserver

三、镜像使用

1.直接运行

bash 复制代码
docker run -itd --name turnserver -p 3478:3478 -p 3478:3478/udp passerma/turnserver

2.带参数运行

支持修改公网 ip、用户名、密码

bash 复制代码
docker run -itd --name turnserver \
-e EXTERNAL_IP=1.2.3.4 -e TURN_USERNAME=myuser -e TURN_PASSWORD=mypass \
-p 3478:3478 -p 3478:3478/udp \
passerma/turnserver

3.配置修改

配置文件位置 /etc/turnserver.conf

配置文件默认如下

复制代码
listening-device=eth0
listening-port=3478
listening-ip=0.0.0.0
external-ip=0.0.0.0
fingerprint
lt-cred-mech
user=user:pass
realm=localhost
no-tlsv1
no-tlsv1_1
no-tlsv1_2

默认用户名密码为 user:pass

四、项目源码

详细实现方式以及代码下载请前往 https://www.passerma.com/article/90

相关推荐
荣光波比2 小时前
K8S(一)—— 云原生与Kubernetes(K8S)从入门到实践:基础概念与操作全解析
云原生·容器·kubernetes
hello_2504 小时前
k8s基础监控promql
云原生·容器·kubernetes
小杨的全栈之路5 小时前
生产级实践:在 Docker 中安全导入自签名证书,保障 Spring Boot 应用通信安全
docker·https
静谧之心6 小时前
在 K8s 上可靠运行 PD 分离推理:RBG 的设计与实现
云原生·容器·golang·kubernetes·开源·pd分离
计算机小手8 小时前
推荐一个 GitHub 开源项目信息卡片生成工具,支持Docker快速部署和API调用
经验分享·docker·github·开源软件
饭来_10 小时前
通过 SSH 远程连接 docker 容器
vscode·docker·ssh
1024find10 小时前
Spark on k8s部署
大数据·运维·容器·spark·kubernetes
kura_tsuki11 小时前
[Docker集群] Docker 容器入门
运维·docker·容器
开始学AI11 小时前
【Docker技术】docker-compose.yml与Dockerfile解析
java·docker·eureka
一水鉴天1 天前
整体设计 逻辑系统程序 之18 Source 容器(Docker)承载 C/P/D 三式的完整设计与双闭环验证 之2
docker·架构·认知科学·公共逻辑