使用nginx和nginx-rtmp-module搭建流媒体服务器

  之前在使用nginxnginx-rtmp-module搭建流媒体服务器的时候遇到一个很尴尬的问题,就是在把nginx-rtmp-module模块添加到nginx中去的时候,我最开始采取的做法是先卸载原来的nginx,再下载nginx和nginx-rtmp-module的源码重新编译并安装.重装完之后我测试了一下流媒体服务器是正常的,但是接下来问题来了,由于我有一些web工程是部署在之前搭建好的lump环境下的,现在重装了nginx,这些工程需要重新部署.于是,我又开始重新部署这些web工程,但是结果让我哭晕在了厕所,因为nginx的目录结构发生了很大改变,导致我没办法配置原来的web工程了.此后我陷入了很长时间的挣扎和徘徊,网上搜寻了很多解决方案,但是这些方案大多都是侧重讲如何编译安装nginx以及进行推拉流测试,没有涉及到我这方面的问题.后来,我在浏览帖子的时候看到有人说把自己编译的nginx可执行文件替换掉原来的nginx共享库能解决问题,于是立马试了一把,结果发现真的可以!现在的nginx能同时运行流媒体服务和部署web工程,鱼与熊掌兼得!

  下面简单介绍一下我的操作过程,希望能为遇到同样问题的你带来一些帮助(我的配置环境:Ubuntu Server 16.04 + nginx1.10.0 + nginx-rtmp-module-master).

  1.先采用apt-get的方式安装nginx.目前用此方式安装的nginx的版本号为1.10.0

1 sudo apt-get update2 sudo apt-get install nginx

  2.到你喜欢的目录下用你喜欢的名字创建一个目录,用于存放nginx和nginx-rtmp-module的源码,例如:我在根目录/softwares(softwares也是我自己创建的)下面创建了nginx目录,接下来我会把nginx和nginx-rtmp-module下载到nginx目录下.

1 cd softwares/2 sudo mkdir nginx

  3.进入nginx目录.

1 cd nginx/

  4.下载nginx源码,注意:下载的源码版本需要与步骤1安装的nginx的版本保持一致,以避免不必要的问题.获取nginx源码的途径很多,此处推荐两种方式.

  方式a:在终端执行apt-get source nginx命令,直接获取到对应版本的源码.

1 sudo apt-get source nginx

  此方式下载完之后会自动解压,nginx-1.10.0目录即nginx源码目录.

  方式b:在nginx的官网上面找到对应版本然后下载.

1 sudo wget nginx.org/download/nginx-1.10.0.tar.gz

  此方式下载完之后需要自己手动解压.解码命令:

1 sudo tar zxvf nginx-1.10.0.tar.gz

  5.下载nginx-rtmp-module的源码.

1 sudo wget github.com/arut/nginx-rtmp-module/archive/master.zip

  因为nginx-rtmp-module已在GitHub上开源,所以也可以直接从GitHub上获取.GitHub地址:

  6.解压nginx-rtmp-module源码的压缩包.

1 sudo unzip master.zip

  7.进入nginx源码目录.

AI新媒体文章 AI新媒体文章

专为新媒体人打造的AI写作工具,提供“选题创作”、“文章重写”、“爆款标题”等功能

AI新媒体文章 75 查看详情 AI新媒体文章

1 cd nginx-1.10.0/

  8.查看当前nginx的配置信息,并将当前配置信息完整保存到一个地方,后面在编译nginx源码的时候需要依据当前的配置信息来进行配置.

1 nginx -V

  注意命令行中的V是大写哦,小写只能看到nginx的版本号.我当前的nginx配置信息如下:

--with-cc-opt='-g -O2 -fPIE -fstack-protector-strong -Wformat -Werror=format-security -Wdate-time -D_FORTIFY_SOURCE=2' --with-ld-opt='-Wl,-Bsymbolic-functions -fPIE -pie -Wl,-z,relro -Wl,-z,now' --prefix=/usr/share/nginx --conf-path=/etc/nginx/nginx.conf --http-log-path=/var/log/nginx/access.log --error-log-path=/var/log/nginx/error.log --lock-path=/var/lock/nginx.lock --pid-path=/run/nginx.pid --http-client-body-temp-path=/var/lib/nginx/body --http-fastcgi-temp-path=/var/lib/nginx/fastcgi --http-proxy-temp-path=/var/lib/nginx/proxy --http-scgi-temp-path=/var/lib/nginx/scgi --http-uwsgi-temp-path=/var/lib/nginx/uwsgi --with-debug --with-pcre-jit --with-ipv6 --with-http_ssl_module --with-http_stub_status_module --with-http_realip_module --with-http_auth_request_module --with-http_addition_module --with-http_dav_module --with-http_geoip_module --with-http_gunzip_module --with-http_gzip_static_module --with-http_image_filter_module --with-http_v2_module --with-http_sub_module --with-http_xslt_module --with-stream --with-stream_ssl_module --with-mail --with-mail_ssl_module --with-threads

  9.配置nginx源码编译信息,将nginx-rtmp-module添加到nginx中.

