(转)RTSP - RTP over TCP

Normally, RTSP provide streaming over UDP. By nature, UDP is a better choice as it provides robust streaming capability for media. However, it is unlikely to use UDP for streaming over the Internet.

通常来说,RTSP提供UDP方式发送RTP流。当然,发送流媒体时,UDP往往是更好的选择。但是,在互联网上使用UDP方式发送流是不可能的。

Some issues with UDP are

下面是使用UDP时的一些问题:

1. RTSP/RTP over UDP requires many UDP ports to be opened (each media stream requires 2 UDP port for data and control).

1. UDP协议上的RTSP/RTP需要打开许多UDP端口(每一路流媒体都需要2个UDP端口,一个用于接收数据,一个用于接收控制信息);

2. Point 1 is a real problem as routers in the Internet may not open these ports.

2.当因特网上的路由器没有打开这些端口的时候,上述第一点将会存在问题;

3. It is normal for intermediate Internet router to filter and ignore UDP packets.

3. 中间网络路由器很容易就过滤或者忽略掉UDP数据包;

4. UDP is unreliable. Media packets may be lost when travelling along the Internet

4. UDP是不可靠传输协议,媒体包在因特网上传输时会面临着丢包。

RTSP/RTP over TCP may resolve this issue.

但是我们如果在TCP传输协议上承载RTSP/RTP将解决这些问题。

1. RTSP/RTP will communicate via 1 port for command and data. That is the RTSP port.

1. RTSP/RTP的控制命令和数据都通过一个端口,即RTSP的端口(默认为554),进行交互。

2. TCP provide reliable streaming

2. TCP协议提供可靠的流传输。

3. It is more likely that the intermediate Internet router allow these TCP packets to go through.

3. TCP包更容易穿透中间网络路由器。

Using RTSP/RTP over TCP come with a price.

但是,使用TCP传输协议承载RTSP/RTP需要花更多的功夫。

1. It complicated the packetization and depacketization process due to binary interleave.

1. 由于二元交织,会使得RTP包封包和解包的过程变得更加复杂。

2. TCP is reliable but have overhead. It may cause delay in real time media.

2. TCP是可靠的传输协议,但正是因为如此,会导致在实时流媒体中的延时。

So, now I will talk about how to setup RTSP/RTP over TCP

接下来让我们来了解一下怎么使用TCP承载RTSP/RTP。

RTSP/RTP over TCP

TCP承载RTSP/RTP

When you use RTSP/RTP over TCP, all command and media data will be sent through the RTSP port, normally, port 554. Also, when using

当使用TCP协议承载RTSP/RTP时,所有的命令和媒体数据都将通过RTSP端口,通常是554,进行发送。同时,数据将经过二元交织格式化之后才能发

RTSP/RTP over TCP, the data will be sent via binary interleave format.

送。

Below will describe the essential for using RTSP/RTP over TCP

接下来我们将描述使用TCP承载RTSP/RTP的主要要素:

 

SETUP

To use TCP communication, you need to request TCP connection during RTSP SETUP. You have to sent SETUP command with

要使用TCP连接,RTSP客户端需要在SETUP阶段请求TCP连接。SETUP命令中应该包括如下格式的Transport:

Transport: RTP/AVP/TCP;interleaved=0-1

This will tell the server to send media data with TCP and interleave the data in channel 0 and 1. Given in the specification, data channel is even

上述Transport将告诉服务端使用TCP协议发送媒体数据,并且使用信道 0 和 1 对流数据以及控制信息进行交织。详细说来,使用偶数信道作为数据

number and control channel is odd (data_ch_num + 1). So, if you data channel is 0, your control channel will be 0 + 1 = 1.

传输信道,使用奇数信道作为控制信道(数据信道 + 1)。所以,如果你设定数据信道为 0 ,那控制信道应该是 0 + 1 = 1。

Below is an example of TCP SETUP

RTP Data

