nginx-视频直播和点播服务的干货分享

近年互联网直播业务非常火热。我也研究了下,发现nginx上配置视频直播点播也很容易实现,特分享一下。一、ubuntu14.04安装nginx及nginx_rtmp_module扩展 nginx根据是否已安装和安装的方式不同,有一下三种方式安装及扩展安装。1.全新安装nginx和nginx_rtmp_module扩展

!/bin/shapt-get updateapt-get install -y gcc libpcre3 libpcre3-dev openssl libssl-dev make git libxml2 libxml2-dev libxslt-dev libgd2-xpm-dev geoip-database libgeoip-devcd /usr/local/src/git clone https://github.com/arut/nginx-rtmp-module.gitwget -c http://mirrors.sohu.com/nginx/nginx-1.9.14.tar.gztar zxvf nginx-1.9.14.tar.gzcd nginx-1.9.14/./configure --with-http_ssl_module --add-module=/usr/local/src/nginx-rtmp-modulemakemake installcd /usr/local/nginx/ln -s pwd/sbin/nginx /usr/sbin/nginx nginx -V wget http://www.*****.com/editor/attached/file/20160322/20160322112243_43972.txtmv 20160322112243_43972.txt /etc/init.d/nginxchmod +x /etc/init.d/nginxservice nginx restart

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

!/bin/shapt-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 2nginx_version=cat a|grep 'nginx version'|cut -d '/' -f 2 | cut -d ' ' -f 1rm -f a cd /usr/local/src/ # apt-get install -y gitgit clone https://github.com/arut/nginx-rtmp-module.git #采用搜狐开源镜像下载对应的nginx版本# apt-get source nginxwget -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" | shmake #强制覆盖cp -rfp objs/nginx /usr/sbin/nginx#检查是否错误/usr/sbin/nginx -t#重启nginxservice nginx restartnginx -V

3.已经编译安装过nginx的,可以直接添加nginx_rtmp_module扩展找到安装nginx的源码根目录,如果没有的话下载新的源码我的安装源码根目录 /usr/local/src/nginx-1.4.6
cd /usr/local/src/# apt-get install -y gitgit clone https://github.com/arut/nginx-rtmp-module.git nginx -V 2>a nginx_config=cat a |grep configure | cut -d ':' -f 2rm -f a cd nginx-1.4.6echo "./configure ${nginx_config} --add-module=/usr/local/src/nginx-rtmp-module" | shmake #强制覆盖cp -rfp objs/nginx /usr/sbin/nginx#检查是否错误/usr/sbin/nginx -t#重启nginxservice nginx restartnginx -V

二、配置使用编辑nginx的配置文件(/etc/nginx/nginx.conf或/usr/local/nginx/conf/nginx.conf)1.在http节点外层添加一个rtmp节点,具体内容如下:
rtmp { server { listen 1935; chunk_size 4096; max_connections 100; #音视频流上传和播放地址都是 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/; } }}

说明:application 表示一个应用地址后面的streamName可以自己定义,点播时会在相应目录下生成类似 streamName.m3u8 和 streamName.ts 的文件。live on; 表示打开直播。hls on; 表示打开点播,会在服务器上生成临时文件的。record off; 是关闭保存视频的功能。点播播放的地址是一个http协议的数据流地址。例如下面配置的 http://你的IP:8080/hls/streamName2.m3u8 。点播的文件默认是逐个生成的,又会逐个自动删除。m3u8文件是一个动态的。用vim可以查看。2.在下面的http节点内部添加一个server节点,具体内容如下:

这个是点播播放地址 http://你的IP:8080/hls/streamName2.m3u8server { listen 8080; 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.3 cd /usr/local/srcif [ ! -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-libx264makecheckinstall --pkgname=ffmpeg --pkgversion="5:${FFMPEG_VERSION}" --backup=no --deldoc=yes --default

ffmpeg –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...%5B)非打广告]包中的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...2.以上环境只是测试学习使用。公网上必须考虑权限安全,网络带宽,视频质量等。3.此类产品网络上也比较多,例如阿里云基础服务中就有视频直播点播的功能。
互联网+时代,时刻要保持学习,携手千锋PHP,Dream It Possible。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,362评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,330评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,247评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,560评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,580评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,569评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,929评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,587评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,840评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,596评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,678评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,366评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,945评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,929评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,165评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,271评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,403评论 2 342

推荐阅读更多精彩内容