04 Streaming

Descargar como pdf o txt
Descargar como pdf o txt
Está en la página 1de 13

16o Concurso de Trabajos Estudiantiles, EST 2013

La realidad actual del streaming de video. El streaming tradicional vs


alternativas actuales

Autor: Mariano Garca Clavera


Director del Trabajo de Grado: Jorge Oribe
Categora: Trabajos finales
Universidad Austral

42 JAIIO - EST 2013 - ISSN: 1850-2946 - Page 285


16o Concurso de Trabajos Estudiantiles, EST 2013

La realidad actual del streaming de video. El streaming


tradicional vs alternativas actuales

Abstract. En los ltimos tiempos se ha evidenciado una presencia masiva de


sitios web que proporcionan video, incurriendo a diferentes tcnicas que suelen
categorizarse dentro de lo que sera streaming de video. Sin embargo, no siempre,
dichas prcticas son la aplicacin de streaming de video en su forma tradicional, al
contrario, son alternativas que basndose en los conceptos tradicionales de streaming
pretenden proporcionar un servicio similar condicionado por los costos, tecnologa y
realidad actual, que cada sitio eventualmente sufre. Por consiguiente en el presente
estudio se pretendi resumir las diferentes alternativas que existen hoy a la ahora de
proveer un video, evaluar sus ventajas y desventajas y estudiar qu suceda en sitos
como Netflix y Youtube.

1. Introduccin

Cuando uno habla de Streaming de video, lo ms probable que uno posea


una definicin vaga de lo que realmente estos trminos quieren decir. En un primer
momento, podramos asociarlo con lo que sera la transmisin de video, cosa que no
es incorrecto, pero estaramos dando una definicin incompleta de estos conceptos.
Podramos agregar tambin, que si hablamos de video, transmitir video, eso incluira
la transmisin de audio y entonces diramos que Streaming de video consiste en la
distribucin de audio o video. Pero nuevamente, nos quedaramos con una definicin
incompleta. Es por eso, que es en el concepto de Streaming donde debemos centrar
nuestra atencin. Qu significa la palabra Streaming? 'Stream' significa 'chorro' o
'flujo' y alude a la descarga de un fichero que no tiene principio ni final: el caso ms
claro es una transmisin en directo. Una emisin en diferido no deja de ser un fichero
muy grande y que se puede transmitir por HTTP, FTP o cualquier otro medio habitual
de descarga. La cuestin es que un stream debe ser transmitido de modo que
cualquiera pueda conectar con l en cualquier momento, y no slo al principio de la
transmisin. De tal forma, que la visualizacin de los contenidos en el cliente se da
sin la necesidad de esperar la descarga completa de un fichero.
Con la recepcin de una pequea parte el cliente es capaz de entregar su
contenido al usuario, mientras contina recibiendo la corriente de datos (streaming)
que ir mostrando posteriormente. La parte almacenada acta como "colchn" entre el
ancho de banda irregular que caracteriza a las redes TCP/IP y el dbito continuo que
requieren las transmisiones de audio y video [1].
Por lo que ahora podramos decir, que Streaming es una tecnologa de
transmisin a travs de la red, en la que no existe descarga de la informacin en un
disco local y que por ende, la informacin que se enva a travs de la red al cliente se
reproduce en tiempo real al recibirla. Tal es as, que esta tecnologa de transmisin
tambin puede ser usada para otros fines. Por ejemplo, se hace uso de streaming en
aplicaciones de control en donde sensores van enviando datos que deben reproducirse
en tiempo real. Luego, en la medida que la informacin que sea transmita sean

42 JAIIO - EST 2013 - ISSN: 1850-2946 - Page 286


16o Concurso de Trabajos Estudiantiles, EST 2013

contenidos multimedia, tales como audio o video, hablaremos de Streaming de Video.


De esta forma, a continuacin se describir lo que es el streaming tradicional,
luego diferentes alternativas de streaming. Una vez comprendido lo anterior, se
seguir con un anlisis de las ventajas y desventajas de cada uno de los streamings
con una tabla descriptiva que complementara dicho anlisis. Por ltimo, se evaluar el
comportamiento del streaming proporcionado por Netflix y Youtube para saber que
est sucediendo realmente cuando vemos un video.

2.1 Streaming Tradicional

El proceso de streaming consiste en la entrega de uno o varios medios


