文档章节

在Nginx服务器上架构Flv流媒体服务器

mind-blowing
 mind-blowing
发布于 2014/05/16 17:31
字数 1600
阅读 197
收藏 5

FLV视频发布方式简介

FLV视频有两总发布方式

HTTP方式

这种方式要下载FLV视频文件到本地播放,一旦FLV视频文件下载完成,就不会消耗服务器的资源和带宽,但是拖动功能没有RTMP/RTMP流媒体方式强大,很多视频网站都是用HTTP方式实现的,如:YouTube,土豆,酷6等

RTMP/RTMP流媒体方式

这种方式不用下载FLV视频文件到本地,可以实时的播放flv文件,可以任意拖拽播放进度条,但是比较消耗服务器的资源,

 

使用nginx来搭建flv流媒体服务器

1、使用nginx来搭建flv流媒体服务器简介

nginx中的Flv Stream模块能实现flv流媒体的功能,而且支持flv视频进度条拖拽,另外nignx还可以作为方向代理服务器代理后端基于Flash Media Server或者Red5的RTMP/RTMP流媒体服务器

 

下面我们就来搭建一个完整的nginx流媒体服务器

1)、Nginx服务器的安装

#安装zlib

wget  http://www.imagemagick.org/download/delegates/zlib-1.2.7.tar.gz

tar xzvf zlib-1.2.7.tar.gz

cd zlib-1.2.7

./configure

make && make install

#安装pcre

wget http://ftp.exim.llorien.org/pcre/pcre-8.12.tar.gz

tar zxvf pcre-8.12.tar.gz

cd pcre-8.12

./configure --prefix=/usr/local/pcre

make && make install

#安装nginx

groupadd www

useradd -g www www

mkdir -p /home/www/flv

chown -R www:www /home/www/flv

wget http://nginx.org/download/nginx-.tar.gz

tar xzvf nginx-1.0.1.tar.gz

cd nginx-1.0.1

./configure --with-http_ssl_module --with-pcre=/root/pcre-8.12 --with-zlib=/root/zlib-1.2.7 

--user=www --group=www --prefix=/usr/local/nginx --with-http_flv_module

(此处可根据实际情况自己修改)

make && make install

2)、安装yamdi

yadmi的作用是为flv文件添加关键帧,才能实现拖动播放

wget http://sourceforge.net/projects/yamdi/files/yamdi/1.4/yamdi-1.4.tar.gz/download

tar xzvf yamdi-1.4.tar.gz

cd yamdi-1.4

make && make install

使用方法:yamdi -i input.flv -o out.flv

给input.flv文件添加关键帧,输出为out.flv文件

3)、配置nginx

vi /usr/local/nginx/conf/nginx.conf 添加以下内容(根据自身情况修改):

user  www www;

worker_processes 30;

error_log  /usr/local/nginx/logs/error.log  crit;

pid        /usr/local/nginx/logs/nginx.pid;

events {

use epoll;

worker_connections      65535;

}

http {

include       mime.types;

default_type  application/octet-stream;

log_format main  '$remote_addr - $remote_user [$time_local] '

'"$request" $status $bytes_sent '

'"$http_referer" "$http_user_agent" '

'"$gzip_ratio"';

keepalive_timeout  60;

server_names_hash_bucket_size  128;

client_header_buffer_size    32k;

large_client_header_buffers  4 32k;

access_log off;

gzip on;

gzip_min_length  1100;

gzip_buffers     4 8k;

gzip_types       text/plain;

output_buffers   1 32k;

postpone_output  1460;

client_header_timeout  3m;

client_body_timeout    3m;

send_timeout           3m;

sendfile                on;

tcp_nopush              on;

tcp_nodelay             on;

######################################################################

server {

listen       80;

server_name  flv.centos.bz

;

root    /home/www/flv;

limit_rate_after 5m;    ####下载了5M以后开始限速

limit_rate 512k;         ####速度限制为512K

index   index.html;

charset utf-8;

location ~ \.flv {

flv;

}

error_page   500 502 503 504  /50x.html;

location = /50x.html {

root   html;

}

}

}

4)、基本上已经设置完毕,但是此时我们测试的时候还需要一个支持拖拽播放的flash播放器,开源的JW Player就可以实现这样的功能,我将编译的播放器上传上来,供大家下载:

