JW Player 使用 RTMP 流



         简介
        RTMP ( Real Time Messaging Protocol 实时消息传输协议) 是一个用于将点播和直播媒体交付给 Adobe Flash 应用 (比如 JW Player) 的体系。RTMP 支持 MP4 和 FLV 视频,AAC 和 MP3 音频。RTMP 相对于一般的 HTTP 视频下载 (很多网站使用这种方式进行在线视频播放) 具有以下优势:
  • RTMP 可以进行视频直播,人们可以在你录制的同时观看视频。
  • RTMP 可以做动态流,播放视频的质量可以根据带宽而自动变化。
  • 播放器可以快进到视频的后面部分,这对于大于十分钟的视频很有用 (这一点是 HTTP 下载方式的在线视频无法匹敌的)。
  • 播放器维护有一个小小的缓冲,避免了视频回放时的重新下载,节省了带宽。
         缺点
        但是,请注意 RTMP 也有自身的缺点,最重要的几个是:
  • RTMP 使用了跟 HTTP 不同的协议和端口号,这使得它很容易遭受 (公司) 防火墙的封堵。可以使用 RTMPT (通过 HTTP 通道) 避免这个问题,但这需要服务器付出一定的性能代价。
  • RTMP 数据被流化后传给播放器,这意味着连接的带宽必须要比视频的数据速率大。如果连接中止了几秒,流将卡住。这个问题在很大问题上可以使用包含一个低质量文件的动态流来进行预防。

        最大的缺点是 RTMP 只能工作在 Flash 而不能工作在 HTML5。新的 HTTP 流协议,比如苹果的 HTTP Live Streaming (HLS),具有更广泛的设备支持 (比如 iOS),在未来的几年内很可能会取代 RTMP。JW Player 在 Flash 和 HTML5 模式下都能够支持苹果 HLS


         服务器支持
        要使用 RTMP,你的主机或者 CDN 需要安装一个专用 RTMP 服务器。这里有两个主流产品,JW Player 都支持:
  • Wowza Media Server 是当前最广泛采用的解决方案。它包含了支持几乎所有的流媒体协议,包括 RTMP。Wowza 3 引入了对 JW6 SMIL manifest 的专用支持 (看下文)。
  • Adobe Media Server 是另外一个很好地选择。因为 Flash 是由 Adobe 开发的,RTMP 的新功能首先会在 FMS 上跑的通。
         CDNS
        以下 CDN (Content Delivery Networks 内容分发网络) 能够支持 RTMP,并且使用 JW Player 测试效果良好。它们都支持 动态流,除了 CloudFront,也都支持现场 直播
         现场直播
        RTMP 的一个关键的特征就是能够进行现场直播,比如展示会,音乐会或者体育赛事。在 JW Player 和一台 RTMP 服务器之后,你还需要一个小工具来将直播视频提取给服务器。有很多这样的工具可供选择。 Flash Live Media Encoder 就是这样的一个免费的,可以用于 Windows 和 Mac 的工具。
        对于 FMS 和 Wowza,嵌入直播流的方式和嵌入点播的方式一样。但是,对于 Akamai、Edgecast 和 Limelight 等 CDN 要求播放器订阅到直播流。JW Player 6 支持这种机制
        JW Player 6 将会像嵌入一个点播文件一样嵌入一个直播流,但有个例外:取代显示在时间轴上的滑块 (直播嘛) 的是播放器在控制条上显示时间的标题。
         负载均衡
        对于大规模的部署,JW Player 为支持服务器的负载均衡提供了三个机制:
  • DNS 负载均衡,独立于 JW Player。
  • RTMP 302 重定向,被 Wowza 用于负载均衡。更多信息参考他们的用户指南。
  • SMIL 负载均衡,包含 RTMP 链接到边缘节点的一个初始化 SMIL 文件。可以参见下面关于 SMIL 文件动态流的例子。
         隐藏字幕
        JW Player 支持 RTMP 直播和点播的字幕隐藏。只支持一个单一的 CC 轨道,而且这个轨道必须是 TX3G 格式的。Wowza 和 Adobe media server 都有能力使用 RTMP 发送 TX3G 字幕。

        JW Player 第一次遭遇一个文本提示的 TX3G 时,它在控制条中放置了一个 CC 按钮。如果用户选择启用 CC,这一偏好会被保存在 cookie,用户以后观看任何视频时 CC 都会是启用状态。


         嵌入一个流
        嵌入一个 RTMP 流到 JW Player 6 只是简单提供一个完整流 URL 的问题。这里是一个很基本的例子,播放一个 MP4 视频:
[javascript]  view plain copy print ? 在CODE上查看代码片 派生到我的代码片
  1. jwplayer("myElement").setup({  
  2.     file: "rtmp://example.com/application/mp4:myVideo.mp4",  
  3.     image: "/assets/myVideo.jpg",  
  4.     height: 360,  
  5.     width: 640  
  6. });  


        以上例子仅仅工作在桌面上,因为 Flash 在移动终端不可用。下面是另一个例子,使用 RTMP 和 HTTP 加载的一个 MP4。RTMP 流将会在桌面播放,下载的 HTTP 将会在移动终端播放:
[javascript]  view plain copy print ? 在CODE上查看代码片 派生到我的代码片
  1. jwplayer("myElement").setup({  
  2.     playlist: [{  
  3.         image: "/assets/myVideo.jpg",  
  4.         sources: [{   
  5.             file: "rtmp://example.com/application/mp4:myVideo.mp4"  
  6.         },{  
  7.             file: "/assets/myVideo.mp4"  
  8.         }]  
  9.     }],  
  10.     height: 360,  
  11.     primary: "flash",  
  12.     width: 640  
  13. });  


        因为 主要呈现模式设置为  Flash,RTMP 流被选中。如果这一选项没有设置,JW Player 将会播放 HTTP 下载,因为很多浏览器 (比如 Chrome、IE)在 HTML5 中支持那个 (JW6 中的默认模式)。
        参见  Working with Playlists 以获取关于加载多路源的更多信息。
         应用和流
        技术上讲,一个 RTMP 流包含两块:
  • 应用路径 (例如rtmp://example.com/vod/)。
  • 标识 (例如mp4:myFolder/video.mp4)。
        JW Player 6 中,这两块被整合到单个 URL。JW Player 根据  mp4flv 或者  mp3 前缀的位置来决定应用和流之间的分割。
        1. MP4/M4V/MOV/F4V 视频需要一个  mp4: 前缀:
[plain]  view plain copy print ? 在CODE上查看代码片 派生到我的代码片
  1. rtmp://example.com/vod/mp4:myFolder/myVideo.mp4  

        2. FLV 视频或者一个直播流 (FLV 容器下的) 需要一个  flv: 前缀:
[plain]  view plain copy print ? 在CODE上查看代码片 派生到我的代码片
  1. rtmp://example.com/vod/flv:myFolder/myVideo.flv  
  2. rtmp://example.com/live/flv:myFolder/myLiveStream  

        3. MP3 音频需要一个  mp3: 前缀:
[plain]  view plain copy print ? 在CODE上查看代码片 派生到我的代码片
  1. rtmp://example.com/vod/mp3:myFolder/mySong.mp3  

        4. M4A/F4A/AAC 音频文件也需要一个  mp4: 前缀:
[plain]  view plain copy print ? 在CODE上查看代码片 派生到我的代码片
  1. rtmp://example.com/vod/mp4:myFolder/mySong.m4a  

        如果没有找到任何前缀,player 在文件名最后一个 / 之后对应用和流进行分割。前缀随后被自动添加 (mp4:mp3:)。注意flv 前缀并不被 Wowza/Adobe 服务器内部使用,因此 JW Player 将在请求流之前将其剥离。


         动态流
        除了加载单一 RTMP 流之外,JW Player 6 支持加载动态流。一个 动态流包含多个具有同一内容的单流,它们具有不同的品质。JW Player 允许在这样一个流中进行不同品质的自动或者手工切换。
        动态流必须使用叫做 SMIL manifest 设置。这是一些包含有 RTMP 应用路径加上存放在 RTMP 服务器上的流的路径的简单的 XML 文件。播放器经常假定一个带有 .smil 后缀的文件是一个 RTMP SMIL manifest:
[javascript]  view plain copy print ? 在CODE上查看代码片 派生到我的代码片
  1. jwplayer("myElement").setup({  
  2.     file: "/assets/myVideo.smil",  
  3.     image: "/assets/myVideo.jpg",  
  4.     height: 360,  
  5.     width: 640  
  6. });  

        这是另一个例子,使用了一个 RTMP 动态流 (为桌面) 和一个渐进 MP4 下载 (为移动终端):
[javascript]  view plain copy print ? 在CODE上查看代码片 派生到我的代码片
  1. jwplayer("myElement").setup({  
  2.     playlist: [{  
  3.         image: "/assets/myVideo.jpg",  
  4.         sources: [{   
  5.             file: "/assets/myVideo.smil"   
  6.         },{  
  7.             file: "/assets/myVideo.mp4"   
  8.         }]  
  9.     }],  
  10.     height: 360,  
  11.     primary: "flash",  
  12.     width: 640  
  13. });  

        注意 SMIL manifest 是  跨域安全限制 的主题。如果你的 SMIL 文件位于你的网站或播放器之外的另一台服务器上,你需要去设置一个 crossdomain.xml 文件。
         SMIL 内容
        这是一个基本的例子,使用了三个不同的流:
[html]  view plain copy print ? 在CODE上查看代码片 派生到我的代码片
  1. <smil>  
  2.   <head>  
  3.     <meta base="rtmp://example.com/vod/" />  
  4.   </head>  
  5.   <body>  
  6.     <switch>  
  7.       <video src="myVideo-high.mp4" height="720" system-bitrate="2000000" width="1280" />  
  8.       <video src="myVideo-medium.mp4" height="360" system-bitrate="800000" width="640" />  
  9.       <video src="myVideo-low.mp4" height="180" system-bitrate="300000" width="320" />  
  10.     </switch>  
  11.   </body>  
  12. </smil>  

        品质的切换由 JW Player 自动完成,它将选用最高品质:
  • 谁的 system-bitrate 更适合连接的当前带宽。
  • 谁的 width 更适合播放器屏幕的当前宽度。
        用户可以通过设置快捷菜单中的品质对这些自动选项进行重写。manifest 中的 关于流的 height 属性用于设置菜单的标签 (例如  720p)。
         WOWZA 3
        Wowza Media Server 3 为这些 SMIL manifest 引入了专门的支持。如果你在运行 3.1.2.15 或更高版本的 Wowza,在你适配的流的 URL 后面添加 /jwplayer.smil 来得到这些 manifest。
        这里是 Wowza3 中 SMIL manifest 和 M3U8 manifest 的 URL 的样子:
[plain]  view plain copy print ? 在CODE上查看代码片 派生到我的代码片
  1. http://example.com/vod/smil:myvideo.smil/jwplayer.smil  
  2. http://example.com/vod/smil:myvideo.smil/manifest.m3u8  



         配置选项
        RTMP 提供了一些配置选项来对流的播放进行调整。它们设置在一个专用的  rtmp 选项块中。
         缓冲长度
        在默认情况下,JW Player 试着为 RTMP 视频维护一个长度为 3 秒的缓冲。这意味着有三秒钟的视频被从服务器端获取并随时可以播放。这个长度可以使用 RTMP bufferlength 选项进行修改:
[javascript]  view plain copy print ? 在CODE上查看代码片 派生到我的代码片
  1. jwplayer("myElement").setup({  
  2.     file: "rtmp://example.com/vod/mp4:myVideo.mp4",  
  3.     height: 360,  
  4.     image: "/assets/myVideo.jpg",  
  5.     rtmp: {  
  6.         bufferlength: 0.1  
  7.     },  
  8.     width: 640  
  9. });  

        可用值的范围是从  0.1 (对于低延时的直播) 到  10 (为防止频繁的重缓冲)。
         FC 订阅
        当使用 Akamai、Edgecast 或者 Limelight 等 CDN 分发直播流时,播放器不能简简单单地连接到直播流。播放器需要通过发送一个叫做 FC Subscribe 的调用到服务器进行订阅。JW Player 包含了对此的支持,使用 RTMP subscribe 选项:
[javascript]  view plain copy print ? 在CODE上查看代码片 派生到我的代码片
  1. jwplayer("myElement").setup({  
  2.     file: "rtmp://example.com/xxxx/myStream",  
  3.     height: 360,  
  4.     image: "/assets/myLivestream.jpg",  
  5.     rtmp: {  
  6.         subscribe: true  
  7.     },  
  8.     width: 640  
  9. });  

        注意这一个功能仅适用于单一 RTMP 流。对于多位率的直播流,应该使用 HLS 协议。
         安全令牌
        Wowza Media Server 具有一个叫做 安全令牌 (参考 《 使用安全令牌保护 RTMP 流》) 的特性,用于保护你的流被下载。它通过播放器发送给服务器一个令牌,然后服务器在开始发送流之前对令牌验证进行工作。JW Player 通过使用 RTMP securetoken 选项支持这一机制:
[javascript]  view plain copy print ? 在CODE上查看代码片 派生到我的代码片
  1. jwplayer("myElement").setup({  
  2.     file: "rtmp://example.com/vod/mp4:myVideo.mp4",  
  3.     height: 360,  
  4.     image: "/assets/myVideo.jpg",  
  5.     rtmp: {  
  6.         securetoken: "Kosif093n203a"  
  7.     },  
  8.     width: 640  
  9. });  

        注意我们不支持编译安全令牌的选项。SWF 通过提供了对 JS (它们都是客户端) 的安全增强,尤其是当 JS 代码有点混乱时。
原文链接: http://www.longtailvideo.com/support/jw-player/28854/using-rtmp-streaming/
### 回答1: 要将RTSP转换为RTMP以在网页上播放,可以借助媒体服务器进行转换。媒体服务器可以将RTSP接收并转发为RTMP,以便在网页上通过RTMP协议进行播放。 首先,需要建立一个媒体服务器,例如使用常用的开源媒体服务器软件,如Nginx-rtmp模块、Wowza Streaming Engine等。在这个服务器上进行配置和设置。 然后,需要将RTSP的地址发送给媒体服务器。可以在服务器的配置文件中指定RTSP的URL,并设置其作为输入源,接收RTSP。 接下来,媒体服务器会将接收到的RTSP转发为RTMP。可以设置转发规则,将RTSP的数据转发到指定的RTMP地址上。 最后,在网页上使用RTMP播放器,如JWPlayer、VideoJS等,通过指定RTMP的地址进行播放。可以在网页上插入播放器并设置其相关参数,包括RTMP地址,以实现RTMP转换后在网页上的播放。 通过以上步骤,RTSP可以成功转换为RTMP,并通过网页播放器在网页上进行播放。这样便实现了在网页上播放RTSP的需求。 ### 回答2: RTSP是实时传输协议,而RTMP是实时消息传输协议。在将RTSP转为RTMP以供网页播放时,可以通过以下步骤实现。 首先,使用一个中间服务器软件,例如Nginx或FFmpeg,来接收RTSP。这个服务器将充当RTSPRTMP之间的转换器。 其次,配置服务器软件以接收RTSP,并将其转换为RTMP。可以通过在配置文件中设置RTSP地址、端口号和转换方法来完成。 然后,将转换后的RTMP传送到网页播放器上。可以使用开源播放器,如JW Player或Video.js,在网页上嵌入播放器,并将RTMP作为播放源。 最后,通过将网页嵌入到网站的页面中,即可实现通过网页播放RTSP转换后的RTMP。这样,用户可以通过访问该网页,使用具有RTMP支持的网页播放器来观看RTSP。 总结来说,将RTSP转为RTMP以供网页播放需要一个中间服务器软件来完成转换,并使用开源播放器嵌入到网页上来播放转换后的RTMP。这样,用户可以通过访问网页来观看RTSP转换后的视频内容。 ### 回答3: 要将 RTSP 转为 RTMP 进行网页播放,可以通过以下步骤实现: 1. 安装媒体服务器:首先,需要安装一个支持 RTMP 协议的媒体服务器,如 Nginx、Wowza、Adobe Media Server 等。 2. 配置 RTMP 模块:在媒体服务器上,需要配置 RTMP 模块,以允许接收 RTMP 。 3. 获取 RTSP :从摄像头或其他 RTSP 源获取 RTSP 的 URL。 4. 转码 RTSP 使用转码工具(如FFmpeg)将 RTSP 转为 RTMP 。可以通过以下命令将 RTSP 转为 RTMP : ``` ffmpeg -i rtsp://ip_address:port/stream_name -c copy -f flv rtmp://ip_address:port/application/stream_name ``` 其中,`ip_address` 是服务器 IP 地址,`port` 是服务器端口号,`stream_name` 是的名称。 5. 链接 RTMP :将转码后的 RTMP 链接到媒体服务器上。例如,如果使用 Nginx 作为媒体服务器,可以在 Nginx 的配置文件中添加以下代码: ``` rtmp { server { listen 1935; application myapp { live on; push rtmp://ip_address:port/live/stream_name; } } } ``` 其中,`ip_address` 是服务器 IP 地址,`port` 是服务器端口号,`stream_name` 是的名称。 6. 网页播放:最后,在网页上使用支持 RTMP 协议的播放器来播放转码后的 RTMP 。你可以使用开源的播放器库,如 JWPlayer、Video.js 或 Flowplayer,通过将播放器配置为连接到 RTMP 的 URL 来实现播放。 通过以上步骤,可以将 RTSP 转为 RTMP ,并在网页上进行播放。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值