multiplexados hacia un cliente en tiempo real, usando una red con un determinado
ancho de banda (que no tiene porqu ser necesariamente grande). En el proceso de
streaming NO hay ningn fichero que se descarga al ordenador del cliente, sino que el
medio se reproduce conforme se est recibiendo, y a su vez el medio se recibe a la
velocidad adecuada para su reproduccin. Esto contrasta con las descargas
progresivas, en las que el fichero s queda descargado en disco y adems se recibe a la
mayor velocidad posible, con el fin de terminar el proceso de descarga lo antes
posible. En un proceso de streaming estndar de audio y vdeo sincronizado, las
peticiones de servicio por parte de los clientes se pueden manejar utilizando el
protocolo RTSP (RealTime Streaming Protocol). Este protocolo se encarga de
controlar el stream de contenido multimedia en dos direcciones, de forma que los
clientes pueden pedir al servidor hacer cosas como rebobinar la pelcula, saltar al
siguiente captulo, etc. Esto se puede conseguir con streaming ya que el medio no se
descarga linealmente sino que se reproduce conforme se obtiene, y se permiten saltos
en la reproduccin, consiguiendo un acceso aleatorio al medio, incluso en saltos hacia
delante. Por otra parte, los datos del medio (el stream que contiene tpicamente audio
y vdeo sincronizados) se pueden transportar usando el protocolo estndar RTP (Real-
Time Transport Protocol), que es un protocolo de transporte que permite la
transmisin de informacin multimedia en tiempo real sobre cualquier tipo de red
(aunque su uso ms habitual es sobre redes IP usando el protocolo UDP) [2].
De esta forma quedan definidos dos canales de comunicacin entre los
clientes y el servidor de streaming:
Un canal para el control de sesin(RTSP)
Un canal para la transmisin de la informacin.(RTP/UDP/TCP)
Adicionalmente, tambin encontramos el protocolo SDP( Protocolo de
Descripcin de Sesiones), que describe los parmetros de inicializacin de los flujos
multimedia y en aquellas aplicaciones que se basan en la transmisin simultnea de
flujos de datos de audio y video, se utiliza el protocolo de control de transporte en
tiempo real (RTCP, real- time transport control protocol) para sincronizar los dos
flujos de datos multimedia antes de realizar la operacin de descodificacin, adems
de proporcionar informacin sobre la calidad del servicio. Diremos luego, que
hablaremos de Streaming Tradicional en la medida que se utilicen los protocolos antes
descriptos [3] [4] [5].

42 JAIIO - EST 2013 - ISSN: 1850-2946 - Page 287


16o Concurso de Trabajos Estudiantiles, EST 2013

2.2 Un poco de Historia


Si bien la incorporacin de contenido multimedia siempre fue una idea que estuvo
presente, en los primeros tiempos los altos costos sumado a las limitaciones tcnicas
constituan una gran dificultad que atentaba con su progreso. Las principales
cuestiones tcnicas en lo que respecta a Streaming consistan en:
Tener una capacidad de procesamiento suficiente as como tambin un ancho
de banda que soporte la requerida tasa de datos.
La creacin de paths de interrupcin de baja latencia en los sistemas
operativos con el fin de prevenir un subdesbordamineto de bufer.
Ya en los principios de los 90, con la apertura del campo multimedia por Apple en
1991 y con un usuario de internet beneficiado por:
Mejoras del ancho de banda, particularmente a finales de la dcada de los
noventa.
Aumentos en los accesos a las redes, especialmente Internet.
Uso de protocolos y formatos estndares como TCP/IP, HTTP.
La comercializacin de Internet
El progreso comenz a ser notorio. Sin embargo, fue recin con la aparicin de
RealNetworks en 1995 donde comenz a existir una solucin disponible para el gran
pblico de transmisin multimedia sobre Internet.
En 1995 RealNetworks logr transmitir por primera vez el audio de un evento, un
partido de baseball entre los Yankees y los Seattle Mariners.
Tal es as, que el streaming, como tecnologa, surge en 1995, para la transmisin de
audio, y poco ms tarde, en la transmisin de vdeo, ampliando las posibilidades de
Internet, al permitir acceder a contenidos audiovisuales sin necesidad de descarga
previa. De tal forma que, con posteriores avances en lo que respecta a redes de
transmisin de datos y computadoras hogareas ms poderosas con sistemas
operativos ms modernos, se hizo ms prctico y accesible para usuarios comunes.
Se podra decir tambin que el uso del streaming tuvo un crecimiento exponencial en
los ltimos aos tanto por su uso para el entretenimiento, como tambin por
considerarse un vehculo utilizado por las organizaciones para promocionar, vender
sus productos y servicios, as como tambin por su utilizacin en las comunicaciones.

2.3 Streaming Alternativo

Este tipo de distincin es la que utilizaremos para distinguir el steaming