After the setup, RTP data will be sent through the TCP socket that is used for RTSP commands. The RTP data will be encapsulate in the following format

SETUP之后,RTP数据将通过用来发送RTSP命令的TCP Socket进行发送。RTP数据将以如下格式进行封装:

| magic number | channel number | embedded data length | data |

magic number - 1 byte value of hex 0x24

RTP数据标识符,"$"

channel number - 1 byte value to denote the channel

信道数字 - 1个字节,用来指示信道

embedded data length - 2 bytes to denote the embedded data length

数据长度 - 2个字节,用来指示插入数据长度

data - data packet, ie RTP packet, with the total length of the embedded data length

数据 - 数据包,比如说RTP包,总长度与上面的数据长度相同

Below is a full example of the communication exchanged

下面是交互过程的一个完整示例:

Also, as RTSP is a application protocol, it has no way to control how TCP timeout the connection. Thus, during the RTSP SETUP, a Session is

然而,由于RTSP是应用协议,没有办法控制TCP连接的超时。所以,在RTSP的SETUP阶段,新建一个会话(SESSION)用于标识已连接的流。

given to identify the connected stream

Session = "Session" ":" session-id [ ";" "timeout" "=" delta-seconds ]

If Session is given, each subsequence RTSP command must be sent with the session so that the server can identify the stream. Also, please note

一旦会话(SESSION)被创建,接下来的每一个RTSP命令都必须加上session_id,否则服务端无法识别命令对应的流。另外,"timeout"的值是可选

that timeout is an optional value. The default value for timeout is 60 seconds. So, it is advisable to send a RTSP command to the server every

的。"timeout"的默认值是60秒。所以,建议每隔60秒向服务端发送一个RTSP命令以保持TCP连接的存活。

60 second to keep the TCP connection alive.

Read RFC 2326 Section 10.12 Embedded (Interleaved) Binary Data for more details

RFC 2326 第10.12节说明了插入二进制数据的细节。

Posted by Thompson Ngat 11:59 PM

Labels: RTSP

以下是一些问答,觉得对我们理解 RTP over TCP 是很有帮助的,也摘抄给大家。

