一、ubuntu14.04安装nginx及nginx_rtmp_module扩展

nginx根据是否已安装和安装的方式不同,有一下三种方式安装及扩展安装。

1.全新安装nginx和nginx_rtmp_module扩展

#!/bin/sh

apt-get update

apt-get install -y gcc libpcre3 libpcre3-dev openssl libssl-dev make git libxml2 libxml2-dev libxslt-dev libgd2-xpm-dev geoip-database libgeoip-dev

cd /usr/local/src/

git clone https://github.com/arut/nginx-rtmp-module.git

wget -c http://mirrors.sohu.com/nginx/nginx-1.9.14.tar.gz

tar zxvf nginx-1.9..tar.gz

cd nginx-1.9./

./configure--with-http_ssl_module --add-module=/usr/local/src/nginx-rtmp-module

make

make install

cd /usr/local/nginx/

ln -s `pwd` /sbin/nginx/usr/sbin/nginx

nginx -V

wget http://www.***.com/editor/attached/file/20160322/20160322112243_43972.txt

mv 20160322112243_43972.txt

/etc/init.d/nginx

chmod +x /etc/init.d/nginx

service nginx restart

2.apt-get安装过nginx的,需重新编译安装并添加nginx_rtmp_module扩展

#!/bin/sh

apt-get -y install dpkg-dev libxml2 libxml2-dev libxslt-dev libgd2-xpm-dev geoip-database libgeoip-dev libpcre3 libpcre3-dev libssl-dev openssl

nginx -V 2>a

nginx_config=`cat a |grep configure | cut -d ':'-f 2`

nginx_version=`cat a|grep 'nginx version'|cut -d '/'-f 2 | cut -d ' '-f 1`

rm -f a

cd /usr/local/src/

# apt-get install -y git

git clone https://github.com/arut/nginx-rtmp-module.git

#采用搜狐开源镜像下载对应的nginx版本

# apt-get source nginx

wget -c "http://mirrors.sohu.com/nginx/nginx-${nginx_version}.tar.gz"

tar zxvf "nginx-${nginx_version}.tar.gz"

cd "nginx-$nginx_version"

echo "./configure ${nginx_config} --add-module=/usr/local/src/nginx-rtmp-module"| sh

make

#强制覆盖

cp -rfp objs/nginx /usr/sbin/nginx

#检查是否错误

/usr/sbin/nginx -t

#重启nginx

service nginx restart

nginx -V

3.已经编译安装过nginx的,可以直接添加nginx_rtmp_module扩展

找到安装nginx的源码根目录,如果没有的话下载新的源码

我的安装源码根目录 /usr/local/src/nginx-1.4.6

cd /usr/local/src/

# apt-get install -y git

git clone https://github.com/arut/nginx-rtmp-module.git

nginx -V 2>a

nginx_config=`cat a |grep configure | cut -d ':'-f 2`

rm -f a

cd nginx-1.4.6

echo "./configure ${nginx_config} --add-module=/usr/local/src/nginx-rtmp-module" | sh

make

#强制覆盖

cp -rfp objs/nginx/usr/sbin/nginx

#检查是否错误

/usr/sbin/nginx -t

#重启nginx

service nginx restart

nginx -V

二、配置使用

编辑nginx的配置文件(/etc/nginx/nginx.conf或/usr/local/nginx/conf/nginx.conf)

1.在http节点外层添加一个rtmp节点,具体内容如下:

rtmp {

server {

listen ;

chunk_size ;

max_connections ;

#音视频流上传和播放地址都是 rtmp://你的IP/live/streamName

#streamName自己是自定义的。

application live {

live on;

record off;

}

#这个是上传地址 rtmp://你的IP:/hls/streamName2

#直播的地址也是这个,点播播放地址在下面

application hls {

live on;

hls on;

#请先创建相应目录(mkdir -p /var/www/hls/ && chown -R www-data:www-data /var/www )

hls_path /var/www/hls/;

}

}

}

2.在下面的http节点内部添加一个server节点,具体内容如下:

#这个是点播播放地址 http://你的IP:8080/hls/streamName2.m3u8

server {

listen ;

index index.html;

root /var/www/hls/;

location /hls {

alias /var/www/hls/;

types {

application/vnd.apple.mpegurl m3u8;

video/mp2t ts;

}

add_header Cache-Control no-cache;

}

}

说明:

这个节点是配置的一个虚拟主机,目的是为了播放上面点播服务生成的视频流。

url中streamName2是根据录制推流的名字来的。需要保持一致。

默认下,该地址有一定的时限行,需要每次都先确认一下,服务器上是否存在该m3u8文件。

3.测试使用

a.推视频流到服务器

(1).使用linux上ffmpeg工具模拟推流到服务器

安装ffmpeg工具

apt-get -y install build-essential git-core checkinstall yasm texi2html libvorbis-dev libx11-dev libvpx-dev libxfixes-dev zlib1g-dev pkg-config netcat libncurses5-dev libfaac-dev libmp3lame-dev libx264-dev