tradicional de aquel que es proporcionado por un servidor web. Es decir, es el caso en
el que el servidor de streaming no se encuentra separado de servidor web. En este tipo
de streaming todos los pedidos se gestin por pedidos HTTP, no encontraremos en
este caso que se est utilizando un terminado protocolo para controlar el streaming y
otro protocolo para el envi de datos, como sucede en el streaming tradicional.
Dentro del streaming alternativo podemos encontrar distintas opciones:

42 JAIIO - EST 2013 - ISSN: 1850-2946 - Page 288


16o Concurso de Trabajos Estudiantiles, EST 2013

Descarga trivial: Cuando un usuario hace click sobre un hipervnculo de


una pgina que apunta a un archivo de audio o video, el browser sigue el
mismo proceso que para un archivo de texto o imagen. Por lo tanto, el HTTP
del browser establece primero una conexin TCP con el http del servidor que
aparece en el link. A continuacin, enva una solicitud del contenido del
archivo especificado en el hipervnculo mediante un mensaje de peticin
GET. El servidor responde enviando el contenido del archivo en un mensaje
de respuesta GET. Al recibirlo, el browser decide a partir del campo Content-
Type de la cabecera del mensaje invocar el reproductor de video y, al mismo
tiempo, le pasa el contenido del archivo comprimido. El reproductor
multimedia procede a descomprimirlo y enva el flujo de bytes resultante a la
tarjeta de sonido. Como puede evidenciarse, la desventaja de este mtodo es
que el browser debe recibir el contenido del archivo completo y esto puede
producir un retardo inaceptable si el tamao del archivo es
considerablemente grande [6].

Descarga Progresiva: Se da cuando el contenido del archivo es enviado


directamente al reproductor en lugar de hacerlo a travs del navegador. De
esta forma el reproductor procede a obtener su contenido de manera normal
mediante HTTP/TCP. Al recibir el contenido del fichero, el reproductor
simplemente dirige el flujo comprimido haca la memoria de reproduccin.
Tras un retardo predefinido para permitir que la memoria se llene
parcialmente diez segundos en el caso del audio- comienza a leer el flujo
desde la memoria y, tras descomprimirlo, enva el flujo resultante haca la
tarjeta de audio o de video. Se realizar una descarga progresiva de la
informacin, de manera que cuando se empiece a disponer de informacin,
se pueda empezar a reproducir. Se descarga usando el mximo ancho de
banda que disponen cliente y servidor, y no hay ningn control para evitar
cortes en la reproduccin: el medio se va almacenando en disco conforme se
descarga, pero si el ancho de banda es ms reducido que el necesario para la
reproduccin, la informacin se reproduce a saltos, ya que se va
reproduciendo conforme llega [7].
o Ventajas:
Fcil de configurar.
o Desventajas:
El video entero es descargado a menos que el usuario
cierre el navegador.
El video se descarga completamente por lo que el
contenido no est protegido.
El usuario no puede reproducir el video desde cualquier
momento. Solo podr ver aquella parte que se encuentre
descargada.

HTTP Pseudo-streaming: Basado en el anterior, lo que pretende es simular


lo que sera el streaming bajo demanda, agregando la posibilidad de
adelantar o retroceder la reproduccin. Es decir que las partes que se saltean

42 JAIIO - EST 2013 - ISSN: 1850-2946 - Page 289


16o Concurso de Trabajos Estudiantiles, EST 2013

no se descargan y permite reducir el ancho de banda que en determinas


situaciones se pierde. Pseudo-streaming requiere adaptaciones tanto para el
lado del cliente como para el lado del servidor. Para el lado del servidor,
existen plugins disponibles para Apache, litghttpd. Mientras que del lado del
cliente, es necesarios reproductores customizados que permiten resincronizar
el video, leer metadata, etc. Si se diera el caso de que estamos viendo un
video que podemos adelantar y que luego lo podemos encontrar en la cache
del browser, luego, el servidor est haciendo uso de HTTP Pseudo-streaming
o Ventajas:
Posibilidad de interactuar con el stream
Mejor utilizacin del ancho de banda
o Desventajas:
Necesita implementaciones tanto del cliente como del
servidor
El video no est protegido, es posible encontrarlo en al
cache del browser.
Dynamic Adaptive Streaming over HTTP (DASH): La idea central es
dividir el video en pequeas partes y proveerlo por HTTP. Luego esas partes
son combinadas en el lado del cliente y reproducidas. Este mtodo soporta
video bajo demanda y live streaming permitiendo entregar el stream correcto
teniendo en cuan saturada este la red. Existen numerosas implementaciones
de este mtodo con diferentes nombres, todas basadas en la idea antes
mencionada: HTTP Live Streaming (Apple), Smooth Streaming (Microsoft)
HTTP Dynamic Streaming (Adobe), Adaptive Bitrate (Octoshape).
o Ventajas:
Sobre HTTP ofrece una solucin muy robusta.
Mejoras en cuanto a la proteccin del contenido dado que
el video es dividido en pequeas partes.
o Desventajas:
Las diferentes implementaciones no son del todo
compatible.
Requiere un desarrollo adicional del lado del cliente.