下载链接:http://blogimg.chinaunix.net/blog/upfile2/100607142612.rar

下载播放器后,上传到上面设置的/home/www/flv/

目录下,把flv视频文件也放到该目录下!

5)、启动nginx后测试:

http://flv.centos.bz/player.swf?type=http&file=test1.flv

说明:#我的ip是192.168.1.116

#player.swf是我的JW Player播放器

#http是表示居于http分发方式

#test1.flv是我的flv视频文件

FLV视频发布方式简介

FLV视频有两总发布方式

HTTP方式

这种方式要下载FLV视频文件到本地播放,一旦FLV视频文件下载完成,就不会消耗服务器的资源和带宽,但是拖动功能没有RTMP/RTMP流媒体方式强大,很多视频网站都是用HTTP方式实现的,如:YouTube,土豆,酷6等

RTMP/RTMP流媒体方式

这种方式不用下载FLV视频文件到本地,可以实时的播放flv文件,可以任意拖拽播放进度条,但是比较消耗服务器的资源,

 

使用nginx来搭建flv流媒体服务器

1、使用nginx来搭建flv流媒体服务器简介

nginx中的Flv Stream模块能实现flv流媒体的功能,而且支持flv视频进度条拖拽,另外nignx还可以作为方向代理服务器代理后端基于Flash Media Server或者Red5的RTMP/RTMP流媒体服务器

 

下面我们就来搭建一个完整的nginx流媒体服务器

1)、Nginx服务器的安装

#安装zlib

wget  http://www.imagemagick.org/download/delegates/zlib-1.2.7.tar.gz

tar xzvf zlib-1.2.7.tar.gz

cd zlib-1.2.7

./configure

make && make install

#安装pcre

wget http://ftp.exim.llorien.org/pcre/pcre-8.12.tar.gz

tar zxvf pcre-8.12.tar.gz

cd pcre-8.12

./configure --prefix=/usr/local/pcre

make && make install

#安装nginx

groupadd www

useradd -g www www

mkdir -p /home/www/flv

chown -R www:www /home/www/flv

wget http://nginx.org/download/nginx-.tar.gz

tar xzvf nginx-1.0.1.tar.gz

cd nginx-1.0.1

./configure --with-http_ssl_module --with-pcre=/root/pcre-8.12 --with-zlib=/root/zlib-1.2.7 

--user=www --group=www --prefix=/usr/local/nginx --with-http_flv_module

(此处可根据实际情况自己修改)

make && make install

2)、安装yamdi

yadmi的作用是为flv文件添加关键帧,才能实现拖动播放

wget http://sourceforge.net/projects/yamdi/files/yamdi/1.4/yamdi-1.4.tar.gz/download

tar xzvf yamdi-1.4.tar.gz

cd yamdi-1.4

make && make install

使用方法:yamdi -i input.flv -o out.flv

给input.flv文件添加关键帧,输出为out.flv文件

3)、配置nginx

vi /usr/local/nginx/conf/nginx.conf 添加以下内容(根据自身情况修改):

user  www www;

worker_processes 30;

error_log  /usr/local/nginx/logs/error.log  crit;

pid        /usr/local/nginx/logs/nginx.pid;

events {

use epoll;

worker_connections      65535;

}

http {

include       mime.types;

default_type  application/octet-stream;

log_format main  '$remote_addr - $remote_user [$time_local] '

'"$request" $status $bytes_sent '

'"$http_referer" "$http_user_agent" '

'"$gzip_ratio"';

keepalive_timeout  60;

server_names_hash_bucket_size  128;

client_header_buffer_size    32k;

large_client_header_buffers  4 32k;

access_log off;

gzip on;

gzip_min_length  1100;

gzip_buffers     4 8k;

gzip_types       text/plain;

output_buffers   1 32k;

postpone_output  1460;

client_header_timeout  3m;

client_body_timeout    3m;

send_timeout           3m;

sendfile                on;

tcp_nopush              on;

tcp_nodelay             on;

######################################################################

server {

listen       80;

server_name  flv.centos.bz

;

root    /home/www/flv;

limit_rate_after 5m;    ####下载了5M以后开始限速

limit_rate 512k;         ####速度限制为512K

index   index.html;

charset utf-8;

location ~ \.flv {

flv;

}

error_page   500 502 503 504  /50x.html;

location = /50x.html {

root   html;

}

}

}