1 sudo ./configure --prefix=/usr/share/nginx --conf-path=/etc/nginx/nginx.conf --http-log-path=/var/log/nginx/access.log --error-log-path=/var/log/nginx/error.log --lock-path=/var/lock/nginx.lock --pid-path=/run/nginx.pid --http-client-body-temp-path=/var/lib/nginx/body --http-fastcgi-temp-path=/var/lib/nginx/fastcgi --http-proxy-temp-path=/var/lib/nginx/proxy --http-scgi-temp-path=/var/lib/nginx/scgi --http-uwsgi-temp-path=/var/lib/nginx/uwsgi --with-debug --with-pcre-jit --with-ipv6 --with-http_ssl_module --with-http_stub_status_module --with-http_realip_module --with-http_auth_request_module --with-http_addition_module --with-http_dav_module --with-http_geoip_module --with-http_gunzip_module --with-http_gzip_static_module --with-http_v2_module --with-http_sub_module --with-http_xslt_module --with-stream --with-stream_ssl_module --with-mail --with-mail_ssl_module --with-threads --add-module=../nginx-rtmp-module-master

  注意,这一行命令其实是这样组成的: sudo ./configure –add-module=../nginx-rtmp-module-master.这样就将nginx-rtmp-module添加到nginx配置里面了,同时将之前保存的nginx配置信息添加到了用于此次编译的配置信息里面,尽可能地保证了编译出来的nginx与原来的nginx功能一致.细心的同学会发现,其实我在配置nginx信息的时候并没有将原来所有的配置信息都写进去,原因是如果全部复制粘贴过去,在编译的时候会出现一些不太好处理的错误,这些错误一时半会儿还没找到好的解决方案,所以就缩减了一些配置信息,缩减之后在功能模块上并无太大差异,所以可放心使用.

  10.配置完成之后,执行make命令开始编译nginx源码.编译完成之后,会在nginx源码目录的objs目录下生成nginx可执行文件.

1 sudo make

  11.将生成的nginx可执行文件拷贝到/usr/sbin目录下,替换原来的nginx共享库文件. 注意: 原来/usr/sbin目录有一个nginx共享库文件,我们使用编译出来的nginx可执行文件对其进行替换.

1 sudo nginx /usr/sbin

  12.重启nginx.

1 sudo service nginx restart

  13.再次查看nginx配置信息.

1 nginx -V

  可以看到nginx-rtmp-module模块已经添加到了nginx里面.

1 --prefix=/usr/share/nginx --conf-path=/etc/nginx/nginx.conf --http-log-path=/var/log/nginx/access.log --error-log-path=/var/log/nginx/error.log --lock-path=/var/lock/nginx.lock --pid-path=/run/nginx.pid --http-client-body-temp-path=/var/lib/nginx/body --http-fastcgi-temp-path=/var/lib/nginx/fastcgi --http-proxy-temp-path=/var/lib/nginx/proxy --http-scgi-temp-path=/var/lib/nginx/scgi --http-uwsgi-temp-path=/var/lib/nginx/uwsgi --with-debug --with-pcre-jit --with-ipv6 --with-http_ssl_module --with-http_stub_status_module --with-http_realip_module --with-http_auth_request_module --with-http_addition_module --with-http_dav_module --with-http_geoip_module --with-http_gunzip_module --with-http_gzip_static_module --with-http_v2_module --with-http_sub_module --with-http_xslt_module --with-stream --with-stream_ssl_module --with-mail --with-mail_ssl_module --with-threads --add-module=../nginx-rtmp-module-master

  试了试推流拉流,功能正常,再运行了一下原来的WEB工程,也正常!

  最后,我说明一下为什么要先通过apt-get的方式安装nginx,再进行编译替换.原因是为了方便在LUMP环境下部署WEB工程.如果不先通过apt-get的方式安装nginx,而是直接下载源码编译安装,则nginx的配置目录会不齐全,很难去部署WEB项目(也许通过某些操作也能实现部署,但是具体怎么操作还是要花时间去研究nginx的).如果不搭建流媒体服务,我建议都通过apt-get的方式安装nginx,步骤简单又省心!

 

以上就是使用nginx和nginx-rtmp-module搭建流媒体服务器的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/288557.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月4日 19:36:14
下一篇 2025年11月4日 19:37:15