2.4 Streaming Tradicional vs. Streaming Alternativo

La primera distincin que hay que llevar a cabo a la hora de realizar la


comparacin es el protocolo de transporte sobre los cuales se dan cada una de las
alternativas, el cual impacta notablemente en servicio de streaming que se est
proporcionando.
El streaming tradicional tiene la particularidad de poder utilizarse sobre UDP
mientras que el streaming alternativo dado que es sobre HTTP, en todas sus versiones,
trabaja sobre TCP.
Como sabemos TCP/IP es usado como la capa de transporte en Internet. Los
archivos se bajan a la cache del browser tan rpido como el sistema lo permita. TCP
incorpora control de flujo para manejar la tasa con la que baja informacin. No existe

42 JAIIO - EST 2013 - ISSN: 1850-2946 - Page 290


16o Concurso de Trabajos Estudiantiles, EST 2013

una tasa predeterminada para el envi de los datos. TCP incrementar dicha tasa hasta
que una prdida significativa de los paquetes que se han enviado indique que la red se
encuentra congestionada. Y en dicho punto, como consecuencia, la tasa de envo
disminuir. Otra desventaja que presenta TCP para su uso en streaming de video, es
que TCP hace uso del mecanismo de ventana deslizante para el control del flujo de
datos. Esto da como resultado que los paquetes se procesen ni bien llegan, por lo que
si la informacin llega muy rpido puede darse un buffer overflow. En tal caso, el
cliente notificar al servidor que disminuya la tasa de envo, de forma de evitar dicho
inconveniente o la necesidad de memorias de reproduccin grandes para ocultar el
efecto de la prdida de un segmento al usuario.
Supongamos que uno quiere transmitir un stream codificado a 40 kbit/s. La
transmisin TCP podra empezar a 10 kbit/s. Luego podra llegar a 100 kbit/s , tasa
sobre la cual se congestionara la red y por ende, quedara definida la tasa mxima.
Supongamos ahora, que un nuevo usuario se conecta a la red y la transmisin se
acelera nuevamente a 30 kbit/s. En ningn momento la tasa de transferencia se
asemeja a la tasa de codificado del stream que se quiere transmitir. Lo que da lugar a
que el usuario note que el video se ha parado [8].
En el caso de que se de una recepcin incorrecta, si se utilizara UDP, la mejor opcin
en la interpolacin de los dato o algn otro tipo de compensacin, pero en este caso al
estar implementado sobre TCP, se reenva el paquete en cuestin.
A su vez, en steaming Tradicional se gana velocidad, dado que este posee un
menor retardo que TCP a costa de sacrificar la confiabilidad que TCP ofrece, pero que
es solucionada utilizando el protocolo RTCP y RTP.
Hay que destacar tambin, la posibilidad del streaming tradicional de proveer
el contenido por medio de tcnicas multicast, ideal para la difusin de medios en vivo.
Por otro lado, con el uso de RTCP, se podr sincronizar flujos de datos de audio y
video antes de realizar la operacin de descodificacin. Incluso brindar la posibilidad
multiservidor y la capacidad de agregar un nuevo stream en una presentacin en vivo.
Se podr informar al emisor los paquetes que se pierden, se podr cambiar el tipo de
codificacin, datos el tamao del buffer e incluso negociar el mtodo de transporte
ms adecuado antes de comenzar la transferencia del flujo datos [9] [10].
Mientras que si nos centramos en el streaming alternativo podemos afirmar
que es una alternativa ms fcil de configurar, permite dado que esta implementada
sobre HTTP, llegar a una mayor audiencia, y por sobre todas las cosas ofrece un
servicio que combinado con un servidor web permite dar una solucin acorde sin la
necesidad de grandes inversiones. Obviamente dispuesto a perder determinados
beneficios y la escalabilidad que el streaming tradicional ofrece.

2.5 Resumen Comparativo


A continuacin, en la ilustracin 1 se presenta un cuadro comparativo que permite
resumir las diferencias existentes a la hora de utilizar diferentes tecnologas de
streaming.

42 JAIIO - EST 2013 - ISSN: 1850-2946 - Page 291


16o Concurso de Trabajos Estudiantiles, EST 2013

Ilustracin 1: Tabla Resumen que compara las diferentes tecnologas de streaming

