WebRTC 环境搭建

embedded/2024/12/29 10:29:08/

主题

本文主要描述webrtc开发过程中所需的环境搭建

环境:

运行环境:ubuntu20.04

Node.js环境搭建

安装编译 Node.js 所需的依赖包:

sudo apt-get updatesudo apt-get install -y build-essential libssl-dev

下载 Node.js 源码:

curl -sL https://nodejs.org/dist/v14.19.0/node-v14.19.0.tar.gz -o node-v14.19.0.tar.gz

解压源码包:

tar -xzf node-v14.19.0.tar.gzcd node-v14.19.0

配置、编译和安装 Node.js:

./configuresudo make && sudo make install
验证 Node.js 和 npm 的安装
node -v && npm -v
测试

app.js

// 引入 http 模块
const http = require('http');// 创建一个 HTTP 服务器
const server = http.createServer((req, res) => {// 设置 HTTP 响应头res.statusCode = 200;res.setHeader('Content-Type', 'text/plain');// 向客户端发送响应res.end('Hello, World!
');
});// 指定服务器监听的端口号
const port = 3000;
server.listen(port, () => {console.log(`服务器正在监听端口 ${port}`);
});node app.js

coturn搭建

ubuntu版本

安装 COTURN 软件包:

sudo apt-get install coturn

编辑 COTURN 配置文件:

sudo vim /etc/coturn/turnserver.conf

请根据实际情况修改以下配置项:

  • realm: 设置 TURN 服务器的域名或 realm。

  • user: 设置 TURN 服务器的用户名和密码。

  • static-auth-secret: 设置身份验证的密钥。

  • server-name: 设置 TURN 服务器的域名或 IP 地址。

    #中继服务器监听的IP地址,NAT环境下直接写私网IP地址,可以指定多个IP
    listening-ip= 你自己的内网IP
    #中继服务器转发地址(本地IP地址将用于传递数据包的给每个端),和监听地址一样
    #一般不开
    #relay-ip=你自己的公网ip
    #外部IP,NAT环境下直接写:公网IP/私网IP
    external-ip=公网ip/内网ip
    #cli-password=123456
    #打开fingerprint的注释,使用长期证书机制。
    fingerprint
    #打开密码验证,使用短期证书机制。
    lt-cred-mech
    #服务器名称,用于OAuth认证,默认和realm相同,直接填公网ip.部分浏览器本段不设可能会引发cors错误。
    server-name=公网ip

    TURN REST API的长期凭证机制范围,同样设为ip,同server-name.

    realm=公网ip
    #移动的ICE(MICE)的规范支持。
    mobility
    #快捷的添加用户是使用user=XXX:XXXX的方式。
    user=jbj:123456

启动 COTURN 服务:

sudo systemctl start coturn

centos版本

# 更新系统包
sudo yum update -y# 安装构建工具和 OpenSSL 开发库
sudo yum groupinstall -y "Development Tools"
sudo yum install -y openssl-devel
sudo yum install -y coturnsudo vim /etc/turnserver.conf#中继服务器监听的IP地址,NAT环境下直接写私网IP地址,可以指定多个IP
listening-ip=172.23.111.111
#中继服务器转发地址(本地IP地址将用于传递数据包的给每个端),和监听地址一样
#relay-ip=8.138.111.111
#外部IP,NAT环境下直接写:公网IP/私网IP
external-ip=8.138.111.111
cli-password=123456
#打开fingerprint的注释,使用长期证书机制。
fingerprint
#打开密码验证,使用短期证书机制。
lt-cred-mech
#服务器名称,用于OAuth认证,默认和realm相同,直接填公网ip.部分浏览器本段不设可能会引发cors错误。
server-name=8.138.111.111
# TURN REST API的长期凭证机制范围,同样设为ip,同server-name.
realm=8.138.111.111
#移动的ICE(MICE)的规范支持。
mobility
#快捷的添加用户是使用user=XXX:XXXX的方式。
user=jbj:123456cert=/www/server/nginx/webrtc/cert.pem
pkey=/www/server/nginx/webrtc/key.pem

检查 COTURN 服务状态:

#开启
sudo systemctl restart coturn
sudo systemctl status coturn

之后,可以使用 COTURN 服务器提供的 STUN 和 TURN 功能,帮助 WebRTC 等实时通信应用程序解决 NAT 穿透问题。

也可以使用命令行启动

# nohup是重定向命令,输出都将附加到当前目录的 nohup.out 文件中;
# 命令后加 & ,后台执行起来后按 
ctr+c,不会停止
sudo nohup turnserver ‐L 0.0.0.0 ‐a ‐u jbj:123456 ‐v ‐f ‐r nort.gov &# 前台启动
sudo turnserver ‐L 0.0.0.0 ‐a ‐u jbj:123456 ‐v ‐f ‐r nort.gov  
#然后查看相应的端口号3478是否存在进程
sudo lsof ‐i:3478

