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.136RTSP版本一般都是 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.0CSeq: 1 //每個訊息都有序號來標記,第一個包通常是option請求訊息User-Agent: VLC media player (LIVE555 Streaming Media v2005.11.10) 伺服器的回應資訊包括提供的一些方法,例如:RTSP/1.0 200 OKServer: UServer 0.9.7_rc1Cseq: 1 //每個回應訊息的cseq數值和請求訊息的cseq相對應Public: OPTIONS, DESCRIBE, SETUP, TEARDOWN, PLAY, PAUSE, SCALE, GET_PARAMETER //伺服器提供的可用的方法2.DESCRIBEC向S發起DESCRIBE請求,為了得到會話描述資訊(SDP):DESCRIBE rtsp://192.168.20.136:5000/xxx666 RTSP/1.0CSeq: 2token: Accept: application/sdpUser-Agent: VLC media player (LIVE555 Streaming Media v2005.11.10) 伺服器回應一些對此會話的描述資訊(sdp):RTSP/1.0 200 OKServer: UServer 0.9.7_rc1Cseq: 2x-prev-url: rtsp://192.168.20.136:5000x-next-url: rtsp://192.168.20.136:5000x-Accept-Retransmit: our-retransmitx-Accept-Dynamic-Rate: 1Cache-Control: must-revalidateLast-Modified: Fri, 10 Nov 2006 12:34:38 GMTDate: Fri, 10 Nov 2006 12:34:38 GMTExpires: Fri, 10 Nov 2006 12:34:38 GMTContent-Base: rtsp://192.168.20.136:5000/xxx666/Content-Length: 344Content-Type: application/sdp v=0 //以下都是sdp資訊o=OnewaveUServerNG 1451516402 1025358037 IN IP4 192.168.20.136s=/xxx666u=http:///e=admin@c=IN IP4 0.0.0.0t=0 0a=isma-compliance:1,1.0,1 a=range:npt=0-m=video 0 RTP/AVP 96 //m表示媒體描述,下面是對會話中視頻通道的媒體描述a=rtpmap:96 MP4V-ES/90000a=fmtp:96 profile-level-id=245;config=000001B0F5000001B509000001000000012000C888B0E0E0FA62D089028307a=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 OKServer: UServer 0.9.7_rc1Cseq: 3Session: 6310936469860791894 //伺服器回應的工作階段識別項Cache-Control: no-cacheTransport: RTP/AVP/TCP;unicast;interleaved=0-1;ssrc=6B8B45674.PLAY用戶端發送播放請求:PLAY rtsp://192.168.20.136:5000/xxx666 RTSP/1.0CSeq: 4Session: 6310936469860791894Range: npt=0.000- //設定播放時間的範圍User-Agent: VLC media player (LIVE555 Streaming Media v2005.11.10)伺服器回應資訊:RTSP/1.0 200 OKServer: UServer 0.9.7_rc1Cseq: 4Session: 6310936469860791894Range: 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.0CSeq: 5Session: 6310936469860791894User-Agent: VLC media player (LIVE555 Streaming Media v2005.11.10)伺服器回應:RTSP/1.0 200 OKServer: UServer 0.9.7_rc1Cseq: 5Session: 6310936469860791894Connection: 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)