4. Casos de Estudio
Se describen luego, los resultados obtenidos luego de haber analizado el
funcionamiento del streaming proporcionado por Youtube y Netflix.

4.1 Youtube

Cuando analizamos como funciona realmente el streaming propuesto por


Youtube ya a primera vista es posible evidenciar que hace uso de la tecnologa de
Adobe. El video llega incrustado como parte de un archivo cuya extensin es .swf .
Entonces cuando queremos ver un video en youtube, lo que est sucediendo es que
este nos devuelve un .swf que se descarga a la cache del browser y luego es ejecutado
por Adobe Flash Player. De esta forma, este .swf se encarga de embeber el video en el
browser, customizar como se ve el reproductor y controlar el comportamiento del
video entre otras cosas. Siendo el parmetro video_id, el que indica el id del video a
reproducir. Se pudo ver tambin, que a la hora de reproducir un video no se hace uso
del protocolo RTSP. Todas las peticiones que se realizaron para interactuar con el
video, particularmente el reproducir y el adelantar se llevan a cabo mediante http

42 JAIIO - EST 2013 - ISSN: 1850-2946 - Page 292


16o Concurso de Trabajos Estudiantiles, EST 2013

request.
Observamos que, al querer adelantar el video, lo que sucede es que se
cancela la descarga de la parte del video que actualmente se est reproduciendo y
comienza a descargarse y reproducirse la nueva parte del video desde la posicin
seleccionada por el usuario. En dicho request, es el atributo range, el que nos
determina la posicin de comienzo del video. Ms precisamente el range se refiere al
cdigo de tiempo de cada frame (fotograma o cuadro, es una imagen particular dentro
de una sucesin de imgenes que componen una animacin). A su vez, si dicha url la
decodificamos, la pegamos en la barra de direccin del navegador es posible
descargar el video desde esa posicin.
Se descarta tambin la posibilidad de encontrar paquetes RTP dado que sobre
TCP no tendran sentido. Y esto se debe a que RTP es una capa diseada para actuar
sobre protocolos no confiables proveyendo determinados beneficios como los que
proveen los protocolos confiables (garantiza orden, timestamp) sin las desventajas que
trae TCP, por lo que aplicar este tipo de combinacin sera totalmente desacertado.
Incluso utilizando Wireshark, no fue posible encontrar evidencia de paquetes con el
protocolo RTP.
La sospecha de que se estuviera haciendo DASH queda totalmente
descartada dado que no se encontraron archivos de extensin .f4v ni .F4M. El primero
seran los fragmentos que se divide el video que se esta stremeando, en cuyo
contenido se encuentra el video y el segundo describe el medio en cuestin, pudiendo
de esta forma ir determinando como debera ir variando el bitRate. Tal como establece
la especificacin de Adobe.
De todos modos, se pudo comprobar que independientemente de la
resolucin de video, en todos los casos siempre se experimento una descarga a las
mayores velocidades posibles y nunca cambiando la calidad de video durante la
reproduccin. La calidad de video en youtube es fija, si bien se puede cambiar
voluntariamente a lo largo del video, esta se mantendr constante y ser el ancho de
banda del cliente quin determine como se ver un video. A mayor ancho de banda,
mayor ser el bitrate que el cliente podr streamear. Y si se diera un cambio en la
calidad del video, producto de que youtube.com est haciendo DASH, el contenido
total del video descargado utilizando un ancho de banda y otro ancho de banda
diferente debera ser distinto. Sin embargo, utilizando 1Mb o 3Mb siempre, en cada
una de las resoluciones, el tamao del archivo final es aproximadamente el mismo.
Por lo que podemos concluir que youtube.com no muestra sus videos
mediante streaming tradicional ni tampoco HTTP Dynamic Streaming. Youtube.com
lleva a cabo pesudo-streaming para la entrega y reproduccin de sus videos. No tiene
en cuenta el ancho de banda del cliente y tampoco enva los videos al bit rate que son
codificados, usa en todos los casos la mxima velocidad de descarga. Los videos
quedan alojados en la cache del browser y todo su mecanismo de streaming se pasa en
HTTP, incluso las acciones de play y adelantar. En todos los casos hace uso de TCP.

4.2 Netflix

Analizar como NetFlix provee su contenido multimedia, por lo menos en


Windows, nos lleva a estudiar la tecnologa de streaming denominada Silverlight.
Silverlight, es un producto desarrollado por Microsoft, que permite crear aplicaciones

42 JAIIO - EST 2013 - ISSN: 1850-2946 - Page 293


16o Concurso de Trabajos Estudiantiles, EST 2013

web, particularmente RIA (Rich Internet Applicaction). A pesar de que Silverlight


