- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章使用 OBS 搭建视频流媒体服务器由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
在 Linux 或 BSD 操作系统上设置基本的实时流媒体服务器.
实时视频流越来越流行。亚马逊的 Twitch 和谷歌的 YouTube 等平台拥有数百万用户,这些用户消磨了无数小时的来观看直播和录制视频。这些视频服务通常可以免费使用,但需要你拥有一个帐户,并且一般会将你的视频内容隐藏在广告中。有些人不希望他们的视频提供给大众观看,或者想更多地控制自己的视频内容。幸运的是,借助强大的开源软件,任何人都可以设置直播服务器.
在本教程中,我将说明如何使用 Linux 或 BSD 操作系统设置基本的实时流媒体服务器.
搭建实时流媒体服务器不可避免地提到系统需求问题。这些需求多种多样,因为实时流媒体涉及许多因素,例如:
在硬件要求方面没有固定规则,因此我建议你进行测试,以便找到最适合你需求的配置。本项目中,我将服务器安装在配有 4GB 内存、20GB 硬盘空间和单个 Intel i7 处理器内核的虚拟机上.
本项目使用实时消息传递协议Real-Time Messaging Protocol(RTMP)来处理音频和视频流。当然还有其他协议可用,但我选择 RTMP 是因为它具有广泛的支持。鉴于像 WebRTC 这样的开放标准变得更加兼容,我比较推荐这条路线.
同样重要的是,要明白“实时”并不总是意味着即时。视频流必须经过编码、传输、缓冲和显示,这通常会增大延迟。延迟可以被缩短或延长,具体取决于你创建的流类型及其属性.
你可以使用许多不同的 Linux 发行版,但我更喜欢 Ubuntu,因此我下载了 Ubuntu 服务器版 作为我的操作系统。如果你希望你的服务器具有图形用户界面(GUI),请随意使用 Ubuntu 桌面版 或其多种风味版本之一。然后,我在我的计算机或虚拟机上启动了 Ubuntu 安装程序,并选择了最适合我的环境的设置。以下是我采取的步骤.
注意:因为这是一个服务器,你可能需要设置静态网络.
。
安装程序完成并重新启动系统后,你会看到一个可爱的新 Ubuntu 系统。 与任何新安装的操作系统一样,安装任何可用的更新:
sudo apt update
sudo apt upgrade
这个流媒体服务器将使用非常强大通用的 Nginx 网络服务器,所以你需要安装它:
sudo apt install nginx
然后你需要获取 RTMP 模块,以便 Nginx 可以处理你的媒体流:
sudo add-apt-repository universe
sudo apt install libnginx-mod-rtmp
修改你的网页服务器配置,使其能够接受和传送你的媒体流.
sudo nano /etc/nginx/nginx.conf
滚动到配置文件的底部并添加以下代码:
rtmp {
server {
listen 1935;
chunk_size 4096;
application live {
live on;
record off;
}
}
}
。
保存配置。我是使用 Nano 来编辑配置文件的异端。在 Nano 中,你可以通过快捷键 Ctrl+X、Y 并按下回车来保存你的配置.
这么一个非常小的配置就可以创建一个可工作的流服务器。稍后你将添加更多内容到此配置中,但这是一个很好的起点.
在开始第一个流之前,你需要使用新配置重新启动 Nginx:
sudo systemctl restart nginx
如果是“小恶魔”(LCTT 译者注:FreeBSD 的标志是一个拿着叉子的红色小恶魔)的信徒,那么建立并运行一个流媒体服务器也非常容易.
前往 FreeBSD 网站并下载最新版本。在你的计算机或虚拟机上启动 FreeBSD 安装程序,然后执行初始步骤并选择最适合你环境的设置。由于这是一个服务器,你可能需要设置静态网络.
在安装程序完成并重新启动系统后,你应该就拥有了一个闪亮的新 FreeBSD 系统。像任何其他新安装的系统一样,你可能希望更新所有内容(从这一步开始,请确保你以 root 身份登录):
pkg update
pkg upgrade
安装 Nano 来编辑配置文件:
pkg install nano
这个流媒体服务器将使用非常强大通用的 Nginx 网络服务器。 你可以使用 FreeBSD 所拥有的优秀 ports 系统来构建 Nginx.
首先,更新你的 ports 树:
portsnap fetch
portsnap extract
进入 Nginx ports 目录:
cd /usr/ports/www/nginx
运行如下命令开始构建 Nginx:
make install
你将看到一个屏幕,询问你的 Nginx 构建中要包含哪些模块。对于这个项目,你需要添加 RTMP 模块。向下滚动直到选中 RTMP 模块,并按下空格键。然后按回车键继续剩下的构建和安装.
Nginx 安装完成后,就该为它配置流式传输了.
首先,在 /etc/rc.conf 中添加一个条目以确保 Nginx 服务器在系统启动时启动:
nano /etc/rc.conf
将此文本添加到文件中:
nginx_enable="YES"
。
接下来,创建一个网站根目录,Nginx 将从中提供其内容。我自己的目录叫 stream:
cd /usr/local/www/
mkdir stream
chmod -R 755 stream/
现在你已经创建了你的流目录,通过编辑配置文件来配置 Nginx:
nano /usr/local/etc/nginx/nginx.conf
在文件顶部加载你的流媒体模块:
load_module /usr/local/libexec/nginx/ngx_stream_module.so;
load_module /usr/local/libexec/nginx/ngx_rtmp_module.so;
。
在 Server 部分下,更改 root 位置以匹配你之前创建的目录位置:
Location / { root /usr/local/www/stream}
。
最后,添加你的 RTMP 设置,以便 Nginx 知道如何处理你的媒体流:
rtmp {
server {
listen 1935;
chunk_size 4096;
application live {
live on;
record off;
}
}
}
保存配置。在 Nano 中,你可以通过快捷键 Ctrl+X、Y,然后按回车键来执行此操作.
如你所见,这么一个非常小的配置将创建一个工作的流服务器。稍后,你将添加更多内容到此配置中,但这将为你提供一个很好的起点.
但是,在开始第一个流之前,你需要使用新配置重新启动 Nginx:
service nginx restart
现在你的服务器已准备好接受你的视频流,是时候设置你的流媒体软件了。本教程使用功能强大的开源的 Open Broadcast Studio(OBS).
前往 OBS 网站,找到适用于你的操作系统的版本并安装它。OBS 启动后,你应该会看到一个首次运行向导,该向导将帮助你使用最适合你的硬件的设置来配置 OBS.
。
OBS 没有捕获任何内容,因为你没有为其提供源。在本教程中,你只需为流捕获桌面。单击“来源Source”下的 “+” 按钮,选择“显示捕获Screen Capture”,然后选择要捕获的桌面.
单击“确定OK”,你应该会看到 OBS 镜像了你的桌面.
现在可以将你新配置的视频流发送到你的服务器了。在 OBS 中,单击“文件 > 设置File > Settings”。 单击“流Stream”部分,并将“串流类型Stream Type” 设置为“自定义流媒体服务器Custom Streaming Server”.
在 URL 框中,输入前缀 rtmp:// 后跟流媒体服务器的 IP 地址,后跟 /live。例如,rtmp://IP-ADDRESS/live.
接下来,你可能需要输入“串流密钥Stream key”,这是观看你的流所需的特殊标识符。 在“串流密钥Stream key”框中输入你想要(并且可以记住)的任何关键词.
。
单击“应用Apply”,然后单击“确定OK”.
现在 OBS 已配置为将你的流发送到你的服务器,你可以开始你的第一个视频流。 单击“开始推流Start Streaming”.
如果一切正常,你应该会看到按钮更改为“停止推流Stop Streaming”,并且在 OBS 的底部将出现一些带宽指标.
。
如果你收到错误消息,请仔细检查 OBS 中的流设置是否有拼写错误。如果一切看起来都不错,则可能是另一个问题阻止了它的工作.
如果没有人观看,就说明直播视频不是很好,所以请成为你的第一个观众! 。
有许多支持 RTMP 的开源媒体播放器,但最著名的可能是 VLC 媒体播放器.
安装并启动 VLC 后,通过单击“媒体 > 打开网络串流Media > Open Network Stream” 打开你的流。输入你的流的路径,添加你在 OBS 中设置的串流密钥,然后单击“播放Play”。 例如,rtmp://IP-ADDRESS/live/SECRET-KEY.
你现在应该可以看到自己的实时视频流了! 。
。
本项目是一个非常简单的设置,可以让你开始工作。 以下是你可能想要使用的另外两个功能.
限制访问: 你可能想要做的下一件事情是限制对你服务器的访问,因为默认设置允许任何人与服务器之间进行流传输。有多种设置方法,例如操作系统防火墙、.htaccess 文件,甚至使用 STMP 模块中的内置访问控制.
录制流: 这个简单的 Nginx 配置只会流传输而不会保存你的视频,但这很容易修改。在 Nginx 配置文件中的 RTMP 部分下,设置录制选项和要保存视频的位置。确保你设置的路径存在并且 Nginx 能够写入它.
application live {
live on;
record all;
record_path /var/www/html/recordings;
record_unique on;
}
实时流媒体的世界在不断发展,如果你对更高级的用途感兴趣,可以在互联网上找到许多其他很棒的资源。祝你好运,直播快乐! 。
原文链接:https://linux.cn/article-14159-1.html 。
最后此篇关于使用 OBS 搭建视频流媒体服务器的文章就讲到这里了,如果你想了解更多关于使用 OBS 搭建视频流媒体服务器的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我在网上搜索但没有找到任何合适的文章解释如何使用 javascript 使用 WCF 服务,尤其是 WebScriptEndpoint。 任何人都可以对此给出任何指导吗? 谢谢 最佳答案 这是一篇关于
我正在编写一个将运行 Linux 命令的 C 程序,例如: cat/etc/passwd | grep 列表 |剪切-c 1-5 我没有任何结果 *这里 parent 等待第一个 child (chi
所以我正在尝试处理文件上传,然后将该文件作为二进制文件存储到数据库中。在我存储它之后,我尝试在给定的 URL 上提供文件。我似乎找不到适合这里的方法。我需要使用数据库,因为我使用 Google 应用引
我正在尝试制作一个宏,将下面的公式添加到单元格中,然后将其拖到整个列中并在 H 列中复制相同的公式 我想在 F 和 H 列中输入公式的数据 Range("F1").formula = "=IF(ISE
问题类似于this one ,但我想使用 OperatorPrecedenceParser 解析带有函数应用程序的表达式在 FParsec . 这是我的 AST: type Expression =
我想通过使用 sequelize 和 node.js 将这个查询更改为代码取决于在哪里 select COUNT(gender) as genderCount from customers where
我正在使用GNU bash,版本5.0.3(1)-发行版(x86_64-pc-linux-gnu),我想知道为什么简单的赋值语句会出现语法错误: #/bin/bash var1=/tmp
这里,为什么我的代码在 IE 中不起作用。我的代码适用于所有浏览器。没有问题。但是当我在 IE 上运行我的项目时,它发现错误。 而且我的 jquery 类和 insertadjacentHTMl 也不
我正在尝试更改标签的innerHTML。我无权访问该表单,因此无法编辑 HTML。标签具有的唯一标识符是“for”属性。 这是输入和标签的结构:
我有一个页面,我可以在其中返回用户帖子,可以使用一些 jquery 代码对这些帖子进行即时评论,在发布新评论后,我在帖子下插入新评论以及删除 按钮。问题是 Delete 按钮在新插入的元素上不起作用,
我有一个大约有 20 列的“管道分隔”文件。我只想使用 sha1sum 散列第一列,它是一个数字,如帐号,并按原样返回其余列。 使用 awk 或 sed 执行此操作的最佳方法是什么? Accounti
我需要将以下内容插入到我的表中...我的用户表有五列 id、用户名、密码、名称、条目。 (我还没有提交任何东西到条目中,我稍后会使用 php 来做)但由于某种原因我不断收到这个错误:#1054 - U
所以我试图有一个输入字段,我可以在其中输入任何字符,但然后将输入的值小写,删除任何非字母数字字符,留下“。”而不是空格。 例如,如果我输入: 地球的 70% 是水,-!*#$^^ & 30% 土地 输
我正在尝试做一些我认为非常简单的事情,但出于某种原因我没有得到想要的结果?我是 javascript 的新手,但对 java 有经验,所以我相信我没有使用某种正确的规则。 这是一个获取输入值、检查选择
我想使用 angularjs 从 mysql 数据库加载数据。 这就是应用程序的工作原理;用户登录,他们的用户名存储在 cookie 中。该用户名显示在主页上 我想获取这个值并通过 angularjs
我正在使用 autoLayout,我想在 UITableViewCell 上放置一个 UIlabel,它应该始终位于单元格的右侧和右侧的中心。 这就是我想要实现的目标 所以在这里你可以看到我正在谈论的
我需要与 MySql 等效的 elasticsearch 查询。我的 sql 查询: SELECT DISTINCT t.product_id AS id FROM tbl_sup_price t
我正在实现代码以使用 JSON。 func setup() { if let flickrURL = NSURL(string: "https://api.flickr.com/
我尝试使用for循环声明变量,然后测试cols和rols是否相同。如果是,它将运行递归函数。但是,我在 javascript 中执行 do 时遇到问题。有人可以帮忙吗? 现在,在比较 col.1 和
我举了一个我正在处理的问题的简短示例。 HTML代码: 1 2 3 CSS 代码: .BB a:hover{ color: #000; } .BB > li:after {
我是一名优秀的程序员,十分优秀!