RTMP协议

目录简介概念rtmp协议握手过程rtmp通信过程简介RTMP协议是RealTimeMessageProtocol(实时信息传输协议)的缩写,它是由Adobe公司提出的一种应用层的协议,用来解决多媒体数据传输流的多路复用(Multiplexing)和分包(packetizing)的问题。     RTMP消息块流和RTMP一起适用于多样性音视频应用程序,从…

大家好,又见面了,我是你们的朋友全栈君。

目录

简介

概念

rtmp协议握手过程

rtmp通信过程


简介

RTMP协议是Real Time Message Protocol(实时信息传输协议)的缩写,它是由Adobe公司提出的一种应用层的协议,用来解决多媒体数据传输流的多路复用(Multiplexing)和分包(packetizing)的问题。          

RTMP消息块流和RTMP一起适用于多样性音视频应用程序,从一对一和一对 多向视频点播服务器直接广播到交互式会议应用程序。          

RTMP协议是应用层协议,是要靠底层可靠的传输层协议(通常是TCP)来保证信息传输的可靠性的。在基于传输层协议的链接建立完成后,RTMP协议也要客户端和服务器通过“握手”来建立基于传输层链接之上的RTMP Connection链接。

 

概念

有效负载:

          包含在每一个包中的数据,就像音视频样本或压缩后的视频数据。

包:

        一个数据包是由固定的包头和有效的负载数据来组成的。

端口:

      rtmp协议默认使用的是1935端口。

消息流:

      一个通信的逻辑通道,让消息流通

消息流id:

     每个消息拥有一个分配的id,标识消息流。

消息块:

    消息的一个片段,一个完整的消息会被分割成小的片段,每个片段都是一个消息块。

消息块流:

    一个通信的逻辑通道,允许消息块在一个特定方向流通,例如:从客户端到服务器。

消息块流id:

     每个消息块有一个分配的id用于识别跟随消息块流。

复合技术:

      把分开的音视频数据组合成一条音视频流的过程。

逆复合技术:

     复合的反向过程,交叉存取组装的音视频数据,是他们成为最初的音视频数据。

时间戳:

     在rtmp消息块中的时间戳使用整数来表示,但是为毫秒。时间戳必须是线性增加的,允许引用程序处理异步传输,带宽度量,检测,流控制。

 

rtmp协议握手过程

       要建立一个有效的rtmp连接,首先经过”握手”阶段,规则如下:

   RTMP协议

   客户端被指定依次向服务器发送C0,C1,C2三个chunk,服务器向客户端发送S0,S1,S2三个chunk。 详细发送要求:

  • 客户端开始发送C0,C1;
  • 客户端必须收到S1后,才发送C2;
  • 客户端必须收到S2后才开始发送其他信息(控制信息和音视频数据) 服务器要等收到C0才能发送S0和S1;
  • 服务器必须等C1后才能发送S2 服务器必须等收到C2之后才能发送其他数据(控制信息和音视频数据)

 

rtmp通信过程

简化如下:     

  • client–> server   : 发送一个创建流的请求  (C0、C1)。     
  • server–> client   : 返回一个流的索引号 (S0、S1、S2)。   
  •  client–> server   : 开始发送 (C2)    
  •  client–> server   : 发送音视频数据(这些包用流的索引号来唯一标识)

 

握手第一阶段:     

        C0和S0都是rtmp版本包,大小1字节                                                                  RTMP协议

        版本:8比特,C0:客户端需求的rtmp版本,S0:服务器选择的rtmp版本,如图:

RTMP协议

RTMP协议

握手第二阶段:

      客户端发送C1包,C1包大小1536字节,格式如下图:

     RTMP协议

      time:包含了一个时间戳,为了同步多个消息块流,     发送端会期望这个值是其他消息块的块流时间。 

C1:RTMP协议S2:RTMP协议 C2:RTMP协议

      服务器应答,发送S1包,S1数据和C1完全相同。

 