15 comments:

  1. Jeff ChenMarch 28, 2011 at 8:01 AM

    Does it still need "keep-alive" in TCP mode?

    I found this:
    http://msdn.microsoft.com/en-us/library/cc245366%28v=prot.10%29.aspx

    However, I cannot find a clear statement in RFC2326.

    ReplyDelete

  2. Thompson NgMarch 28, 2011 at 7:09 PM

    My experience is Yes.

    All media server/camera I have encounter so far requires me to send a RTSP message to keepalive the RTSP session while getting RTP stream from the same socket.

    ReplyDelete

  3. AndyJune 5, 2011 at 1:39 AM

    Hello, in the pic, there is a "$\000", I know the $ is the magic char, but, what does the "\00" mean?

    ReplyDelete

  4. Thompson NgJune 5, 2011 at 2:32 AM

    \0 is just a null character in C. 00 is ASCII representation of channel 0.

    So just imagine $\000 is a printf from C++ for 1 byte of magic and 1 byte of channel

    Just remember that you need 1 byte of magic 0x24, and 1 byte of channel number will do.

    ReplyDelete

  5. AndyJune 6, 2011 at 5:35 AM

    Thanks for the response, Thompson.

    ReplyDelete

  6. _vl_June 24, 2011 at 9:11 AM

    What would be the RTCP metric for RTP over TCP to monitor for bandwidth congestion: delay, or jitter ? And would that monitoring prevent against delay accumulation? Anyone tried to research that?

    ReplyDelete

  7. Thompson NgJune 25, 2011 at 1:38 AM

    Normally, it should use the jitter on RTCP report and the server should reduce the sending rate.

    ReplyDelete

  8. laurenSeptember 21, 2011 at 11:42 AM

    You are right that UDP is a better choice as it provides robust streaming capability for media. But I never knew about its issues that you listed above.Thanks.
    pdf digital signature

    ReplyDelete

  9. Thompson NgSeptember 21, 2011 at 11:53 PM

    In fact, RTP/UDP does not really work in the public Internet most of the time. The UDP packets will be filtered by the ISP usually.

    ReplyDelete

  10. psychesnetJanuary 31, 2012 at 6:58 PM

    Dear Thompson Ng,

    What open source do you use for pack RTP over TCP ? 
    ccRTP or ....
    I try to use oRTP, but it seems only support UDP streaming.
    Thanks a lot.

    ReplyDelete

  11. raghavaMay 17, 2012 at 10:27 PM

    Hi Thompson Ng,
    i am writting an rtsp application in c.After sending PLAY command to server(ipcam) it responding with success code.
    but am not able to receive the data buffers.
    Do i need to create socket again for rtp port. which sent by SETUP command. can you give some info How i can receive data buffer?
    Thanks in advance

    ReplyDelete

  12. Thompson NgMay 17, 2012 at 11:15 PM

    For RTSP tunneling, you need to create 2 TCP sockets. One POST socket to send commands and one GET socket to receive data and response. You need to set up these 2 socket with a session ID so that the server can bind these 2 socket together.

    Then, you send your command via POST socket and read your response from GET socket.

    Note, both command response and data are received via GET socket. Thus, you need to check for magic byte 0x24 to identify if you are getting command response or data response

    ReplyDelete

  13. TarunFebruary 11, 2013 at 3:32 AM

    A very useful information to stream RTSP - RTP over TCP.
    Can you tell me for this what changes do we have to make in the live 555 libraries as they also stream RTSP - RTP over UDP 
    and you also have the knowledge of live 555 as seen in your article http://thompsonng.blogspot.in/search/label/Live555.

    ReplyDelete

  14. Thompson NgFebruary 11, 2013 at 6:59 PM

    Live555 comes with openRTSP that allow RTSP/RTP over TCP. http://www.live555.com/openRTSP/

    openRTSP will switch to RTSP/RTP over TCP with switch command -t

    I did not really work with it. But my advise is... Put debug point at the main.c command -t potion. Step through the code and you will able to find the relevant code

    ReplyDelete

  15. TarunFebruary 12, 2013 at 10:52 PM

    I am using Live 555 to stream the live video from camera so according to there documentationenter link description here i have implemented the createNewStreamSource() and createNewRTPSink() but the problem now i am facing is what should be the function call.

    ReplyDelete

参考:

http://blog.csdn.net/cloume/article/details/11771403

时间: 2025-01-05 02:33:45

(转)RTSP - RTP over TCP的相关文章

RTSP - RTP over TCP

Normally, RTSP provide streaming over UDP. By nature, UDP is a better choice as it provides robust streaming capability for media. However, it is unlikely to use UDP for streaming over the Internet. 通常来说,RTSP提供UDP方式发送RTP流.当然,发送流媒体时,UDP往往是更好的选择.但是,在互联

(转)live555 RTSP Server RTP over TCP BUG

最近碰到一个非常棘手的问题,NVR通过ONVIF协议接入IPC进行录像,在录像时,会发现其中有个别IPC会出现录像断断续续的情况.这种情况很难复现,但是这种情况一旦出现,整个过程会一直持续很长时间,一般是直到重启RTSP Server. 通过苦逼型的大规模测试发现: 1.IPC与NVR之间是通过RTP over TCP的方式传输数据(这个测试结果很简单就可以知道): 2.开启1个客户端(通过RTP over TCP传输数据),打开rtsp流后,使用任务管理器强制结束.紧接着马上再开1个客户端,打

live555 RTSP Server RTP over TCP BUG