tiene infinidad de utilidades nos concentraremos en la tecnologa utilizada para llevar
a cabo el streaming que es Smooth Streaming. Esta tecnologa no es otra cosa que
DASH, y es lo que realmente utiliza Netflix a la hora de proveernos un video. De esta
forma, Netflix posee sus pelculas codificados en varias calidades, y detectando
nuestro ancho de banda, descargar aquel que se adecue a nuestra velocidad de
bajada. Esto implica que ver un video con Smooth Streaming sea mucho ms suave y
rpido que con otros mtodos de streaming tradicionales.
Se evidencia que al comenzar a ver una pelcula se descarga un archivo .xap,
que al igual que suceda con youtube que era un .swf, este determinar el
funcionamiento del reproductor. Si inspeccionamos ese .xap, no es otra cosa que un
archivo comprimido que posee todo lo necesario para poder correr una aplicacin con
el plugin Silverlight. Si lo descomprimimos encontraremos siempre como mnimo dos
archivos, un manifest y el archivo propio que contiene el cdigo necesario para la
ejecucin del reproductor (.dll). Sin embargo, lo que realmente sucede con Netflix es
que el .xap suele guardarse en la cache del browser , tiene solo un archivo un .dll y
luego, se baja el manifest por separado [11].
Este manifest, describe los diferentes encoding que posee la pelcula tanto
para el audio como para el video, identificndolos con un Id y la url del host donde se
encuentran alojados. En el caso estudiado se detectaron 6 video que van desde los
0,235 Mbps a 1,750 Mbps y tres tipos de audio (espaol, ingles y portugus) con sus
respectivos bitRates.
A continuacin, comenzarn las diferentes solicitudes de los fragmentos de
video de acuerdo al ancho de banda disponible. Tal es as que se irn generando
request de este tipo:
http://959.ar.akam.nflxvideo.net/la50/156/1768216156.ismv/range/2216419-
2448828?token=133...
En los cuales, segn el ancho de banda disponible ser el fragmento que se
va a recibir, conectndose al servidor correspondiente de acuerdo a lo descripto en el
manifest. Y ser el parmetro range el que indique el offset que se necesitar para
poder reproducir el video en el momento correcto. Por lo tanto, en el request anterior
se est accediendo al host: 959.ar.akam.nflxvideo.net y luego
/la50/156/1768216156.ismv/ indica el tipo de codificacin que se est solicitando. En
este caso, segn lo descripto en el manifest se estara bajando un fragmento de un
encoding de 0,375 Mbps con una resolucin de 384x288p, en formato .ismv.
Este formato no es otra cosa que un fragmento de un video en formato
MPEG-4. Este fragmento es definido por la tecnologa Smooth como un MPG-4
Movie Fragment y es almacenado con otro archivo que permite su acceso de forma
rpida y aleatoria. De esta forma, cuando un cliente solicita un fragmento en
determinada ubicacin, el servidor encuentra de forma dinmica el Movie Fragment
box con el MPG-4 contiguo y solo enva este a travs de la red [12]. En otras
palabras, el servidor no tiene una pelcula dividida en millones de chucks, sino que
estos son creados dinmicamente por cada solicitud. Lo que da lugar ahorros en lo
que respecta a manejo de archivos. Todo esto da lugar a que el video se vaya
descargando en pequeas partes y no en una sola unidad como en la descarga
progresiva, que es el caso de Youtube.
Hay que destacar el hecho, de que antes de comenzar a reproducir la pelcula,

42 JAIIO - EST 2013 - ISSN: 1850-2946 - Page 294


16o Concurso de Trabajos Estudiantiles, EST 2013

se van descargando fragmentos de diferente bitRate en diferentes conexiones TCP,


