1 #LyX 1.3 created this file. For more info see http://www.lyx.org/
11 \paperpackage widemarginsa4
15 \use_numerical_citations 0
16 \paperorientation portrait
19 \paragraph_separation indent
21 \quotes_language english
29 Introducción a los Sistemas Distribuídos (74.43)
47 El protocolo PPP es muy utilizado para establecer una comunicación entre
48 2 redes (routers), ya sea entre LANs o entre una LAN y WAN u otras redes
50 Incluso es útil para comunicar un sólo host a una red distante (donde no
51 sería viable tender un cable o utilizar un medio inalámbrico).
52 Al poder ser montado sobre líneas telefónicas conmutadas, este protocolo
53 fue (y es) muy utilizado para proveer acceso a internet.
60 \begin_inset Float figure
67 \begin_inset LatexCommand \label{cap:Diagrama-de-estados-ppp}
71 Diagrama de estados de una conexión PPP
84 Lo primero que debe hacer el protocolo es establecer una conexión física
85 entre las dos puntas de la comunicación, para esto debe discar el número
86 si se utiliza sobre una línea telefónica conmutada, para establecer el
88 Una vez establecido el canal, empieza a actuar el LCP (Link Control Protocol)
89 que negocia, enviando frames PPP, los parámetros de la conexión.
90 Una vez acordados estos parámetros, puede realizarse una etapa de autenticación
91 , para verificar la identidad de las puntas y así permitir o no que la comunicac
93 Finalmente, si todo resultó bien, se envía una serie de paquetes NCP (Network
94 Control Protocol) para configurar la capa de red (como la dirección IP,
95 si se quisiera utilizar el protocolo TCP/IP en dicha capa).
98 En este momento las dos puntas de la conexión están comunicadas y pueden
99 realizar todas sus tareas como si estuvieran conectadas en una LAN.
102 Un vez finalizado, se procede prácticamente de forma inversa a como se estableci
103 ó la conexión para liberarla.
104 Primero se libera la IP a través del procotocolo NCP, luego se libera el
105 enlace cerrando la conexión de la capa LCP y finalmente se cierra la conexión
106 física (se corta el módem), si fuera necesario.
109 Se puede ver un diagrama de estados de este proceso en la figura
110 \begin_inset LatexCommand \vref{cap:Diagrama-de-estados-ppp}
120 Entre las cosas que se pueden configurar (negociando a través del protocolo
121 LCP) está el tamaño de la cabecera del frame (ya que los campos
129 generalmente son fijos y pueden evitarse, el campo
133 puede ser de 1 o 2 bytes y el
137 de 2 o 4) y el máximo tamaño del
142 Estos parámetros se establecen con valores por omisión para poder ser negociado
143 s luego con el protocolo LCP.
146 El protocolo NCP es muy específico sobre qué protocolo de red se quiera
147 negociar, por lo que es muy difícil hablar en términos generales de él.
148 Para el caso más común, donde se configura una capa de red IP, se utiliza
149 el protocolo IPCP (IP Control Protocol) cuya tarea se limita prácticamente
150 a la asignación de la IP (aunque puede negociar compresión de cabeceras
152 Hay también extensiones, como la extensión para configurar servidores de
153 nombre (definido en la RFC 1877
154 \begin_inset Quotes eld
157 PPP Internet Protocol Control Protocol Extensions for Name Server Addresses
158 \begin_inset Quotes erd
164 Configuración de los routes sobre línea dedicada
165 \layout Subsubsection
168 \layout Subsubsection
170 Sin modems (null modems)
176 Tablas de ruteo (simulación)
179 Análisis de la captura HTTP
182 Registro de un nuevo usuario
183 \layout Subsubsection
188 Requirió para cargar el
192 16 mensajes HTTP, 8 GET y 7 respuestas 200 (OK) y 1 404 (NOT FOUND), correspond
193 ientes a dichos mensajes.
194 Los 8 GET fueron para pedir los siguientes archivos:
226 (que devolvió NOT FOUND).
227 Para la página específica de registro de un usuario (el formulario) solo
228 requirió 2 mensajes HTTP (GET y su respuesta) ya que las imágenes ya las
229 tenía en el cache el navegador.
230 Una vez presionado el botón de ENVIAR se observan 4 mensajes más HTTP,
231 primero un POST para enviar los datos del formulario al servidor, luego
232 su correspondiente respuesta 200 (OK).
233 Finalmente se vuelve a cargar el
237 para lo que se utilizan 2 mensajes más (GET y su respuesta 200).
238 Nuevamente observamos que como las imágenes están en el cache, no se vuelven
240 \layout Subsubsection
245 Lo primero que se observa son 3 segmentos para establecer la conexión (SYN
246 y ACK), luego por cada mensaje HTTP se observa al menos 2 segmentos TCP,
247 el que lleva el mensaje HTTP y el ACK que confirma la recepción de dicho
249 Además, si el mensaje HTTP es mayor a algo menos de 1500 bytes (tamaño
250 del MTU de ethernet), se observa la fragmentación y por cada fragmento
251 se generan 2 nuevos segmentos TCP (nuevamente uno que lleva el fragmento
252 de mensaje HTTP y el ACK correspondiente).
253 Finalmente se observan 4 segmentos TCP para la desconexión (FIN y ACK).
256 Para obtener el index.php y sus imágenes se observa que se hace todo en la
257 misma conexión, pero al estar ociosa durante un tiempo el servidor http
258 pide la desconexión y cuando se va a cargar la siguiente página vuelve
259 a iniciar una nueva conexión.
262 En total se observaron 4 conexiones:
265 index.php+imagenes: 53 segmentos (incluyendo 3 segmentos de conexión y 4
269 index.php?NuevoUsuario: 27 segmentos (incluyendo 3 segmentos de conexión
273 index.php?GuardarUsuario+index.php: 97 segmentos (incluyendo 3 segmentos de
274 conexión y 4 de desconexión)
278 \layout Subsubsection
283 Al ser el protocolo IP el transporte de los segmentos TCP, se observa que
284 para cada segmento, hay un paquete IP que lo transporta (incluyendo los
285 segmentos de control, como SYN y ACK).
286 No hay otro tipo de paquete IP que no este asociado a un segmento TCP.
289 Cantidad de paquetes IP: 177
290 \layout Subsubsection
295 Al ser el protocolo ethernet el transporte de los paquetes IP, se observa
296 que para cada paquete, hay un frame ethernet que lo transporta.
297 En esta actividad no se aprecia otro tipo de frame ethernet que no este
298 asociado a un paquete IP.
301 Cantidad de frames ethernet: 177
304 Nueva pregunta de la FAQ
307 A partir de ahora sólo enumeraremos la cantidad de
311 y mencionaremos si hay alguna diferencia con la actividad anterior, ya
312 que la mecánica es muy similar.
313 \layout Subsubsection
318 12 mensajes en total:
321 GET /~luca/foro/index.php?module=faqs&accion=AgregarPregunta HTTP/1.1
324 HTTP/1.1 200 OK (text/html)
327 GET /favicon.ico HTTP/1.1
330 HTTP/1.1 404 Not Found (text/html)
333 POST /~luca/foro/index.php?module=faqs&accion=guardarpregunta HTTP/1.1
336 HTTP/1.1 200 OK (text/html)
339 GET /~luca/foro/index.php?module=faqs HTTP/1.1
342 HTTP/1.1 200 OK (text/html)
345 GET /~luca/foro/avatars/phpQe1MqS HTTP/1.1
348 HTTP/1.1 304 Not Modified
351 GET /favicon.ico HTTP/1.1
354 HTTP/1.1 404 Not Found (text/html)
355 \layout Subsubsection
362 index.php?module=faqs&accion=AgregarPregunta
364 se reutiliza una conexión previa así que no hay SYN y se utilizan 10 segmentos
365 TCP (incluyendo los 4 de la desconexión).
370 se reutilizó otra conexión diferente, por lo cual tampoco se presentan
371 los segmentos de conexión.
372 En ésta se utilizan 8 segmentos TCP (incluyendo la desconexión).
373 Finalmente el envío de los datos se realiza todo en una nueva conexión
374 que se compone de 88 segmentos TCP (incluyendo conexión y desconexión).
375 \layout Subsubsection
380 En total se utilizan 106 paquetes IP.
381 \layout Subsubsection
386 En total se utilizan 106 frames ethernet.
390 \layout Subsubsection
395 GET /~luca/foro/index.php?module=faqs&accion=NuevaRespuesta&idpreg=1 HTTP/1.1
398 HTTP/1.1 200 OK (text/html)
401 GET /favicon.ico HTTP/1.1
404 HTTP/1.1 404 Not Found (text/html)
407 POST /~luca/foro/index.php?module=faqs&accion=guardarrespuesta HTTP/1.1
410 HTTP/1.1 200 OK (text/html)
413 GET /~luca/foro/index.php?module=faqs&accion=Mostrarrespuestas&idpreg=1 HTTP/1.1
416 HTTP/1.1 200 OK (text/html)
419 GET /~luca/foro/avatars/phpQe1MqS HTTP/1.1
422 HTTP/1.1 304 Not Modified
425 GET /~luca/foro/avatars/phpGifOBK HTTP/1.1
428 HTTP/1.1 304 Not Modified
431 GET /favicon.ico HTTP/1.1
434 HTTP/1.1 404 Not Found (text/html)
437 Total: 14 mensajes HTTP
438 \layout Subsubsection
445 index.php?module=faqs&accion=NuevaRespuesta&idpreg=1
447 : 10 (reutiliza conexión, incluye desconexión)
454 : 7 (reutiliza conexión, incluye desconexión)
457 Resto: 31 (incluye conexión y desconexión)
458 \layout Subsubsection
463 Total: 48 paquetes IP.
464 \layout Subsubsection
469 Total: 48 frames ethernet.
472 Análisis de la captura FTP
478 La captura fue realizada transfiriendo un archivo binario de 1.9 Mb, llamado
479 db4o-4.5-mono.tar.gz.
480 Para la transferencia se han intercambiado 16 mensajes FTP 8 response y
484 Lo primero que se recibe es el response del server dando su identificacion
486 Luego un request del comando USER y la respuesta del servidor diciendo
487 que se necesita password para dicho usuario.
488 El siguiente comando es PASS con el que se envia el password y recibimos
489 la respuesta de que estamos loggeados.
492 El cliente envía un SYST para saber el tipo de sistema que hay del otro
493 lado, a lo que el server responde UNIX Type: L8.
494 Luego se cambia el tipo de modo de transferencia con TYPE y a continuación
495 se hace un PORT para establecer un canal de comunicación.
498 Como último comando se envía RETR para traer un archivo, luego recibimos
499 una respuesta de que se estableció un canal binario y por último un response
500 cuando se completo la transferencia.
503 También se registraron 1346 paquetes FTP-DATA intercambiados durante la
504 transferencia del archivo.
505 Once de dichos paquetes correspondieron a paquetes de control conteniendo
506 TCP Previous segment lost.
507 El resto corresponden a envío de 1448 bytes de datos transferidos.
513 Lo primero que se observa son 3 segmentos para establecer la conexión (SYN
514 y ACK) entre un puerto alto (35631) y el puerto FTP del server.
515 Luego 2 paquetes para la autenticación de usuario y a continuación está
516 la negociación del puerto y el comando RETR usando 34 segmentos.
519 Sigue a continuación la transferencia del archivo entre el puerto ftp-data
520 del servidor y el puerto local 32985.
523 La transferencia consume 1466 paquetes, de los cuales tenemos algunos de
525 Hay 112 ACK, 5 paquetes TCP ACKed lost segment y 3 de TCP Window Update.
528 La comunicación termina con 11 segmentos TCP.
534 En total se utilizan 1516 paquetes IP.
540 En total se utilizan 1516 frames ethernet.
543 Análisis de la captura Telnet
546 Se realizó la captura al inicio de una conexión mediante telnet al servidor
547 donde se encontraba el archivo RFC792 al cual se le modificaron 5 líneas
548 (una en cada hoja) se lo guardó y luego se desconecto del servidor cerrando
555 Se contaron en total 717 mensajes telnet, donde en su mayoría contenían
556 cada uno de ellos, un caracter correspondiente a una tecla presionada y
557 en algunas ocasiones líneas completas transmitidas por el servidor hacia
559 Tambíen se puede notar que los primeros mensajes pertenecen a la negociación
560 del protocolo e intercambio de parámetros.
566 Como en los protocolos anteriores se puede observar que se utilizan 3 segmentos
567 para establecer la conexión (SYN, ACK), y que todos los mensajes telnet
568 van montados en un segmento TCP.
569 Por lo tanto tendremos tantos segmentos TCP como mensajes de telnet haya
570 sumando además los segmentos TCP de control, en total 1005 segmentos fueron
578 Cada segmento TCP va acompañado por un paquete IP, en total 1005 paquetes
585 Analogamente al caso anterior, podemos observar 1005 frames ethernet.