FFMPEG_VERSION=2.3.

cd /usr/local/src

if [ ! -d "/usr/local/src/ffmpeg-${FFMPEG_VERSION}"]; then

sudo wget "http://ffmpeg.org/releases/ffmpeg-${FFMPEG_VERSION}.tar.bz2"

sudo tar -xjf "ffmpeg-${FFMPEG_VERSION}.tar.bz2"

fi

cd "ffmpeg-${FFMPEG_VERSION}"./configure--enable-version3 --enable-postproc --enable-libvorbis --enable-libvpx --enable-gpl --enable-nonfree --enable-pthreads --enable-libfaac --enable-libmp3lame --enable-libx264

make

checkinstall --pkgname=ffmpeg --pkgversion="5:${FFMPEG_VERSION}"--backup=no --deldoc=yes--defaultffmpeg –version

使用ffmpeg工具把本地的视频文件模拟推送到服务器

ffmpeg -re -i /data/localFile.mp4 -c copy -f flv rtmp://你的IP/live/streamName

这个命令会把本地的localFile.mp4模拟推入live直播流,然后可以通过 rtmp://你的IP/live/streamName地址观看该直播。

ffmpeg -re -i /data/localFile.mp4 -c copy -f flv /var/www/hls/streamName

这个命令会把本地的localFile.mp4模拟推入到hls应用中,然后可以通过rtmp://你的IP/hls/streamName 地址观看该直播,也可以通过播放器打开http://你的IP:8080/hls/streamName.m3u8查看该视频的点播

(2).Windows上使用一些专业工具推流到服务器