sar网络上传下载检测

sudo apt-get install sysstat#每1s检测一次
sudo sar -n DEV 1

  • 09:03:19 PM: 这表示输出统计信息的时间是下午 9 点 3 分 19 秒。

网络接口信息:

  • lo: 这是本地回环接口,用于本机之间的通信。

  • ens33: 这是主网卡接口。

  • docker0: 这是 Docker 容器网桥接口。

  • docker_gwbridge: 这是 Docker 网关桥接口。

网络流量统计指标:

  • rxpck/s: 每秒接收的数据包数量。

  • txpck/s: 每秒发送的数据包数量

  • rxkB/s: 每秒接收的数据量,单位为 KB。

  • txkB/s: 每秒发送的数据量,单位为 KB。

  • rxcmp/s: 每秒接收的压缩数据包数量。

  • txcmp/s: 每秒发送的压缩数据包数量。

  • rxmcst/s: 每秒接收的多播数据包数量。

  • %ifutil: 网卡利用率百分比。

nginx环境搭建

安装 Nginx 编译依赖

sudo apt-get updatesudo apt-get install build-essential libtool zlib1g-dev libpcre3 libpcre3-dev openssl

下载 Nginx 源码

wget http://nginx.org/download/nginx-1.15.8.tar.gz
tar xvzf nginx-1.15.8.tar.gz
cd nginx-1.15.8/

配置 Nginx 编译参数 (支持 HTTPS)

./configure --with-http_ssl_module

编译安装

# 编译 Nginx
make# 安装 Nginx
sudo make install查看 Nginx 的编译参数
nginx -V--with-http_ssl_module 表示 Nginx 已经编译了对 SSL/TLS 协议的支持。

学习资料分享

0voice · GitHub


http://www.ppmy.cn/embedded/149710.html

相关文章

Android 14.0 设置默认屏幕亮度百分比

1.概述 在14.0的系统ROM产品开发中,在一些产品开发中,对于设置默认屏幕亮度和屏幕亮度百分比的功能,在开发中也是常见的功能,在10.0的平台设置可能有一些不同,一般的都是在SettingProvider中设置就可以了 在11.0以后的系统中设置默认屏幕亮度的方法就不同了,接下来具体分…

在K8S中,etcd数据库数据如何更改?

在kubernetes中,etcd中的数据更改主要发生在以下几个场景中: 1. 创建、更新和删除Kubernetes资源对象: 当用户在kubernetes中创建(POST)、更新(PUT)或删除(DELETE)一个…

解密MQTT协议:从QOS到消息传递的全方位解析

1、QoS介绍 1.1、QoS简介 使用MQTT协议的设备大部分都是运行在网络受限的环境下,而只依靠底层的TCP传输协议,并不 能完全保证消息的可靠到达。 MQTT提供了QoS机制,其核心是设计了多种消息交互机制来提供不同的服务质量,来满足…

讲解substr函数

substr JavaScript 中的 substr语法示例注意 PHP 中的 substr语法示例 Python 中的等价方法语法示例 其他语言Java 补充 substr 是编程中用于截取字符串的一个方法或函数,其功能是从一个字符串中提取出一部分子字符串。不同的编程语言中,这个功能的实现方…

在 Ubuntu 上搭建 MinIO 服务器

本文首发于博客园,原文链接:https://www.cnblogs.com/spcodhu/p/18635554 原文与本文的作者系同一人,因此投稿原创文章。 在日常开发时,如果有文件上传下载的需求(比如用户头像),但是又不想使用…

win10系统上打包electron,实现在win7系统运行

降低版本,win7上能运行的版本是: node: 14.17.0 node 链接地址:Index of /download/release/v14.17.0/ electron: "^13.6.9" (压缩包在百度网盘) electron-builder: "^22.14.13" 链接: https://pa…

ESP-NETIF L2 TAP 接口-物联网嵌入式开发应用

ESP-NETIF L2 TAP 概述 ESP-NETIF L2 TAP 接口是 ESP-IDF 访问用户应用程序中的数据链路层(OSI/ISO 中的 L2)以进行帧接收和传输的机制。在嵌入式开发中,它通常用于实现非 IP 相关协议,如 PTP 和 Wake on LAN 等。 Tips : 目前…

Kubernetes# Helm工具使用

目录 概念 核心组件 Helm客户端 Tiller Chart Repository Release Helm安装 Helm使用 创建Helm Chart 定义Chart元数据 定义Template模板 定义values参数 打包和部署 Helm Chart 推送到远程仓库 Helm常用命令 概念 Helm 是一个 Kubernetes 的包管理工具&#…