luego de un tiempo, solo quedarn dos conexiones TCP, una encargada de obtener el
audio y otra el video. Como se notar, siempre que sea posible se pretender
descargar aquellos fragmentos de mayor resolucin. A su vez, si bien antes dijimos
que luego de un tiempo solo perduraban dos conexiones, una para audio y otra para
video, se puede ver que en determinados momentos ambas conexiones descargan
video. Y esto se debe seguramente, para poder estar transmitiendo siempre contenido
en ambas conexiones. Si la conexin de audio no est siendo utilizada para la
transmisin de audio entonces se aprovecha y se enva contenido de video.
Hay que aclarar que Netflix no nos permite definir un tipo de resolucin de
bajada, en todos los casos transmitir aquel fragmento de mayor resolucin de
acuerdo al ancho de banda disponible. Sin embargo, si se reduce la ventana del
reproductor a tal punto de no poder ver el video, la resolucin de los fragmentos ser
al mnimo BitRate. Por otro lado, si lo que pretendemos es adelantar la pelcula, esta
operacin tambin se realiza mediante una http request, el cual una vez solicitado,
puede demorar un tiempo la reproduccin dado que antes, el reproductor pretender
cargar determinado contenido en el buffer. Cada vez que adelantamos, se produce una
nueva conexin TCP.
Por lo que entonces, podemos concluir que Netflix, hace uso de una tpica
tecnologa de streaming adaptativo, el video/audio es cortado en segmentos pequeos,
por lo general denominados chunks. Cada chunk son por lo general de 2 a 4 segundos
de duracin, los cuales, por un lado se los puede ver como un grupo de imgenes y
por el otro, hay que afirmar, que cada chunk no tiene dependencia con el pasado o
futuro del resto de los otros chucks. Por ende cada uno puede ser, decodificado
independientemente de cualquier otro chuck. De esta forma, cada chuck es descagado
utilizando HTTP progressive download.
Ahora, la parte que da lugar a que podamos afirmar que Netflix, utiliza
adaptative streamings es debido a que el browser va solicitando chucks de diferente
bitrate. De esta forma, como los servidores web tienden a enviar la informacin a la
mayor velocidad posible, el cliente puede estimar el ancho de banda y decidir
descargar chucks ms grandes o ms chicos, dado que el video se encuentra
codificado para distintas definiciones, por lo que cada envo se encuentra
condicionado al ancho de banda del usuario. Toda esta informacin, es posible
obtenerla desde el manifest, antes explicado y un correcto funcionamiento del
reproductor Silverlight [13].

5. Conclusin
A lo largo de este trabajo, se pudo darle un marco de referencia a lo que se
entiende cuando hablamos de streaming. Evidenciando un streaming tradicional,
basado en protocolos tradicionales diseados para la transferencia de datos sujetos a
limitaciones de tiempo real y un streaming alternativo que sobre el protocolo HTTP
pretende dar una solucin similar.
De esta forma el streaming tradicional se caracteriz en poder enviar video y
que este llegue al usuario sin pausas, que este pudiera controlar su recepcin as como
tambin, poder recibir video en tiempo real con la mejor calidad de acuerdo a su
ancho de banda y poder ir notificando la calidad del servicio que estaba recibiendo.

42 JAIIO - EST 2013 - ISSN: 1850-2946 - Page 295


16o Concurso de Trabajos Estudiantiles, EST 2013

Mientras que el streaming alternativo, se presenta como una solucin capaz de


simular el mismo comportamiento que el streaming tradicional, pero de una forma
ms sencilla aunque con determinadas limitaciones.
Se destaca particularmente la opcin de streaming adaptativo como la opcin
que hoy en da, puede que no est implementada en todos los sitios que ofrecen
videos, pero es la tecnologa que basndose en los protocolos tradicionales supo
adaptarlos y aplicarlos al contexto actual. Permiti desligarse de la necesidad de
requerir un servidor de streaming dedicado, y centrar el trfico entre cliente y servidor
a travs de HTTP. Lo que dio lugar a tener un mayor alcance (mayor audiencia), dado
que el trafico HTTP puede alcanzar la mayora de los dispositivos e incluso a
diferencia de otros protocolos, los firewalls no los bloquean y, por sobre todas las
cosas, sentarse sobre la base de una tecnologa ms escalable.
Un ejemplo del uso de esta tecnologa fue Netflix, que haciendo uso de
Smooth Streaming hacia llegar su contenido a sus usuarios. Sin embargo, Smooth
Streaming era solo una de las tantas formas para ofrecer streaming adaptativo. Hay
otras alternativas, Smooth Streaming era una de ellas, pero tambin estaban las
opciones propuestas por Adobe, Octashape o Apple.
De todos modos, si bien hoy en da, existen actores fundamentales y cada
uno ofrece su tecnologa similar por separado, no existe una estandarizacin definida
en lo que respecta a Streaming adaptativo, pero se est en camino a eso. Puede
tambin que en un futuro cercano, sean los mismos browsers los que incorporen de
manera nativa las funcionalidades de streaming.
Tal es as, que la importancia del streaming de video seguir creciendo, y se
deber seguir investigando, controlando y evaluando las tendencias del mercado de tal
forma de poder elegir la tecnologa correcta y que proporcione un stream de la mejor
calidad segn sean las condiciones tcnicas de enlace que tenga el grupo de usuarios.
La tecnologa ser fundamental, determinar aspectos claves en los costos y en la
complejidad del sitio que la implemente. Pero tampoco habr de olvidarse, que el
stream a ofrecer deber estar orientado a la audiencia que lo consuma y desde donde
lo consuma. Por lo que determinar que una tecnologa es mejor que otra o utilizar este
protocolo o aquel depender de la audiencia a la que se quiera llegar, la complejidad
que se est dispuesto asumir, los costos relacionados con dicha complejidad, la
calidad del servicio que se quiera proporcionar y por sobre todas las cosas el tipo de
aplicacin que se est desarrollando. De todos modos, en cualquier variante que se
lleve a cabo el streaming, se podr notar de fondo que dicha implementacin
perseguir siempre los mismos conceptos sobre los cuales los protocolos tradicionales
se establecieron.
Luego se puede afirmar que el mundo del streaming no se limitaba solo a los
protocolos tradicionales, y tampoco sus alternativas acotaban la cuestin. Existan y
existen numerosos aspectos que no fueron considerados en este trabajo pero que
tambin juegan y condicionan el modo de obtener un correcto desempeo a la hora de
llevar a cabo streaming de video. Con solo mencionar cuestiones como buffering, tipo
de codecs, formatos y dems dan nocin de lo complejo que se convertido el mundo
del streaming.