我是使用 锐动PC录制/直播SDK(http://www.rdsdk.com/contrast/pc3.html)[非打广告]包中的demo来推流的,这个可以免费使用且免安装。

网上推荐的常见推流测试工具有 OBS, XSplit, FMLE 等。

推流的地址是 rtmp://你的IP/hls/streamName 或者 rtmp://你的IP/live/streamName

(3).自己编写手机等设备的APP,录制手机摄像头捕捉到的头像及麦克风捕捉到的声音,一起推送到服务器。

这类安卓或IOS的SDK也比较多。可自行开发。

b.使用播放器点播播放视频

Windows和linux桌面版都可以是VLC播放器打开 http://你的IP:8080/hls/streamName.m3u8这个地址观看直播(这个播放器不支持rtmp直播播放?)

c.使用Web浏览器在网页上播放直播视频

编写HTML页面index.html:

<!DOCTYPE html>

<html>

<head>

<meta http-equiv="content-type" content="text/html; charset=utf-8">

<title>HLS Player</title>

</head>

<body>

<video poster="poster.png" height="720" width="1280" controls>

<source src="http://你的IP/hls/streamName.m3u8" type="application/vnd.apple.mpegurl"/>

<p class="warning">Your browser does not support HTML5 video.</p>

</video>

</body>

</html>

修改IP,保存页面至/var/www/hls/index.html中。

用苹果设备访问http://你的IP:8080/index.html就可以看到该直播了。

由于H5兼容性问题,只能在苹果设备上用浏览器访问。

如果想要其他设备都能访问需做兼容处理。一般用flash嵌入网页中去播放直播(rtmp://...)或点播 (http://...xxx.m3u8)

d.使用nginx_rtmp_module扩展包内文件来同时录制和直播测试

在nginx_rtmp_module扩展包内有测试文件,复制该文件夹内的文件到站点根目录(如/var/www/html)

cp -r /usr/local/src/nginx-rtmp-module/test/www/* /var/www/html;

修改index.html文件中rtmp的地址为 rtmp://你的IP/live/streamName

修改record.html文件中flashvars的streamer为 rtmp://你的IP/live 并改flashvars的file值为streamName

保存。

使用浏览器同时打开两个页面 :

http://你的IP:8080/index.html(这个是直播观看的地址)

http://你的IP:8080/record.html(这个是直播录像的地址,采用的是flash录制电脑的摄像头[请点击允许])

三、其他

1.nginx-rtmp-module的配置请看Wiki https://github.com/arut/nginx-rtmp-module/wiki/Control-module

2.以上环境只是测试学习使用。公网上必须考虑权限安全,网络带宽,视频质量等。

3.此类产品网络上也比较多,例如阿里云基础服务中就有视频直播点播的功能。

nginx视频直播/点播服务干货分享的更多相关文章

  1. 三、直播整体流程 五、搭建Nginx+Rtmp直播流服务

    HTML5实现视频直播功能思路详解_html5教程技巧_脚本之家 https://m.jb51.net/html5/587215.html 三.直播整体流程 直播整体流程大致可分为: 视频采集端:可以 ...

  2. 视频直播点播nginx-rtmp开发手册中文版

    2016年8月18日12:42:35 参照官方文档https://github.com/arut/nginx-rtmp-module/wiki/Directives 请注意这个是粗翻译版,仅供参考,不 ...

  3. Android中直播视频技术探究之---视频直播服务端环境搭建(Nginx+RTMP)

    一.前言 前面介绍了Android中视频直播中的一个重要类ByteBuffer,不了解的同学可以 点击查看 到这里开始,我们开始动手开发了,因为我们后续肯定是需要直播视频功能,然后把视频推流到服务端, ...

  4. 使用 nginx 和 rtmp 插件搭建视频直播和点播服务器

    使用 nginx 和 rtmp 模块 ,可以很容易地搭建一个视频直播和点播服务器出来. 首先,看一下最经典的参考文献: How to set up your own private RTMP serv ...

  5. 【腾讯Bugly干货分享】H5 视频直播那些事

    本文来自于腾讯bugly开发者社区,非经作者同意,请勿转载,原文地址:http://dev.qq.com/topic/57a42ee6503dfcb22007ede8 Dev Club 是一个交流移动 ...

  6. 利用Nginx搭建RTMP视频直播,点播服务器,ffmpeg推流,回看

        一.环境和工具 ubuntu 14.04 desktop 不用server的原因是一部分的演示用到了linux视频播放和直播软件,自己还要装桌面,麻烦. 不建议使用 最新的16TLS,我一开始 ...

  7. 在Windows下搭建基于nginx的视频直播和点播系统

    http://my.oschina.net/gaga/blog/478480 一.软件准备 由于nginx原生是为linux服务的,因此官方并没有编译好的windows版本可以下载,要在windows ...

  8. 【腾讯bugly干货分享】HTML 5 视频直播一站式扫盲

    本文来自于腾讯bugly开发者社区,非经作者同意,请勿转载,原文地址:http://bugly.qq.com/bbs/forum.php?mod=viewthread&tid=1277 视频直 ...

  9. 收藏:视频网站(JavaEE+FFmpeg)/Nginx+ffmpeg实现流媒体直播点播系统

    FFmpeg安装(windows环境)http://www.cnblogs.com/xiezhidong/p/6924775.html 最简单的视频网站(JavaEE+FFmpeg)http://bl ...

随机推荐

  1. .NET基础笔记(C#)

    闲着没事就把以前学习时的笔记拿出来整理了一下,个人感觉有点用,就想拿出来跟园友共享一下.有些基础性的内容比如基本概念.语法什么的就不发了. 内容:1.构造方法(函数) 2.继承   3.访问修饰符   ...

  2. wemall app商城源码中ScrollView中嵌套ListView主要代码

    很多时间我们在scorllview中嵌入listview的时候,都只能看到listview显示一行数据,而我们的要求是显示多行,即我们数据的行数, 当ListView的高度设定一定的值时,ListVi ...

  3. 'utf8' codec can't decode byte 0xd1 in position 931: invalid continuation byte解决方法

    有时候,我得到这样的字符œ导致的UnicodeDecodeError错误. 我需要能够使串的UTF-8有或没有这些字符. 在工作中,经常遇到,读取一个文件,或者是从网页获取一个问题,明明看着是gb23 ...

  4. 四大组件之一---------activity的知识

    activity的生命活动 activity的四种启动模式 Android中以一个任务栈用来管理activity 一个栈的形式进行管理 在清单文件中,通过<activity>标签的andr ...

  5. MySQL1236错误的恢复

    从库出现问题 mysql> show slave status\G; *************************** . row *************************** ...

  6. 用C语言写的万年历---亲手写的。好累哦

    #include <stdio.h>#include <stdlib.h>#include <string.h>#define str "   SUN   ...

  7. Unity3D动态读取外部MP3文件给AudioSource

    在PC端VR游戏开发中,需要动态加载本地的MP3文件,但是Unity3D不知道出于什么原因,到5.4.0也不支持MP3文件的外部加载(目前只支持wav和ogg). 因此要想通过www来加载mp3文件就 ...

  8. 使用JDB调试Java程序

    Java程序中有逻辑错误,就需要使用JDB来进行调试了.调试程序在IDE中很方便了,比如这篇博客介绍了在Intellj IDEA中调试Java程序的方法. 我们课程内容推荐在Linux环境下学习,有同 ...

  9. html实现 页面禁止右键 禁止复制 禁止图片拖动 禁止复制和剪切

    众所周知,一般的屏蔽的方法是用JS来编写的脚本,但是也可以直接通过修改网页属性的方法来屏蔽右键 禁止复制. 禁止右键 oncontextmenu="return false" 禁止 ...

  10. Windows下Nginx的安装与使用(一):配置端口转发

    什么是端口转发 当我们在服务器上搭建一个图书以及一个电影的应用,其中图书应用启动了 8001 端口,电影应用启动了 8002 端口.此时如果我们可以通过: localhost:8001 //图书 lo ...