Streaming media
|
Streaming media is media that is consumed (read, heard, viewed) while it is being delivered. Streaming is more a property of the delivery system than the media itself. The distinction is usually applied to media that is distributed over computer networks; most other delivery systems are either inherently streaming (radio, television) or inherently non-streaming (books, video cassettes, audio CDs).
The word "stream" is also used as a verb, meaning to deliver streaming media.
The remainder of this article discusses technology for streaming media over computer networks.
Contents |
History
Attempts to display media on computers date back to the earliest days of computing, in the mid-20th century. However, little progress was made for several decades, due primarily to the high cost and limited capabilities of computer hardware.
Academic experiments in the 1970s proved out the basic concepts and feasibility of streaming media on computers.
During the 1980s, consumer-grade computers became powerful enough to display media. The primary technical issues were:
- having enough CPU power and bus bandwidth to support the required data rates
- creating low-latency interrupt paths in the OS to prevent underrun
However, computer networks were still limited, and media was usually delivered over non-streaming channels. In the 1990s, CD-ROMs became the most prevalent method of media distribution to computers.
The late 1990s saw:
- greater network bandwidth, especially in the last mile
- increased access to networks, especially the Internet
- use of standard protocols and formats, such as TCP/IP, HTTP, and HTML
- commercialization of the Internet
These advances in computer networking combined with powerful home computers and modern operating systems to make streaming media practical and affordable for ordinary consumers.
Technology
A streaming media system is made of many interacting technologies. Video cameras and audio recorders create raw media. Editors use composition tools to combine raw media into a finished work. Servers store media and make it available to many people. Clients retrieve media from servers and display it to the user. Servers and clients store media in various file formats; they send and receive it in various stream formats.
Servers and clients communicate over computer networks, using agreed upon network protocols. Servers encode media into a stream for transmission; clients receive the stream and decode it for display. codecs perform the encoding and decoding.
Media is big. Under current (2005) technology, media storage and transmission costs are still significant; therefore, media is often compressed for storage or streaming.
A media stream can be on demand or live. On demand streams are stored on a server for a long period of time, and are available to be transmitted at a user's request. Live streams are only available at one particular time, as in a video stream of a live sporting event.
Protocol issues
Designing a network protocol to support streaming media raises many issues.
Datagram protocols, such as the User Datagram Protocol (UDP), send the media stream as a series of small packets, called datagrams. This is simple and efficient; however, packets are liable to be lost or corrupted in transit. Depending on the protocol and the extent of the loss, the client may be able to recover the data with error correction techniques, may interpolate over the missing data, or may suffer a dropout.
The Real-time Transport Protocol (RTP), the Real Time Streaming Protocol (RTSP) and the Real Time Control Protocol (RTCP) were specifically designed to stream media over the network. They are all built on top of UDP.
Reliable protocols, such as the Transmission Control Protocol (TCP), guarantee correct delivery of each bit in the media stream. However, they accomplish this with a system of timeouts and retries, which makes them more complex to implement. It also means that when there is data loss on the network, the media stream stalls while the protocol handlers detect the loss and retransmit the missing data. Clients can minimize the effect of this by buffering data for display.
Another issue is that firewalls are more likely to block UDP-based protocols than TCP-based protocols.
Unicast protocols send a separate copy of the media stream from the server to each client. This is simple, but can lead to massive duplication of data on the network. Multicast protocols undertake to send only one copy of the media stream over any given network connection, i.e. along the path between any two network routers. This is a more efficient use of network capacity, but it is much more complex to implement. Furthermore, multicast protocols must be implemented in the network routers, as well as the servers.
As of 2005, most routers on the Internet do not support multicast protocols, and many firewalls block them. Multicast is most practical for organizations that run their own networks, such as universities and corporations. Since they buy their own routers and run their own network links, they can decide if the cost and effort of supporting a multicast protocol is justified by the resulting bandwidth savings.
Peer-to-peer (P2P) protocols arrange for media to be sent from clients that already have it to clients that do not. This prevents the server and its network connections from becoming a bottleneck. However, it raises technical, performance, quality, business, and legal issues.
Newer camcorders stream video to a computer over a FireWire connection. This uses a system of time-based reservations to ensure throughput, and can be received by multiple clients at once.
Social and legal issues
Some streaming broadcasters use streaming systems that interfere with the ability to record streams for later playback, either inadvertently through poor choice of streaming protocol or deliberately because they believe it is to their advantage to do so. Broadcasters may be concerned that copies will result in lost sales or that consumers may skip commercials. Whether users have the ability and the right to record streams has become a significant issue in the application of law to cyberspace.
In principle, there is no way to prevent a user from recording a media stream that has been delivered to their computer. Thus, the efforts of broadcasters to prevent this consist of making it inconvenient, or illegal, or both.
Broadcasters can make it inconvenient to record a stream, for example, by using unpublished data formats or by encrypting the stream. Of course, data formats can be reverse engineered, and encrypted streams must be decrypted with a key that resides—somewhere—on the consumer's computer, so these measures are security through obscurity, at best.
Efforts to make it illegal to record a stream may rely on copyrights, patents, license agreements, or—in the United States—the DMCA.
References
- Schneier, Bruce (May 15, 2001). The Futility of Digital Copy Prevention (http://www.schneier.com/crypto-gram-0105.html#3) Crypto-Gram Newsletter.
- Schneier, Bruce (August 2000). The Fallacy of Trusted Client Software (http://infosecuritymag.techtarget.com/articles/august00/columns2_cryptorhythms.shtml) Information Security Magazine . also at The Fallacy of Trusted Client Software (http://www.schneier.com/essay-063.html).
- Schneier, Bruce (October 15, 2001). SSSCA (http://www.schneier.com/crypto-gram-0110.html#3) Crypto-Gram Newsletter.
See also
- Web radio (audio)
- Webcast (video)
- List of Internet stations
- Electronic Frontier Foundation
- Center for Democracy and Technology
Streaming media systems
- FFmpeg
- Helix Community
- Icecast
- IceShare P2P Icecast protocol
- MuSE
- MPEG-4
- Ogg
- PeerCast
- Peercasting P2P streaming
- QuickTime
- RealSystem
- SHOUTcast
- VideoLAN
- Windows Media
- Zina (Open-source alternative to Andromeda written in PHP)
Codecs
Protocols
File formats
- AVI
- ASF -- WindowsMedia
- FLV -- Flash
- MPEG
- mp3PRO
- Ogg Vorbis audio
- Ogg Theora video
- RM -- Real
- QuickTime
- WMV -- WindowsMedia
- XviD
Description formats
External Links
Streaming media systems
- Andromeda (http://www.turnstyle.com/andromeda) (for PHP or ASP)
- Darkice (http://darkice.sourceforge.net/)
- Forbidden (http://www.forbidden.co.uk/)
- Flumotion (http://www.flumotion.net) (Distributed streaming media server)
- Streamripper (http://streamripper.sourceforge.net/)
- Clipstream (http://www.clipstream.com/) (audio and video streaming technology with a player written in Java)
- Web Video 4 U (http://www.webvideo4u.co.uk)
- Live Tv Streams (http://www.tv-all.net/index.php)
Companies
- Streamcity: Flash Streaming Video Production (http://www.streamcity.co.uk/)
- Fluendo: Linux Multimedia Company (http://www.fluendo.com/)
- rinf.com: Hundreds of free media streams (http://www.rinf.com/)
- StreamUK: Microsoft accredited DRM specialists (http://www.streamuk.com/)
- article (http://www.intranetjournal.com/articles/200102/) by Josh Beggs (Raspberry Media)
- all-streaming-media.com
- Streaming Media Protocols (http://all-streaming-media.com/articles/Streaming-Media-Intro_Streaming-protocols.htm)
- STL in Action: A Universal Streaming Service (http://cuj.com/documents/s=8254/cuj1066686750349/)
- StreamingMedia.com (http://cuj.com/documents/s=8254/cuj1066686750349/)
- Microsoft Windows Media (http://www.microsoft.com/windows/windowsmedia/)
- RealNetworks (http://www.realnetworks.com/index_rn.html)
- Apple Quicktime (http://developer.apple.com/quicktime/)
- Helix Community (http://www.helixcommunity.org/)
- United Streaming (http://www.unitedstreaming.com/)
- DayPort, Inc. - Streaming, WorkFlow & Convergence Technologies (http://www.dayport.com/)
- Max Management - Streaming video (http://www.max.be/) (Dutch)da:Streaming media
de:Streaming Media es:Streaming fr:streaming nl:Streaming media ja:ストリーミング pl:Media strumieniowe pt:Streaming Media