42 JAIIO - EST 2013 - ISSN: 1850-2946 - Page 296


16o Concurso de Trabajos Estudiantiles, EST 2013

6. Bibliografa

[1] "Utilizacin de video Streaming." J. Aramberri y J. Lasa. N.p., n.d. Web. 07 Aug.
2012.<http://www.rediris.es/difusion/publicaciones/boletin/58-59/ponencia10.html />.
Sitio
[2] "RTSP: FAQ." Computer Science - Columbia University. N.p., n.d. Web. 07 Aug.
2012. < http://www.cs.columbia.edu/~hgs/rtsp/faq.html >.Sitio
[3] Streaming de Audio y Vdeo Grupo de Redes de Computadoras Universidad
Pontificia de Valencia. N.p., n.d. Web. 07 Aug. 2012.
<http://www.grc.upv.es/docencia/tdm/practicas/P3.pdf >. Prctica
[4] "RTSP" Computer Science - Columbia University. H. Schulzrinne, A. Rao, R.
Lanphier. N.p, 2 Feb. 1998. Web. 07 Aug. 2012.
<http://www.cs.columbia.edu/~hgs/rtsp/draft/draft-ietf-mmusic-rtsp-09.pdf >. Paper
[5] " RTP: A Transport Protocol for Real-Time Applications" The Internet
Engineering Task Force (IETF). H. Schulzrinne,S. Casner, R. Frederick,V. Jacobson,
Jul 2003. Web. 07 Aug. 2012. < http://www.ietf.org/rfc/rfc3550.txt >. Paper
[6] "Video Delivery in HTTP." Roman10. N.p., n.d. Web. 07 Aug. 2012.
<http://www.roman10.net/video-delivery-in-http/ />. Sitio
[7] "Redes de Computadoras e Internet". Fred Halsall, Editorial Pearson
[8] "Streaming Media Bible". Steve Mack, Editorial Hungry Minds.
[9] "RTCP, RTP Control Protocol." Network Sorcery, Inc. N.p., n.d. Web. 07 Aug.
2012. < http://www.networksorcery.com/enp/protocol/rtcp.htm >.Sitio
[10] "6.1 RTCP Packet Format." Freesoft.org. N.p., n.d. Web. 10 Aug. 2012.
<http://freesoft.org/CIE/RFC/1889/14.htm >.Sitio
[11] " An Experimental Evaluation of Rate-Adaptation Algorithms in Adaptive
Streaming over HTTP". Saamer Akhshabi, Ali C. Begen, Constantine Dovrolis, Feb
2011. Web. 07 Aug. 2012. <http://www.cc.gatech.edu/~dovrolis/Papers/final-saamer-
mmsys11.pdf>. Paper
[12]Live_and_On_Demand_Video_with_Silverlight_and
IIS_Smooth_Streaming_FINAL Microsoft N.p., n.d. Web. 10 Aug. 2012.
<http://download.microsoft.com/download/3/A/4/3A4A066C-6543-4BC1-
A8B_and_On_Demand_Video_with_Silverlight_and%20IIS_Smooth_Streaming_
FINAL.pdf />.Sitio
[13] "Analysis of Netflixs security framework for Watch Instantly service " Pomelo,
LLC TechMemo. N.p, Mar 2009. Web. 07 Aug. 2012.
<http://pomelollc.files.wordpress.com/2009/04/pomelo-tech-report-netflix.pdf>.
Paper.

42 JAIIO - EST 2013 - ISSN: 1850-2946 - Page 297

También podría gustarte