Lab Assignment 15/ INF5060: Multimedia data communication using network processors
2004 Carsten Griwodz & Pål HalvorsenINF5060 – multimedia data communication using network processors Assignment 6 – Lab setup IXP lab switch … IXP1200 local network ( xxx) ssh connection ( xxx) To MEDIA SERVER LOAD BALANCER hub To media server cluster
2004 Carsten Griwodz & Pål HalvorsenINF5060 – multimedia data communication using network processors Assignment 6 – Scenario Media server–client scenario: the two “server” machines each run a streaming server have their network interfaces configured equally, i.e., IP address the servers should answer to requests and start a media stream the clients send requests to the server the IXP card should implement a transparent load balancer selecting one of the “equal” servers to serve a request according to a simple policy
2004 Carsten Griwodz & Pål HalvorsenINF5060 – multimedia data communication using network processors Assignment 6 – Client/Server Applications User inf5060 (same password as root) Server ( (also installed on the other machines)): komssys: /home/inf5060/komssys rtsp server: /home/inf5060/komssys/LINUX/rtsp/server/rstp_server video file: /home/inf5060/video/full_1.mpg Client ( ) mplayer: /home/inf5060/MPlayer-1.0pre2/mplayer starting playback: retrieving data from server: mplayer rtsp:// :9070/full_1.mpg retrieving data local client: o mplayer /home/inf5060/video/full_1.mpg o mplayer rtsp://localhost:9070/full_1.mpg useful options: no audio: -ao null ascii art video output: –vo aa …
2004 Carsten Griwodz & Pål HalvorsenINF5060 – multimedia data communication using network processors Assignment 6 – Implementation The assignment: implement the transparent load balancer use the packet bridge with ARP support to forward packets (see assignment 5) when a request is received, use a policy (random, RR) to choose which of the “equal” machines that should serve the request (to which port to forward packets) the load balancer must remember which clients use which port implement a load balancer monitor (see assignment 3): let the load balancer keep a statistic of how many packets are sent to each server implement a crosscall that can display the load statistics for the media servers (total number of packets and percentage of total for each server machine/port)
2004 Carsten Griwodz & Pål HalvorsenINF5060 – multimedia data communication using network processors Assignment 6 – Deliverables The assignment: write and deliver a short (2-3 pages) report describing your system report source code deadline: Monday 29/ present your system to the class give a 15-minutes overview over your implementation o design o what is running where (StrongARM vs. Microengine) o what is stored where (SDRAM vs. SRAM vs. Scratch) give a demo of the system presentation day: Friday 3/
2004 Carsten Griwodz & Pål HalvorsenINF5060 – multimedia data communication using network processors Multimedia Signaling Protocols Signaling protocols used for connection setup distribution information about data protocols Primary Internet signaling protocols RTSP – Real-Time Streaming Protocol HTTP-like mainly for on-demand audio and video streaming SIP – Session Initiation Protocol SMTP-like mainly for IP telephony SDP – Session Description Protocol not really a protocol carried inside RTSP and SIP for description of data stream H.323 descriptions of data streams carried in ASN.1 encoding mainly for IP telephony Data protocols RTP/RTCP – Real-Time Transfer Protocol/RTP Control Protocol
2004 Carsten Griwodz & Pål HalvorsenINF5060 – multimedia data communication using network processors Real-Time Streaming Protocol (RTSP) Internet media-on-demand select and playback streaming media from server similar to VCR, but potentially new functionality integration with Web security varying quality need for control protocol start, stop, pause, … RTSP is also usable for Near video-on-demand (multicast) Live broadcasts (multicast, restricted control functionality) ...
2004 Carsten Griwodz & Pål HalvorsenINF5060 – multimedia data communication using network processors RTSP Approach In line with established Internet protocols Similar to HTTP 1.1 in style Uses URLs for addressing: rtsp://video.server.com:8765/videos/themovie.mpg Range definitions Proxy usage Expiration dates for RTSP DESCRIBE responses Other referenced protocols from Internet (RTP, SDP) Functional differences from HTTP Data transfer is separate from RTSP connection typically via RTP unlike “HTTP streaming” Server maintains state – setup and teardown messages Server as well as clients can send requests
2004 Carsten Griwodz & Pål HalvorsenINF5060 – multimedia data communication using network processors RTSP Features Rough synchronization Media description in DESCRIBE response Timing description in SETUP response Fine-grained through RTP sender reports Aggregate and separate control of streams possible Virtual presentations Server controls timing for aggregate sessions RTSP Server may control several data (RTP) servers Load balancing through redirect at connect time Use REDIRECT at connect time Caching Only RTSP caching (stream state) so far Data stream caching is under discussion
2004 Carsten Griwodz & Pål HalvorsenINF5060 – multimedia data communication using network processors RTSP Methods OPTIONS C S determine capabilities of server/client C S DESCRIBE C S get description of media stream ANNOUNCE C S announce new session description SETUP C S create media session RECORD C S start media recording PLAY C S start media delivery PAUSE C S pause media delivery REDIRECT C S redirection to another server TEARDOWN C S immediate teardown SET_PARAMETER C S change server/client parameter GET_PARAMETER C S read server/client parameter
2004 Carsten Griwodz & Pål HalvorsenINF5060 – multimedia data communication using network processors media server RTSP Operation Integration with other real-time and multimedia protocols RTSP server data source media player AV subsystem RTSP client RTSP SETUP RTSP OK RTSP PLAY RTSP OK RTP AUDIO RTP VIDEO RTSP TEARDOWN RTSP OK get UDP port choose UDP port
2004 Carsten Griwodz & Pål HalvorsenINF5060 – multimedia data communication using network processors Relevant RTSP Messages Complete protocol specified in RFC2326 Client sends SETUP rtsp://server.name.com:5540/path/leading/to/medium.typ RTSP/1.0 CSeq: 12 Transport: RTP/AVP;unicast;client_port= Server answers RTSP/ OK CSeq: 12 Date: 15 Oct :15:00 GMT Session: anything_even_with_newline_if_its_microsoft Transport: RTP/AVP;unicast;client_port= ;server_port=6256_6257 RTSP works over TCP no reliable message boundaries RTSP headers end with double return, each return may be “ 0xa ”, “ 0xd ”, “ 0xa 0xd ” or “ 0xd 0xa ” but RTSP can have a body as well indicated by Content-Length=, number of after double return We assume that a session ends when the client closes the TCP connection even though that is not standard compliant