实现简单网页rtmp直播:nginx+ckplayer+linux

ShoppingChen 2020-05-11

一、安装nginx

安装带有rtmp模块的nginx服务器(其它支持rtmp协议的流媒体服务器像easydarwin、srs等+Apache等web服务器也可以),此处使用nginx服务器,简单方便。

安装请参考我的CSDN:nginx安装,经过多次安装实践,此方法适用于rhel和centos系统,ubuntu可能会不适用,如果安装过程中出现大量错误,请另行百度安装方法。

不一定非要使用云服务器,可以自己使用vmware虚拟一个linux系统,就可以在同一台电脑上实现整套流程,不过是局域网,和广域网可能还有部分差异,但是大同小异,流程都是差不多的,简单使用的话,用vmware的方式就够了。注意需要关闭防火墙或者通行相关端口。

二、推流

推流在此我使用的是ffmpeg,ffmpeg虽然是一个开源软件,但是功能很多也很强大(一般开源软件性能都不是很强,只是让你入门学习使用),此处用它绰绰有余。ffmpeg官网有不用自己编译的版本,也可以自己动手编译下,锻炼下自己动手的能力,此处就不放windows版本的了,之前自己动手编译过一个linux版本的,不想自己动手的可以去这里CSND下载

推流命令:

while(1) { .\ffmpeg.exe -re -i F:\ChengTongPan\MangZhong.mp4 -vcodec copy -acodec copy -f flv rtmp://x.x.x.x:xxxx/live/room }

ffmpeg自带的循环推流在这里不能使用,只能使用一个简陋的循环推流。

三、选择播放方式

这里使用ckplayer的方式,此方式会依赖flash,过后我会尝试寻找不依赖flash的方式,据了解,html5已经可以不依赖falsh实现rtmp协议视频播放,待以后探索。。

编辑index.html,在网上找了一个别人的:

<!DOCTYPE html>
<html>

    <head>
        <meta charset="UTF-8">
        <title>ckplayer</title>
        
        <style type="text/css">
            body {
                margin: 0;
                padding: 0px;
                font-family: "Microsoft YaHei", YaHei, "微软雅黑", SimHei, "黑体";
                font-size: 18px;
            }
            p{
                padding-left: 2em;
            }
        </style>

    </head>

    <body>
        <div id="video" style="width: 100%; height: 400px;max-width: 600px;">
        </div>
        <script type="text/javascript" src="ckplayer/ckplayer.js" charset="UTF-8"></script>
        <script type="text/javascript">
            var videoObject = {
                container: ‘#video‘, //容器的ID或className
                variable: ‘player‘, //播放函数名称
                //loop: true, //播放结束是否循环播放
                autoplay: true,//是否自动播放
                poster: ‘material/poster.jpg‘, //封面图片
                preview: { //预览图片
                    file: [‘material/mydream_en1800_1010_01.png‘, ‘material/mydream_en1800_1010_02.png‘],
                    scale: 2
                },
                //flashplayer:true,
                //live:true,
                //debug:true,
                //video:‘rtmp://58.200.131.2:1935/livetv/hunantv‘ 此链接是网络流,可以测试使用,可以替换为你自己的rtmp流地址
                video:‘rtmp://ip+port/live/room‘
            };
            var player = new ckplayer(videoObject);
        </script>
    </body>

</html>

下载ckplayer,百度一大堆,好像没找到上传附件的方式,此处就先不放了。。。

下载解压ckplayer到nginx的根目录下,应该是在/usr/local/nginx/html下面,不是在这里的自己找一下自己的根目录在哪就好了。

四、播放测试:

找到一个带有flash插件的浏览器,打开nginx下的html文件即可播放,我的是http://x.x.x.x/ckplayer,打开后如下:

实现简单网页rtmp直播:nginx+ckplayer+linux

 至此,rtmp协议的简单直播服务就搭建完成了。

相关推荐