rtsp簡介(ZT)
Real Time Streaming Protocol或者RTSP(實時流媒體協定),是由Real network 和Netscape共同提出的如何有效地在IP網絡上傳輸流媒體資料的應用層協定。RTSP提供一種可擴充的架構,使能夠提供能控制的,按需傳輸實時資料,比如音頻和視訊檔案。源資料可以包括現場資料的回報和存貯的檔案。rtsp對流媒體提供了諸如暫停,快進等控制,而它本身并不傳輸資料,rtsp作用相當于流媒體伺服器的遠端控制。傳輸資料可以通過傳輸層的tcp,udp協定,rtsp也提供了基于rtp傳輸機制的一些有效的方法。
RTSP消息格式:
RTSP的消息有兩大類,一是請求消息(request),一是回應消息(response),兩種消息的格式不同.
請求消息:
方法 URI RTSP版本 CR LF
消息頭 CR LF CR LF
消息體 CR LF
其中方法包括OPTION回應中所有的指令,URI是接受方的位址,例如:rtsp://192.168.20.136
RTSP版本一般都是 RTSP/1.0.每行後面的CR LF表示回車換行,需要接受端有相應的解析,最後一個消息頭需要有兩個CR LF
回應消息:
RTSP版本 狀态碼 解釋 CR LF
消息頭 CR LF CR LF
消息體 CR LF
其中RTSP版本一般都是RTSP/1.0,狀态碼是一個數值,200表示成功,解釋是與狀态碼對應的文本解釋.
簡單的rtsp互動過程:
C表示rtsp用戶端,S表示rtsp服務端
1.C->S:OPTION request //詢問S有哪些方法可用
1.S->C:OPTION response //S回應資訊中包括提供的所有可用方法
2.C->S:DESCRIBE request //要求得到S提供的媒體初始化描述資訊
2.S->C:DESCRIBE response //S回應媒體初始化描述資訊,主要是sdp
3.C->S:SETUP request //設定會話的屬性,以及傳輸模式,提醒S建立會話
3.S->C:SETUP response //S建立會話,傳回會話辨別符,以及會話相關資訊
4.C->S:PLAY request //C請求播放
4.S->C:PLAY response //S回應該請求的資訊
S->C:發送流媒體資料
5.C->S:TEARDOWN request //C請求關閉會話
5.S->C:TEARDOWN response //S回應該請求
上述的過程是标準的、友好的rtsp流程,但實際的需求中并不一定按部就班來。
其中第3和4步是必需的!第一步,隻要伺服器用戶端約定好,有哪些方法可用,則option請求可以不要。第二步,如果我們有其他途徑得到媒體初始化描述資訊(比如http請求等等),則我們也不需要通過rtsp中的describe請求來完成。第五步,可以根據系統需求的設計來決定是否需要。
rtsp中常用方法:
1.OPTION
目的是得到伺服器提供的可用方法:
OPTIONS rtsp://192.168.20.136:5000/xxx666 RTSP/1.0
CSeq: 1 //每個消息都有序号來标記,第一個包通常是option請求消息
User-Agent: VLC media player (LIVE555 Streaming Media v2005.11.10)
伺服器的回應資訊包括提供的一些方法,例如:
RTSP/1.0 200 OK
Server: UServer 0.9.7_rc1
Cseq: 1 //每個回應消息的cseq數值和請求消息的cseq相對應
Public: OPTIONS, DESCRIBE, SETUP, TEARDOWN, PLAY, PAUSE, SCALE, GET_PARAMETER //伺服器提供的可用的方法
2.DESCRIBE
C向S發起DESCRIBE請求,為了得到會話描述資訊(SDP):
DESCRIBE rtsp://192.168.20.136:5000/xxx666 RTSP/1.0
CSeq: 2
token:
Accept: application/sdp
User-Agent: VLC media player (LIVE555 Streaming Media v2005.11.10)
伺服器回應一些對此會話的描述資訊(sdp):
RTSP/1.0 200 OK
Server: UServer 0.9.7_rc1
Cseq: 2
x-prev-url: rtsp://192.168.20.136:5000
x-next-url: rtsp://192.168.20.136:5000
x-Accept-Retransmit: our-retransmit
x-Accept-Dynamic-Rate: 1
Cache-Control: must-revalidate
Last-Modified: Fri, 10 Nov 2006 12:34:38 GMT
Date: Fri, 10 Nov 2006 12:34:38 GMT
Expires: Fri, 10 Nov 2006 12:34:38 GMT
Content-Base: rtsp://192.168.20.136:5000/xxx666/
Content-Length: 344
Content-Type: application/sdp
v=0 //以下都是sdp資訊
o=OnewaveUServerNG 1451516402 1025358037 IN IP4 192.168.20.136
s=/xxx666
u=http:///
[email protected]
c=IN IP4 0.0.0.0
t=0 0
a=isma-compliance:1,1.0,1
a=range:npt=0-
m=video 0 RTP/AVP 96 //m表示媒體描述,下面是對會話中視訊通道的媒體描述
a=rtpmap:96 MP4V-ES/90000
a=fmtp:96 profile-level-id=245;config=000001B0F5000001B509000001000000012000C888B0E0E0FA62D089028307
a=control:trackID=0//trackID=0表示視訊流用的是通道0
3.SETUP
用戶端提醒伺服器建立會話,并确定傳輸模式:
SETUP rtsp://192.168.20.136:5000/xxx666/trackID=0 RTSP/1.0
CSeq: 3
Transport: RTP/AVP/TCP;unicast;interleaved=0-1
User-Agent: VLC media player (LIVE555 Streaming Media v2005.11.10)
//uri中帶有trackID=0,表示對該通道進行設定。Transport參數設定了傳輸模式,包的結構。接下來的資料標頭部第二個位元組位置就是 interleaved,它的值是每個通道都不同的,trackID=0的interleaved值有兩個0或1,0表示rtp包,1表示rtcp包,接受端根據interleaved的值來差別是哪種資料包。
伺服器回應資訊:
RTSP/1.0 200 OK
Server: UServer 0.9.7_rc1
Cseq: 3
Session: 6310936469860791894 //伺服器回應的會話辨別符
Cache-Control: no-cache
Transport: RTP/AVP/TCP;unicast;interleaved=0-1;ssrc=6B8B4567
4.PLAY
用戶端發送播放請求:
PLAY rtsp://192.168.20.136:5000/xxx666 RTSP/1.0
CSeq: 4
Session: 6310936469860791894
Range: npt=0.000- //設定播放時間的範圍
User-Agent: VLC media player (LIVE555 Streaming Media v2005.11.10)
伺服器回應資訊:
RTSP/1.0 200 OK
Server: UServer 0.9.7_rc1
Cseq: 4
Session: 6310936469860791894
Range: npt=0.000000-
RTP-Info: url=trackID=0;seq=17040;rtptime=1467265309
//seq和rtptime都是rtp包中的資訊
5.TEARDOWN
用戶端發起關閉請求:
TEARDOWN rtsp://192.168.20.136:5000/xxx666 RTSP/1.0
CSeq: 5
Session: 6310936469860791894
User-Agent: VLC media player (LIVE555 Streaming Media v2005.11.10)
伺服器回應:
RTSP/1.0 200 OK
Server: UServer 0.9.7_rc1
Cseq: 5
Session: 6310936469860791894
Connection: Close
以上方法都是互動過程中最為常用的,其它還有一些重要的方法如get/set_parameter,pause,redirect等等
ps:
sdp的格式
v=<version>
o=<username> <session id> <version> <network type> <address type> <address>
s=<session name>
i=<session description>
u=<URI>
e=<email address>
p=<phone number>
c=<network type> <address type> <connection address>
b=<modifier>:<bandwidth-value>
t=<start time> <stop time>
r=<repeat interval> <active duration> <list of offsets from start-time>
z=<adjustment time> <offset> <adjustment time> <offset> ....
k=<method>
k=<method>:<encryption key>
a=<attribute>
a=<attribute>:<value>
m=<media> <port> <transport> <fmt list>
v = (協定版本)
o = (所有者/建立者和會話辨別符)
s = (會話名稱)
i = * (會話資訊)
u = * (URI 描述)
e = * (Email 位址)
p = * (電話号碼)
c = * (連接配接資訊)
b = * (帶寬資訊)
z = * (時間區域調整)
k = * (加密密鑰)
a = * (0 個或多個會話屬性行)
時間描述:
t = (會話活動時間)
r = * (0或多次重複次數)
媒體描述:
m = (媒體名稱和傳輸位址)
i = * (媒體标題)
c = * (連接配接資訊 — 如果包含在會話層則該字段可選)
b = * (帶寬資訊)
k = * (加密密鑰)
a = * (0 個或多個媒體屬性行)
參考文章:rfc2326(rtsp);rfc2327(sdp)