4)、基本上已经设置完毕,但是此时我们测试的时候还需要一个支持拖拽播放的flash播放器,开源的JW Player就可以实现这样的功能,我将编译的播放器上传上来,供大家下载:

下载链接:http://blogimg.chinaunix.net/blog/upfile2/100607142612.rar

下载播放器后,上传到上面设置的/home/www/flv/

目录下,把flv视频文件也放到该目录下!

5)、启动nginx后测试:

http://flv.centos.bz/player.swf?type=http&file=test1.flv

说明:#我的ip是192.168.1.116

#player.swf是我的JW Player播放器

#http是表示居于http分发方式

#test1.flv是我的flv视频文件

© 著作权归作者所有

mind-blowing
粉丝 51
博文 218
码字总数 112809
作品 0
宝山
运维
私信 提问
nginx搭建视频服务器

nginx搭建mp4、flv流媒体服务器 一、FLV视频发布方式简介   FLV视频有两总发布方式   1、 HTTP方式   这种方式要下载FLV视频文件到本地播放,一旦FLV视频文件下载完成,就不会消耗服务...

hbssliulei
2013/12/15
0
0
nginx轻松搭建自己的flv流媒体服务器

nginx搭建flv流媒体服务器 <!--[if !supportLists]-->一、<!--[endif]-->FLV视频发布方式简介 FLV视频有两总发布方式 <!--[if !supportLists]-->1、 <!--[endif]-->HTTP方式 这种方式要下载F......

frankgao
2011/01/21
2.6K
2
nginx+ ffmpeg 实现 hls直播和点播

一、搭建http服务器: ./configure --add-module=/home/andrew/Work/tools/nginx-rtmp-module --with-httpdavmodule --without-httprewritemodule make && make install /usr/local/nginx/sb......

andrew810810
2016/05/17
1K
0
Nginx和Nginx+的比较(下)

版权声明:本文为博主chszs的原创文章,未经博主允许不得转载。 https://blog.csdn.net/chszs/article/details/50440778 Nginx和Nginx+的比较(下) 作者:chszs,未经博主允许不得转载。经许可...

chszs
2015/12/31
0
0
EasyDSS RTMP流媒体服务器是怎样炼成的:Easy而且更加互联网!

开发EasyDSS的初衷 自从12年开始做EasyDarwin的时候,当时眼光一直都仅仅局限在安防监控视频这一块,对RTMP没有太大的重视,对于后起之秀HLS更是没有太多关注,然而经历了15直播火热的发展,...

xiejiashu
2017/12/09
0
0

没有更多内容

加载失败,请刷新页面

加载更多

OSChina 周六乱弹 —— 早上儿子问我他是怎么来的

Osc乱弹歌单(2019)请戳(这里) 【今日歌曲】 @凉小生 :#今日歌曲推荐# 少点戾气,愿你和这个世界温柔以待。中岛美嘉的单曲《僕が死のうと思ったのは (曾经我也想过一了百了)》 《僕が死の...

小小编辑
今天
1K
12
Excption与Error包结构,OOM 你遇到过哪些情况,SOF 你遇到过哪些情况

Throwable 是 Java 中所有错误与异常的超类,Throwable 包含两个子类,Error 与 Exception 。用于指示发生了异常情况。 Java 抛出的 Throwable 可以分成三种类型。 被检查异常(checked Exc...

Garphy
今天
20
0
计算机实现原理专题--二进制减法器(二)

在计算机实现原理专题--二进制减法器(一)中说明了基本原理,现准备说明如何来实现。 首先第一步255-b运算相当于对b进行按位取反,因此可将8个非门组成如下图的形式: 由于每次做减法时,我...

FAT_mt
昨天
13
0
好程序员大数据学习路线分享函数+map映射+元祖

好程序员大数据学习路线分享函数+map映射+元祖,大数据各个平台上的语言实现 hadoop 由java实现,2003年至今,三大块:数据处理,数据存储,数据计算 存储: hbase --> 数据成表 处理: hive --> 数...

好程序员官方
昨天
20
0
tabel 中含有复选框的列 数据理解

1、el-ui中实现某一列为复选框 实现多选非常简单: 手动添加一个el-table-column,设type属性为selction即可; 2、@selection-change事件:选项发生勾选状态变化时触发该事件 <el-table @sel...

everthing
昨天
11
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部