相关推荐

  • PHP文件引入路径管理:解决组件require引发的500错误与跨环境兼容性

    在PHP开发中,使用require或include引入头部、底部等组件时,常因文件路径解析不当导致本地运行正常而线上出现500错误。核心问题在于混淆了文件系统路径与URL路径,以及相对路径在不同文件深度下的不稳定性。本文将深入探讨PHP文件引入机制,分析常见错误原因,并提供一种基于定义项目根路径常量…

    2025年12月10日
    000
  • PHP怎么复制文件_PHP文件复制功能实现方法详解

    使用PHP的copy()函数可直接复制文件,但需确保源文件存在、目标目录可写且路径正确。通过file_exists()检查源文件,is_dir()和is_writable()验证目标目录,若目录不存在则用mkdir($destinationDir, 0755, true)递归创建。批量复制或文件夹复…

    2025年12月10日
    000
  • 解决PHP require 路径问题:从500错误到高效组件引入

    在PHP开发中,require 或 include 引入文件(如页眉和页脚)时,开发者常遇到本地环境正常而线上服务器出现500错误的问题。这通常源于文件路径引用不当,尤其是混淆了文件系统路径与URL路径。本文将深入探讨此问题,并提供基于文件路径的多种解决方案,最终推荐一种通过集中化配置实现高效、稳健…

    2025年12月10日
    000
  • PHP开发环境如何配置_PHP集成环境安装配置步骤

    配置PHP开发环境有集成和手动两种方式,集成环境如XAMPP安装简便适合新手,手动配置灵活适合进阶用户;建议新项目使用PHP 8.x以获得性能提升,旧项目可先沿用PHP 7.x并评估升级需求;若XAMPP启动失败因端口占用,可通过修改Apache和MySQL端口或关闭冲突程序解决。 PHP开发环境配…

    2025年12月10日
    000
  • PHP中GET和POST有什么主要区别_PHP中GET与POST请求方法的关键差异对比

    答案:GET和POST的核心区别在于数据传输方式、安全性、数据大小限制及使用场景。GET将数据附加在URL中,适用于获取数据、可缓存和书签化,但有长度限制且不安全;POST将数据封装在请求体中,适合提交敏感或大量数据,更安全且无大小限制,但不可缓存。 在PHP中,GET和POST是两种最基础也最常用…

    2025年12月10日
    000
  • PHP如何实现基本的路由功能_PHP构建简单URL路由系统的思路与实现

    答案:PHP路由通过将URL映射到处理逻辑,实现解耦、美观、安全和易维护。核心步骤包括配置重写规则、创建入口文件index.php、定义Router类进行请求匹配与分发,并支持动态参数提取和404处理;进一步可扩展路由分组、中间件、控制器、命名路由等机制以提升灵活性和可维护性。 PHP实现基本的路由…

    2025年12月10日
    000
  • PHP怎么安装GD库_PHP图像处理库安装方法

    GD库是PHP图像处理的核心扩展。安装需在php.ini中启用extension=gd,Linux系统通过apt或yum安装php-gd后重启服务器,macOS通常自带但需手动启用。验证方法为使用phpinfo()查看GD信息或运行图像创建脚本。常见函数包括imagecreate、imagecolo…

    2025年12月10日
    000
  • php中的生成器(Generator)是什么?PHP生成器(Generator)原理与应用

    PHP生成器通过yield实现惰性求值,按需逐个返回数据而非一次性加载,显著降低内存占用。它适用于处理大文件、数据库大批量查询、无限序列生成和API分页等场景,避免内存溢出。生成器只能单次迭代,需注意资源清理与异常处理,合理命名并避免提前转为数组,以充分发挥其流式处理优势。 PHP中的生成器(Gen…

    2025年12月10日
    000
  • PHP怎么配置SSL_PHP环境SSL证书配置教程

    配置PHP的SSL环境需先获取SSL证书,推荐使用Let’s Encrypt免费证书;将证书文件、私钥及中间证书上传至服务器指定目录;接着配置Apache或Nginx服务器,Apache需启用SSLEngine并设置证书路径,Nginx则在server块中添加ssl_certificat…

    2025年12月10日
    000
  • php如何配置错误报告?php错误报告级别设置指南

    PHP错误报告配置需根据环境区分:开发时开启display_errors和E_ALL级别报告以快速调试,生产时关闭显示并记录日志,常用error_reporting控制级别,结合ini_set()或框架实现灵活管理。 PHP错误报告的配置核心在于控制哪些类型的错误被显示给用户或记录到日志文件,以及如…

    2025年12月10日
    000
  • PHP如何安全地执行系统命令_PHP系统命令安全执行函数

    安全执行PHP系统命令需严格验证输入、使用escapeshellarg()转义参数、优先选用proc_open实现精细控制,并结合最小权限原则与系统配置(如禁用高危函数、设置open_basedir、低权限运行服务)构建纵深防御体系。 在PHP中安全地执行系统命令,核心在于严格的输入验证、正确使用参…

    2025年12月10日
    000
  • PHP exec()调用FFMPEG:生产环境失效疑难排查与解决方案

    本文深入探讨了PHP中通过exec()函数调用FFMPEG命令时,在本地环境正常运行但在生产环境失效的常见问题。核心症结往往不在于FFMPEG的路径或文件权限,而是命令字符串的复杂拼接与引用解析错误。教程将指导读者如何排查此类问题,并通过简化命令、精确调试和安全实践来确保FFMPEG命令在生产环境的…

    2025年12月10日
    000
  • 深入理解PHP exec()与FFmpeg:确保命令在生产服务器上正确执行

    本文旨在解决PHP exec()函数在生产环境调用FFmpeg时遇到的常见问题。我们将探讨FFmpeg路径、文件权限、PHP执行环境等潜在因素,并重点剖析导致命令失效的核心原因——exec()命令字符串的语法构建与shell解析。通过提供详细的排查步骤、安全的代码示例及最佳实践,帮助开发者确保FFm…

    2025年12月10日
    000
  • 在 Laravel Nova 中实现邮件附件发送功能

    本教程详细指导如何在 Laravel Nova 应用中,通过自定义 Action 实现带文件附件的邮件发送功能。我们将探讨如何在 Mailable 类中利用 attach() 方法,将存储在服务器上的文件作为附件发送给收件人,并提供具体的代码示例和注意事项,确保邮件能够成功携带附件送达。 在 lar…

    2025年12月10日
    000
  • Laravel Dropzone 文件上传指南:解决 500 错误及最佳实践

    本文旨在解决 Laravel 应用中 Dropzone 文件上传时遇到的 500 内部服务器错误。核心问题在于未正确从请求中获取上传文件实例以及 move 方法的使用不当。通过明确指定文件输入名称并利用 Laravel 文件移动功能,可以有效解决文件无法保存的问题,确保文件上传流程顺畅。 Larav…

    2025年12月10日
    000
  • Laravel 文件上传:Dropzone 500 错误解析与正确实现

    本文旨在解决 Laravel 应用中集成 Dropzone 进行文件上传时遇到的 500 内部服务器错误。核心问题在于控制器中未能正确获取上传文件实例并采用 Laravel 推荐的文件移动方式。通过修正 request()->file() 的参数以及调整 move 方法的用法,可以有效实现文件…

    2025年12月10日
    000
  • php怎么预防sql注入_php防止sql注入的几种方法

    核心理念是“不信用户,参数先行”,即始终将用户输入视为威胁,通过预处理语句实现SQL逻辑与数据分离,从根本上防止SQL注入。具体措施包括:优先使用PDO或mysqli的预处理语句处理数据值;对无法参数化的表名、列名采用白名单验证;结合输入验证、最小权限原则、错误信息隐藏等多层防御;避免使用已被废弃的…

    2025年12月10日
    000
  • php如何使用共享内存 php进程间通信之共享内存(Shmop)

    答案:PHP中通过Shmop扩展实现共享内存,需手动安装并启用,使用shmop_open等函数操作内存段,并结合信号量避免数据竞争,适用于高频数据共享场景。 PHP中使用共享内存,简单来说,就是让不同的PHP进程可以访问同一块内存区域,从而实现数据共享和进程间通信。Shmop扩展就是PHP提供的一种…

    2025年12月10日
    000
  • PHP如何设置时区_PHP中设置默认时区的几种方式

    设置PHP时区可解决时间显示错误问题,主要方法有三种:修改php.ini全局设置、在脚本中使用date_default_timezone_set()函数、通过.htaccess文件配置;其中推荐优先使用php.ini方式并重启服务器使配置生效。 PHP设置时区,说白了就是告诉PHP脚本,你在哪个时间…

    2025年12月10日
    000
  • php如何获取CPU和内存使用情况?PHP系统资源监控与获取

    PHP获取CPU和内存使用情况需借助系统命令或读取/proc文件,常用exec()或shell_exec()执行top、free等命令并解析输出,也可通过sys_getloadavg()获取负载、memory_get_usage()获取脚本内存;但执行外部命令有性能开销和安全风险,如命令注入、权限提…

    2025年12月10日
    000

发表回复

登录后才能评论
关注微信