直播流RTMP 知识
分享直播相关知识点:
http://blog.csdn.net/kingroc/article/details/50839994
#!/bin/bash
# Order Finish Startup
# it is v.0.0.2 version.
# chkconfig: - 85 15
# description: Socket Sign Handler
# processname: nginx
echo -e "NGINX安装流媒体扩展RTMP开始 :host_ip"
echo -e ""
#访问IP地址(正式环境的访问地址)
host_ip="https://127.0.0.1"
#设置总执行时间5分钏
alltime=300;
#休息时间长-5分钟内执行2~3次
step=100
echo -e ""
echo "====================================================="
echo "Congratulations on your RTMP Install Host : ${host_ip}"
echo "====================================================="
echo -e ""
#编绎安装过程
echo -e ""
cd nginx-1.8.1
./configure --prefix=/usr/local/nginx --add-module=../nginx-rtmp-module-master --with-http_ssl_module
make && make install
#启动端口打开文件(使用1935端口)
vim /etc/sysconfig/iptables
#添加一行
-A RH-Firewall-1-INPUT -m state --state NEW -m tcp -p tcp --dport 1935 -j ACCEPT
#重启防火墙
service iptables restart
#配置相关的端口
netstat -tlun
#NGINX 配置协议
rtmp_auto_push on;
rtmp_auto_push_reconnect 1s;
rtmp {
server {
listen 1935;
application vod{
#播放视频时,查找文件的路径
play /usr/local/nginx/html/flv;
}
application live {
live on;
max_connections 1024;
#record video; #只录视频
record all; #视频音频同时录制
#exec_record_done /usr/local/nginx/sbin/operator_record.py $path $addr;
#exec_record_done, 视频文件录制完成后,进行的数据库类操作
record_unique off;
#record_path /tmp/flv;
#录制视频时,视频文件生成保存的路径
record_path /usr/local/nginx/html/flv;
}
}
}
######========================================================================================================
#RTMP 线上服务器配置流媒体上传(备份代码)
#rtmp_auto_push on;
#rtmp_auto_push_reconnect 1s;
rtmp {
server {
listen 1935;
application vod{
#播放视频时,查找文件的路径
play /usr/local/nginx/html/flv;
}
application live{
live on;
max_connections 1024;
#record video; #只录视频
record all; #视频音频同时录制
record_suffix .mp4; #支持多种格式
access_log logs/rtmp_access.log;
#recorder video{ record audio; }
#exec_record_done, 视频文件录制完成后,进行的数据库类操作
exec_record_done /usr/local/nginx/html/config/rt_water.sh $path $basename;
record_unique off;
#录制视频时,视频文件生成保存的路径
record_path /usr/local/nginx/html/flv;
exec_kill_signal term;
}
}
}
######========================================================================================================
####安装FFMPEG####
#从repo导入GPG密钥:
rpm --import http://packages.atrpms.net/RPM-GPG-KEY.atrpms
#安装ATRPMS Repo:
rpm -ivh http://dl.atrpms.net/all/atrpms-repo-6-7.el6.x86_64.rpm
#Ffmpeg需要libdc1394-devel,它在epel库中可用。 执行以下命令安装epel存储库:
rpm -Uvh http://dl.fedoraproject.org/pub/epel/7/x86_64/e/epel-release-7-9.noarch.rpm
#从ATRPMS安装FFMpeg存储库:yum -y --enablerepo=atrpms install ffmpeg ffmpeg-devel
yum -y --enablerepo=atrpms install ffmpeg ffmpeg-devel
#版本
ffmpeg -version
#生成水印
ffmpeg -i html/flv/20170731204517649162.flv -i watermark.png -filter_complex "overlay=x=(main_w-overlay_w)/2:y=(main_h-overlay_h)/2" shiiiii.flv
#MP4加水印(加参数 -strict -2 )
ffmpeg -i html/flv/20170731221241722162.mp4 -i html/flv/123.png -strict -2 -filter_complex "overlay=x=(main_w-overlay_w)/2:y=(main_h-overlay_h)/3" html/flv/shiiiii3.mp4
ffmpeg -i /usr/local/nginx/html/flv/2017082117163622150113.mp4 -i /usr/local/nginx/html/flv/img/water.png -strict -2 -filter_complex "overlay=x=(main_w-overlay_w)/2:y=(main_h-overlay_h)/3" /usr/local/nginx/html/flv/20170821/2017082117163622150113.mp4
#接收流
./ffmpeg -i rtmp://192.168.1.232:1935/live/zhut -acodec copy -vcodec copy -f flv -y /usr/local/src/test.flv
#生成水印脚本加载
application myapp {
live on;
exec /var/scripts/exec_wrapper.sh $name;
exec_kill_signal term;
}
#exec /usr/local/nginx/html/config/rt_water.sh $name $path;
#######参数补充说明:
#### $name 文件名($basename) == 20170801123625987162
#### $addr 客户IP == 119.145.5.126
#### $path 文件地址 == /usr/local/nginx/html/flv/20170801123625987162.mp4
#### $filename 文件名带后缀 == 20170801123625987162.mp4
#暂停1秒
sleep 1s
echo -e ""
echo -e "Start clearUsers | lostBlackOrder"
echo -e ""
#每2分钟执行一次
for((i=0;i<alltime;i=(i+step)));do
echo -e ""
curl -k "${host_ip}/index.php?controller=flush&action=clearUsers&type=today";
curl -k "${host_ip}/index.php?controller=flush&action=lostBlackOrder&type=today";
echo -e "Once Finish ====== Sleep(${step}) Seconds"
echo -e ""
#休眠时间
sleep $step
done
echo -e "All Finish ======UPDATE"
sleep 1s
#结束
echo -e ""
echo "====================================================="
echo "Finish Handler , Total Time = ${alltime} 秒 ---END "
echo "====================================================="
echo -e ""
###编译安装PHP的Swool扩展;phpize
DOWNLOAD: wget http://pecl.php.net/get/swoole-1.9.3.tgz
# tar zxvf swoole-1.7.6-stable.tar.gz
# cd swoole-1.7.6-stable
# phpize
# ./configure --with-swoole --with-php-config=/usr/local/php/bin/php-config
# make && make install**
//ext_dir == swoole.so
extension_dir=/usr/local/php/lib/php/extensions/no-debug-non-zts-20131226/
服务端:命令
/usr/local/php/bin/php /usr/local/nginx/html/web/socket/server.php
直播流RTMP 知识的更多相关文章
- 移动端videojs视频插件使用直播流rtmp、hls、http-flv的注意事项
可以访问:https://videojs.com/ 下载对应的脚本包 特别注意的是 移动端videojs一般应用的直播流协议为HLS, RTMP协议一般是PC上使用,需要flash支持. HLS直播源 ...
- 抛开flash,自己开发实现C++ RTMP直播流播放器
抛开flash,自己开发实现C++ RTMP直播流播放器 众所周知,RTMP是以flash为客户端播放器的直播协议,主要应用在B/S形式的场景中.本人研究并用C++开发实现了RTMP直播流协议的播放器 ...
- 实现输出h264直播流的rtmp服务器
RTMP(Real Time Messaging Protocol)是常见的流媒体协议,用来传输音视频数据,结合flash,广泛用于直播.点播.聊天等应用,以及pc.移动.嵌入式等平台,是做流媒体开发 ...
- 实现输出h264直播流的rtmp服务器 flash直播服务器【转】
实现输出h264直播流的rtmp服务器 RTMP(Real Time Messaging Protocol)是常见的流媒体协议,用来传输音视频数据,结合flash,广泛用于直播.点播.聊天等应用,以及 ...
- 实现输出h264直播流的rtmp服务器 flash直播服务器
http://www.cnblogs.com/haibindev/archive/2012/04/16/2450989.html 实现输出h264直播流的rtmp服务器 RTMP(Real Time ...
- 搭建rtmp直播流服务之4:videojs和ckPlayer开源播放器二次开发(播放rtmp、hls直播流及普通视频)
前面几章讲解了使用 nginx-rtmp搭建直播流媒体服务器; ffmpeg推流到nginx-rtmp服务器; java通过命令行调用ffmpeg实现推流服务; 从数据源获取,到使用ffmpeg推流, ...
- 实时监控、直播流、流媒体、视频网站开发方案流媒体服务器搭建及配置详解:使用nginx搭建rtmp直播、rtmp点播、,hls直播服务配置详解
注意:这里不会讲到nginx流媒体模块如何安装的问题,只研究rtmp,hls直播和录制相关的nginx服务器配置文件的详细用法和说明.可以对照这些命令详解配置nginx -rtmp服务 一.nginx ...
- 搭建rtmp直播流服务之3:java开发ffmpeg实现rtsp转rtmp并实现ffmpeg命令的接口化管理架构设计及代码实现
上一篇文章简单介绍了java如何调用ffmpeg的命令:http://blog.csdn.net/eguid_1/article/details/51777716 上上一篇介绍了nginx-rtmp服 ...
- 搭建rtmp直播流服务之2:使用java实现ffmpeg命令接口化调用(用java执行ffmpeg命令)
欢迎大家积极开心的加入讨论群 群号:371249677 (点击这里进群) 一.环境搭建 1.安装ffmpeg 下载对应系统的ffmpeg安装包,个人采用windows平台进行开发,所以安装了windo ...
随机推荐
- CSS 图像高级 Css Sprites
上节课中我们学习了背景图像,这节课我们学习背景图像的高级知识,如Css Sprites,CSS 背景渐变等. Css Sprites Css Sprites,国内也叫CSS精灵.它的原理是将许多的小图 ...
- el-input的color修改无效问题
相信很多前端初学者跟我一样也遇到过el-input的color修改无效问题 如下图:我想把el-input里面的文字改成蓝色,但是使用总是失败 修改方法:打开调试界面,找到el-input对应的sty ...
- 利用Access-Control-Allow-Origin响应头解决跨域请求原理
传统的跨域请求没有好的解决方案,无非就是jsonp和iframe,随着跨域请求的应用越来越多,W3C提供了跨域请求的标准方案(Cross-Origin Resource Sharing).IE8.Fi ...
- 使用scrapy中xpath选择器的一个坑点
情景如下: 一个网页下有一个ul,这个ur下有125个li标签,每个li标签下有我们想要的 url 字段(每个 url 是唯一的)和 price 字段,我们现在要访问每个li下的url并在生成的请求中 ...
- 原型设计工具—Axure
作为软件设计的一员,需要在软件开发初期确保软件的具体内容,防止后期大幅度的修改. 在这样的情况下,原型设计软件就起到了关键的作用. 摘要: 原型设计为什么这么重要呢? 因为它帮助我们搭建了低保真或高保 ...
- input下拉框
用Html5和css.js写的,引用的bootstrap和jquery文件请各位看客自己去下载
- Kubernetes 1.3.1 快速单机部署
Kubernetes发展到今天, 在官网上已经有非常多的成熟部署方案, 但是由于墙的原因, 最简单的MiniKube都无法进行, 参考了以下两篇文章后, 终于安装成功. k8s-1.13版本测试环境搭 ...
- boost中Function和Lambda的使用
:first-child { margin-top: 0px; } .markdown-preview:not([data-use-github-style]) h1, .markdown-previ ...
- centos服务器监控 服务器虚拟机里面的客户端zabbix-agent安装
开启zabbix要用的端口, 也可以关闭服务器的防火 [html] view plain copy #vim /etc/sysconfig/iptables -A INPUT -m state --s ...
- python基础之Day14
一.生成器 1.什么是生成器 在函数内但凡出现yield关键字,再调用函数就不会执行函数体代码,会返回一个值,该值称之为生成器,生成器本质就是迭代器 2.为什么要有生成器 生成器是一种自定义迭代器的方 ...