← Volver a la lista de posts

Una muy breve historia de Internet

A principios de los años 60’s, en Estados Unidos, varias universidades tenían computadores de tiempo compartido: enormes máquinas, con una fracción de la capacidad de tu teléfono móvil actual, que se accedían a través de terminales sin pantalla, permitiendo a varios compartir los recursos del computador de forma simultánea.

Muchos creían que los computadores habían llegado a una cúspide evolutiva y no había mucho por desarrollar en ese campo. Así que la atención se centró en pensar cómo podrían comunicarse estos computadores de forma remota. Las aplicaciones serían infinitas: chat, juegos, transferencia de archivos, publicación de documentos, etc.

La idea fue desarrollada paralelamente por Paul Baran en Estados Unidos y Donald Davies en Inglaterra. Consistía de una red parecida a la telefónica pero con dos cambios importantes. El primero era construir la red a partir de muchos nodos interconectados entre sí (la red telefónica es centralizada o descentralizada con unos cuantos nodos principales).

Screenshots

La nueva red tendría la topología distribuída. Imagen tomada de http://www2.cffn.ca/usha/part-iii-article-by-pramod-dhakal/129-the-law-of-rule-centralized-decentralized-and-distributed-systems

El segundo cambio era mucho más revolucionario: partir la información en paquetes que volverían a ser reensamblados por el receptor. Cuando descuelgas el teléfono y haces una llamada, ocupas un canal por la duración de la llamada. La red soporta un número limitado de canales simultáneos por lo que se satura rápidamente. Pero lo realmente inaceptable es la subutilización del canal (piensa en las pausas para respirar, los incómodos silencios, o cuando dejas descolgado el teléfono para abrir la puerta). Al dividir la información en paquetes se puede hacer un mejor uso del medio, porque solo se usa cuando se está enviando información. Otra ventaja es que los paquetes pueden tomar diferentes rutas de ser necesario.

Pero para lograr una red basada en enrutamiento de paquetes (packet switching), los computadores tendrían que implementar algoritmos de enrutamiento, detección de errores, reensamblado de paquetes, etc. La solución parecía viable en un principio, al fin y al cabo los computadores son muy buenos para ese tipo de tareas. Desafortunadamente a AT&T, en Estados Unidos, no le interesó la idea en 1965 y el tema se congeló.

El surgimiento de ARPANET

Dos años después, en 1967, se inició un proyecto en una pequeña agencia del gobierno de Estados Unidos llamada ARPA (Advanced Research Projects Agency) que había nacido en 1958 como respuesta al lanzamiento del Sputnik 1, pero que, después del nacimiento de la NASA, se había reducido a financiar proyectos exploratorios en universidades.

El proyecto consistía en crear una red que conectara a varias universidades a través de líneas telefónicas. Sin embargo, a ninguna universidad le interesaba asignar recursos de su computador para ejecutar las tareas que requería la red (implementación de algoritmos de enrutamiento, detección de errores, reensamblado de paquetes, etc.) La solución fue crear e instalar una máquina adicional en cada universidad entre el computador y la línea telefónica que se encargaría de las tareas propias de la red. A esta máquina se le dio el nombre de IMP (Interface Message Processor) y es lo que hoy en día conocemos como routers (enrutadores).

Screenshots

Un IMP. Equivalente al router que usas en tu hogar para conectarte a Internet. Imágen tomada de http://galleryhip.com/interface-message-processor.html

La idea era muy simple. Cuando un computador (host) se quería comunicar con otro, enviaba un mensaje a través del IMP. El IMP partía el mensaje en paquetes (cada paquete tenía un encabezado y parte del mensaje) y los redireccionaba al IMP destino que reensamblaba el mensaje y se lo pasaba al computador (host). La forma en la que se interpretaba el mensaje era responsabilidad de los computadores (hosts), los IMP’s se limitaban a transportar la información.

Protocolos

En 1968 un grupo de jóvenes se empezó a reunir periódicamente y a definir los primeros protocolos que se utilizarían sobre la red. Para evitar ofender a los creadores del IMP y de la red, llamaron los documentos “petición para comentarios”. El 7 de Abril de 1969 lanzaron el primer RFC (Request For Comments), el RFC 1, que define la comunicación entre el host y el IMP. El grupo se empezó a llamar a sí mismo el Network Working Group (NWG) y en los siguientes años definieron otros protocolos como el FTP - File Transfer Protocol (RFC 114) y el Email (RFC 196).