握手第三阶段:  

          客户端发送C2包:C2包,包大小1536字节,包格式如图:     

            RTMP协议

         时间:4byte,这个字段必须对应发送的时间戳(C2:S1, S2:C1);     时间2:4byte,这个包含先前的每一个包被读的时间戳,     以及1528字节。

 

握手完成

       消息分块:握手完成,复合多个消息分块,每个消息块有一个唯一分配的消息块流id,消息块流在网络上传输。 一个消息块发送完,才能发送下一个消息块。服务器接收完,基于消息块流id,复合成消息。

 

拆分的意义

     消息块格式:   

            消息块的默认大小128字节。通过set Chunk size 设置块的最大值。     格式如图:

         RTMP协议

 

参考:https://www.yuque.com/docs/share/6d5357b8-33a9-42e2-9b9d-6bf72805716a

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/124660.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 【原创】三星、镁光、海力士内存颗粒命名规则摘录

    【原创】三星、镁光、海力士内存颗粒命名规则摘录 

    2022年6月22日
    112
  • pycharm配置远程服务器_服务器asp环境配置

    pycharm配置远程服务器_服务器asp环境配置前言1、说明首先介绍下我本人情况,我在windows笔记本电脑上下载了Pycharm专业版,因为我本人只是用来跑代码,想把代码自动同步起来,因此特地通过pycharm来远程使用Linux上配置好的环境,加速代码运行。当然大家也可以使用Xshell等软件,使用命令行来操作。2、环境介绍目前使用的环境:Linux:20.04Pycharm:2019专业版Windows:64位Anaconda:Python3.7一、添加并设置部署1、点击Pycharm工作栏上方“Tools->

    2022年8月28日
    2
  • 从贝叶斯方法谈到贝叶斯网络语言_深度贝叶斯网络

    从贝叶斯方法谈到贝叶斯网络语言_深度贝叶斯网络从贝叶斯方法谈到贝叶斯网络0引言事实上,介绍贝叶斯定理、贝叶斯方法、贝叶斯推断的资料、书籍不少,比如《数理统计学简史》,以及《统计决策论及贝叶斯分析JamesO.Berger著》等等,然介绍贝叶斯网络的中文资料则非常少,中文书籍总共也没几本,有的多是英文资料,但初学者一上来就扔给他一堆英文论文,因无基础和语言的障碍而读得异常吃力导致无法继续读下去则是非…

    2022年10月19日
    3
  • pycharm使用技巧及常用快捷键_2010版excel快捷键大全

    pycharm使用技巧及常用快捷键_2010版excel快捷键大全本文对Pycharm常用快捷键进行了汇总整理,强烈建议你收藏学习,相信这些快捷键一定能提高你Python编程的效率。1.格式化代码【Ctrl+Alt+L】我们写代码的时候会发现…

    2022年8月28日
    4
  • SpringBoot整合SpringBatch

    SpringBoot整合SpringBatchSpringBatch简介SpringBatch是一个轻量级的综合性批处理框架,可用于开发企业信息系统中那些至关重要的数据批量处理业务.SpringBatch基于POJO和Spring框架,相当容易上手使用,让开发者很容易地访问和利用企业级服务.SpringBatch不是调度(scheduling)框架.因为已经有很多非常好的企业级调度框架,包括商业性质的和开源的,例如Quartz,T…

    2022年5月28日
    153
  • 分布式事务saga开源实现_spring分布式事务解决方案

    分布式事务saga开源实现_spring分布式事务解决方案Saga模式是一种分布式异步事务,一种最终一致性事务,是一种柔性事务。Saga事务模型又叫做长时间运行的事务(Long-running-transaction),它是由普林斯顿大学的H.Garcia-Molina等人提出,它描述的是另外一种在没有两阶段提交的的情况下解决分布式系统中复杂的业务事务问题。Saga的组成每个Saga由一系列sub-transactionTi组成每个T…

    2022年9月19日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号