最近碰到一个非常棘手的问题,NVR通过ONVIF协议接入IPC进行录像,在录像时,会发现其中有个别IPC会出现录像断断续续的情况.这种情况很难复现,但是这种情况一旦出现,整个过程会一直持续很长时间,一般是直到重启RTSP Server. 通过苦逼型的大规模测试发现: 1.IPC与NVR之间是通过RTP over TCP的方式传输数据(这个测试结果很简单就可以知道): 2.开启1个客户端(通过RTP over TCP传输数据),打开rtsp流后,使用任务管理器强制结束.紧接着马上再开1个客户端,打

MPlayer 开始支持RTSP/RTP流媒体文件

hostzhu点评:MPlayer对流媒体的支持,让大家能更进一步地利用linux来看网络直播,对Linux下多媒体应用的推动作用可以说不可度量. RTSP/RTP streaming support for MPlayerThe Open Source "MPlayer" media player can now receive and play standards-compliant RTP audio/video streams, using the "LIVE555

EasyDarwin开源社区流媒体视频课程:流媒体传输控制协议(RTSP RTP SDP)详解之RTSP

视频课程及相关文档代码地址:https://github.com/EasyDarwin/Course#course-3 流媒体传输协议介绍 一.RTSP协议介绍 什么是rtsp? RTSP协议以客户服务器方式工作,,如:暂停/继续.后退.前进等.它是一个多媒体播放控制协议,用来使用户在播放从因特网下载的实时数据时能够进行控制, 因此 RTSP 又称为"因特网录像机遥控协议". RTSP(Real-Time Stream Protocol)是一种基于文本的应用层协议,在语法及一些消息参数

RTSP,RTP,RTCP的区别

下面的文章讲解的都非常详细,可以参考OpenRTSP的源码学习.这个是live555库里面的工具Demo http://www.360doc.com/content/12/0516/23/7828500_211547756.shtml http://blog.csdn.net/heanyu/article/details/6202500 http://blog.csdn.net/span76/article/details/12913307 http://blog.csdn.net/franki

CDN技术详解及实现原理

CDN技术详解 一本好的入门书是带你进入陌生领域的明灯,<CDN技术详解>绝对是带你进入CDN行业的那盏最亮的明灯.因此,虽然只是纯粹的重点抄录,我也要把<CDN技术详解>的精华放上网.公诸同好. 第一章    引言    “第一公里”是指万维网流量向用户传送的第一个出口,是网站服务器接入互联网的链路所能提供的带宽.这个带宽决定了一个 网站能为用户提供的访问速度和并发访问量.如果业务繁忙,用户的访问数越多,拥塞越严重,网站会在最需要向用户提供服务时失去用户.(还有“中间一公里” 和

[总结]视音频技术零基础学习方法

一直想把视音频编解码技术做一个简单的总结,可是苦于时间不充裕,一直没能完成.今天有着很大的空闲,终于可以总结一个有关视音频技术的入门教程,可以方便更多的人学习从零开始学习视音频技术.需要注意的是,本文所说的视音频技术,指的是理论层面的视音频技术,并不涉及到编程相关的东西. 0.     生活中的视音频技术 平时我们打开电脑中自己存电影的目录的话,一般都会如下图所示,一大堆五花八门的电影.(其实专业的影视爱好者一概会把影视文件分门别类的,但我比较懒,一股脑把电影放在了一起) 因为下载的来源不同,这

[总结]视音频编解码技术零基础学习方法

一直想把视音频编解码技术做一个简单的总结,可是苦于时间不充裕,一直没能完成.今天有着很大的空闲,终于可以总结一个有关视音频技术的入门教程,可以方便更多的人学习从零开始学习视音频技术.需要注意的是,本文所说的视音频技术,指的是理论层面的视音频技术,并不涉及到编程相关的东西. 0.     生活中的视音频技术 平时我们打开电脑中自己存电影的目录的话,一般都会如下图所示,一大堆五花八门的电影.(其实专业的影视爱好者一概会把影视文件分门别类的,但我比较懒,一股脑把电影放在了一起) 因为下载的来源不同,这