En Octubre de 1969 se hizo la primera comunicación entre dos hosts, uno en UCLA (University of California) y el otro en SRI (Stanford Research Institute), cada uno con su respectivo IMP. La comunicación fue un éxito y aproximádamente cada mes se agregaba un nuevo nodo (universidad) a la red.

Algunas personas empezaron a pensar cómo implementar una red de packet-switching sobre medios distintos a las costosas líneas telefónicas que usaba ARPANET. La ALOHANET, en Hawaii, fue una de las primeras y utilizaba pequeños radios, idénticos a los que utilizaban los taxis hace algunos años, para transportar los mensajes. Otras redes empezaron a surgir, pero no estaban interconectadas porque utilizaban diferentes medios, y diferentes tamaños y encabezados de paquetes para transmitir la información.

La solución, propuesta en Mayo de 1974, fue usar routers que conectaran las diferentes redes que existían en el momento. El router entendería los paquetes de las dos redes a las que estaba conectada. Pero el principal problema del esquema era que el router necesitaría recibir el mensaje completo de una red antes de redireccionarlo a la otra; tampoco había una forma estándar de identificar los hosts dentro de cada red. Se divisó una solución que se convirtió en lo que hoy conocemos como los protocolos TCP/IP.

El objetivo era que las redes sirvieran de transporte para otros paquetes “estándar” que todos entendieran. Los llamaron datagramas para mayor claridad y es lo que hoy conocemos como el protocolo TCP (Transmission Control Protocol).

La forma en que hoy funciona el transporte de carga nos sirve como analogía. Los datagramas TCP son equivalentes a los contenedores, que pueden ser transportados por diferentes medios (tierra, aire, o mar), sin importar su contenido. TCP también se encargaría de establecer la conexión, y garantizar la confiabilidad de la comunicación.

Screenshots

Los datagramas TCP son equivalentes a los contenedores de carga, no importa por qué red están siendo transportados, ni la mercancia que contengan. Imagen tomada de http://www.shippingherald.com/NEWS/Containers/tabid/72/currentpage/2/Default.aspx

Los datagramas TCP se encapsulan en otro paquete con encabezados que definen hacia dónde se dirige el mensaje. Esto se definió en el IP (Internet Protocol) y es por eso que se les llama direcciones IP.

Screenshots

Las capas TCP/IP. Paquetes viajando dentro de otros paquetes de la misma forma en que las cajas con mercancia viajan dentro de otras cajas. Imagen tomada de http://www.technologyuk.net/the_internet/internet/tcp_ip_stack.shtml

Las ventajas para las aplicaciones son enormes porque solo necesitan definir el contenido y el destino (la dirección IP) de los mensajes. TCP/IP se encarga de dividir el contenido, envolverlo y redireccionarlo sin importar el medio que se esté utilizando. Gracias a TCP/IP es que hoy en día puedes navegar por Internet a través de una red Wifi, una red celular, o a través de un cable conectado al router de tu hogar.

El final de ARPANET, el inicio de Internet

A mediados de los años 80’s nuevas redes proliferaban en todo el mundo. Se había creado una red de redes, o Internet. En 1983 ARPANET hizo la migración a TCP/IP, pero los costos del mantenimiento de la red seguían creciendo, mientras otras redes, más rápidas, eran más fáciles de mantener. En 1998 la ARPANET fue dada de baja. Ese año, la Universidad de California patrocinó un simposio para conmemorar la ARPANET. En su discurso, David Cohen dijo las siguientes palabras:

In the beginning ARPA created ARPANET.
And the ARPANET was without form and void.
And the darkness was upon the deep.
And the spirit of the ARPA moved upon the face of the network and ARPA said, 'Let there be a protocol', and there was a protocol. And ARPA saw that it was good.
And ARPA said, 'Let there be more protocols' and it was so. And ARPA saw that it was good.
And ARPA said, 'Let there be more networks' and it was so.

En 1989 Tim Berners-Lee propuso el proyecto World Wide Web (WWW) trabajando para CERN, que era en su momento el nodo de Internet más grande en Europa … fue el inicio de una nueva revolución que hoy seguimos viviendo.

La historia en detalle la encuentras en el libro Where Wizards Stay Up Late: The Origins of the Internet.

¿Cómo convertirte en Desarrollador Web?

Descarga gratis el e-book

Conoce la mentalidad, los roles y las tecnologías que debes saber para convertirte en desarrollador Web.

Descargar e-book