Exercicios Lista 2 Kurose, Ross - 2013 - Camada de Aplicação

Fazer download em pdf ou txt
Fazer download em pdf ou txt
Você está na página 1de 7

124 yREDES DE COMPUTADORES E A INTERNET

EXERCÍCIOS
DE FIXAÇÃO E PERGUNTAS

Questões de revisão do Capítulo 2

SEÇÃO 2.1

R1. Relacione cinco aplicações da Internet não proprietárias e os protocolos de camada de aplicação que elas
usam.
R2. Qual é a diferença entre arquitetura de rede e arquitetura de aplicação?
R3. Para uma sessão de comunicação entre um par de processos, qual processo é o cliente e qual é o servidor?
R4. Em uma aplicação de compartilhamento de arquivos P2P, você concorda com a afirmação: “não existe
nenhuma noção de lados cliente e servidor de uma sessão de comunicação”? Justifique sua resposta.
R5. Que informação é usada por um processo que está rodando em um hospedeiro para identificar um processo
que está rodando em outro hospedeiro?
R6. Suponha que você queria fazer uma transação de um cliente remoto para um servidor da maneira mais rápida
possível. Você usaria o UDP ou o TCP? Por quê?
R7. Com referência à Figura 2.4, vemos que nenhuma das aplicações relacionadas nela requer “sem perda de
dados” e “temporização”. Você consegue imaginar uma aplicação que requeira “sem perda de dados” e seja
também altamente sensível ao atraso?
R8. Relacione quatro classes de serviços que um protocolo de transporte pode prover. Para cada uma, indique se
o UDP ou o TCP (ou ambos) fornece tal serviço.
R9. Lembre-se de que o TCP pode ser aprimorado com o SSL para fornecer serviços de segurança processo a
processo, incluindo a decodificação. O SSL opera na camada de transporte ou na camada de aplicação? Se
o desenvolvedor da aplicação quer que o TCP seja aprimorado com o SSL, o que ele deve fazer?

SEÇÕES 2.2-2.5

R10. O que significa protocolo de apresentação (handshaking protocol)?


R11. Por que HTTP, FTP, SMTP, POP3 rodam sobre TCP e não sobre UDP?
R12. Considere um site de comércio eletrônico que quer manter um registro de compras para cada um de seus
clientes. Descreva como isso pode ser feito com cookies.
R13. Descreva como o cache Web pode reduzir o atraso na recepção de um objeto requisitado. O cache Web
reduzirá o atraso para todos os objetos requisitados por um usuário ou somente para alguns objetos? Por quê?
R14. Digite um comando Telnet em um servidor Web e envie uma mensagem de requisição com várias linhas.
Inclua nessa mensagem a linha de cabeçalho ,IPRGLºHGVLQFH: para forçar uma mensagem de
resposta com a codificação de estado 1RW0RGLºHG.
R15. Por que se diz que o FTP envia informações de controle “fora da banda”?
R16. Suponha que Alice envie uma mensagem a Bob por meio de uma conta de e-mail da Web (como o Hotmail
ou gmail), e que Bob acesse seu e-mail por seu servidor de correio usando POP3. Descreva como a mensagem
vai do hospedeiro de Alice até o hospedeiro de Bob. Não se esqueça de relacionar a série de protocolos de
camada de aplicação usados para movimentar a mensagem entre os dois hospedeiros.
R17. Imprima o cabeçalho de uma mensagem de e-mail que tenha recebido recentemente. Quantas linhas de
cabeçalho Received: há nela? Analise cada uma.
R18. Do ponto de vista de um usuário, qual é a diferença entre o modo ler-e-apagar e o modo ler-e-guardar no
POP3?
CAMADA DE APLICAÇÃO y
125
R19. É possível que o servidor Web e o servidor de correio de uma organização tenham exatamente o mesmo
apelido para um nome de hospedeiro (por exemplo, foo.com)? Qual seria o tipo de RR que contém o nome
de hospedeiro do servidor de correio?
R20. Examine seus e-mails recebidos e veja o cabeçalho de uma mensagem enviada de um usuário com um
endereço de correio eletrônico .edu. É possível determinar, pelo cabeçalho, o endereço IP do hospedeiro do
qual a mensagem foi enviada? Faça o mesmo para uma mensagem enviada de uma conta do gmail.

SEÇÃO 2.6

R21. No BitTorrent, suponha que Alice forneça blocos para Bob durante um intervalo de 30 s. Bob retornará,
necessariamente, o favor e fornecerá blocos para Alice no mesmo intervalo? Por quê?
R22. Considere um novo par, Alice, que entra no BitTorrent sem possuir nenhum bloco. Sem qualquer bloco, ela
não pode se tornar uma das quatro melhores exportadoras de dados para qualquer dos outros pares, visto que
ela não possui nada para enviar. Então, como Alice obterá seu primeiro bloco?
R23. O que é uma rede de sobreposição? Ela inclui roteadores? O que são as arestas da rede de sobreposição?
R24. Considere um DHT com uma topologia da rede de sobreposição (ou seja, cada par rastreia todos os pares no
sistema). Quais são as vantagens e desvantagens de um DHT circular (sem atalhos)?
R25. Relacione pelo menos quatro diferentes aplicações que são apropriadas naturalmente para arquiteturas P2P.
(Dica: Distribuição de arquivo e mensagem instantânea são duas.)

SEÇÃO 2.7

R26. O servidor UDP descrito na Seção 2.7 precisava de um socket apenas, ao passo que o servidor TCP precisava
de dois. Por quê? Se um servidor TCP tivesse de suportar n conexões simultâneas, cada uma de um hospedeiro
cliente diferente, de quantos sockets precisaria?
R27. Para a aplicação cliente-servidor por TCP descrita na Seção 2.7, por que o programa servidor deve ser
executado antes do programa cliente? Para a aplicação cliente-servidor por UDP, por que o programa
cliente pode ser executado antes do programa servidor?

PROBLEMAS
P1. Falso ou verdadeiro?
a. Um usuário requisita uma página Web que consiste em algum texto e três imagens. Para essa página, o
cliente enviará uma mensagem de requisição e receberá quatro mensagens de resposta.
b. Duas páginas Web distintas (por exemplo, www.mit.edu/research.html e www.mit.edu/
students.html) podem ser enviadas pela mesma conexão persistente.
c. Com conexões não persistentes entre navegador e servidor de origem, é possível que um único segmento
TCP transporte duas mensagens distintas de requisição HTTP.
d. O cabeçalho Date: na mensagem de resposta HTTP indica a última vez que o objeto da resposta foi
modificado.
e. As mensagens de resposta HTTP nunca possuem um corpo de mensagem vazio.
P2. Leia o RFC 959 para FTP. Relacione todos os comandos de cliente que são suportados pelo RFC.
P3. Considere um cliente HTTP que queira obter um documento Web em um dado URL. Inicialmente, o
endereço IP do servidor HTTP é desconhecido. Nesse cenário, quais protocolos de transporte e de camada de
aplicação são necessários, além do HTTP?
P4. Considere a seguinte cadeia de caracteres ASCII capturada pelo Wireshark quando o navegador enviou uma
mensagem HTTP GET (ou seja, o conteúdo real de uma mensagem HTTP GET). Os caracteres <cr><lf> são
126 yREDES DE COMPUTADORES E A INTERNET

retorno de carro e avanço de linha (ou seja, a cadeia de caracteres em itálico <cr> no texto abaixo representa
o caractere único retorno de carro que estava contido, naquele momento, no cabeçalho HTTP). Responda às
seguintes questões, indicando onde está a resposta na mensagem HTTP GET a seguir.
GET /cs453/index.html HTTP/1.1<cr><lf>Host: gai
a.cs.umass.edu<cr><lf>User-Agent: Mozilla/5.0 (
:LQGRZV8:LQGRZV17HQ86UY *HF
ko/20040804 Netscape/7.2 (ax) <cr><lf>Accept:ex
t/xml, application/xml, application/xhtml+xml, text
/html;q=0.9, text/plain;q=0.8,image/png,*/*;q=0.5
<cr><lf>Accept-Language: en-us,en;q=0.5<cr><lf>Accept-
(QFRGLQJ]LSGH»DWH<cr><lf>Accept-Charset: ISO
-8859-1,utf-8;q=0.7,*;q=0.7<cr><lf>Keep-Alive: 300<cr>
<lf>Connection:keep-alive<cr><lf><cr><lf>
a. Qual é a URL do documento requisitado pelo navegador?
b. Qual versão do HTTP o navegador está rodando?
c. O navegador requisita uma conexão não persistente ou persistente?
d. Qual é o endereço IP do hospedeiro no qual o navegador está rodando?
e. Que tipo de navegador inicia essa mensagem? Por que é necessário o tipo de navegador em uma mensagem
de requisição HTTP?
P5. O texto a seguir mostra a resposta enviada do servidor em reação à mensagem HTTP GET na questão
anterior. Responda às seguintes questões, indicando onde está a resposta na mensagem.
HTTP/1.1 200 OK<cr><lf>Date: Tue, 07 Mar 2008
12:39:45GMT<cr><lf>Server: Apache/2.0.52 (Fedora)
FU!OI!/DVW0RGLºHG6DW'HF
GMT<cr><lf>ETag: “526c3-f22-a88a4c80”<cr><lf>Accept-
Ranges: bytes<cr><lf>Content-Length: 3874<cr><lf>
Keep-Alive: timeout=max=100<cr><lf>Connection:
Keep-Alive<cr><lf>Content-Type: text/html; charset=
ISO-8859-1<cr><lf><cr><lf><!doctype html public “-
//w3c//dtd html 4.0 transitional//en”><lf><html><lf>
<head><lf> <meta http-equiv=”Content-Type”
content=”text/html; charset=iso-8859-1”><lf> <meta
QDPH ¯*(1(5$725¯FRQWHQW ¯0R]LOOD>HQ@ :LQGRZV17
5.0; U) Netscape]”><lf> <title>CMPSCI 453 / 591 /
NTU-ST550A Spring 2005 homepage</title><lf></head><lf>
<muito mais texto do documento em seguida (não mostrado)>
a. O servidor foi capaz de encontrar o documento com sucesso ou não? A que horas foi apresentada a
resposta do documento?
b. Quando o documento foi modificado pela última vez?
c. Quantos bytes existem no documento que está retornando?
d. Quais são os 5 primeiros bytes do documento que está retornando? O servidor aceitou uma conexão
persistente?
P6. Obtenha a especificação HTTP/1.1 (RFC 2616). Responda às seguintes perguntas:
a. Explique o mecanismo de sinalização que cliente e servidor utilizam para indicar que uma conexão
persistente está sendo fechada. O cliente, o servidor, ou ambos, podem sinalizar o encerramento de uma
conexão?
b. Que serviços de criptografia são providos pelo HTTP?
c. O cliente é capaz de abrir três ou mais conexões simultâneas com um determinado servidor?
d. Um servidor ou um cliente pode abrir uma conexão de transporte entre eles se um dos dois descobrir que
a conexão ficou lenta por um tempo. É possível que um lado comece a encerrar a conexão enquanto o
outro está transmitindo dados por meio dessa conexão? Explique.
CAMADA DE APLICAÇÃO y
127
P7. Suponha que você clique com seu navegador Web sobre um ponteiro para obter uma página e que o endereço
IP para o URL associado não esteja no cache de seu hospedeiro local. Portanto, será necessária uma consulta
ao DNS para obter o endereço IP. Considere que n servidores DNS sejam visitados antes que seu hospedeiro
receba o endereço IP do DNS; as visitas sucessivas incorrem em um RTT igual a RTT1, . . ., RTTn. Suponha
ainda que a página associada ao ponteiro contenha exatamente um objeto que consiste em uma pequena
quantidade de texto HTML. Seja RTT0 o RTT entre o hospedeiro local e o servidor que contém o objeto.
Admitindo que o tempo de transmissão seja zero, quanto tempo passará desde que o cliente clica o ponteiro
até que receba o objeto?
P8. Com referência ao Problema 7, suponha que o arquivo HTML referencie oito objetos muito pequenos no
mesmo servidor. Desprezando tempos de transmissão, quanto tempo passa, usando-se:
a. HTTP não persistente sem conexões TCP paralelas?
b. HTTP não persistente com o navegador configurado para 5 conexões paralelas?
c. HTTP persistente?
P9. Considere a Figura 2.12, que mostra uma rede institucional conectada à Internet. Suponha que o tamanho
médio do objeto seja 850 mil bits e que a taxa média de requisição dos navegadores da instituição aos
servidores de origem seja 16 requisições por segundo. Suponha também que a quantidade de tempo que
leva desde o instante em que o roteador do lado da Internet do enlace de acesso transmite uma requisição
HTTP até que receba a resposta seja 3 segundos em média (veja Seção 2.2.5). Modele o tempo total médio
de resposta como a soma do atraso de acesso médio (isto é, o atraso entre o roteador da Internet e o
SPUFBEPSEBJOTUJUVJÎÍP FPUFNQPNÏEJPEFBUSBTPEB*OUFSOFU1BSBBNÏEJBEFBUSBTPEFBDFTTP VTFͅ o
Δβ), sendo Δ o tempo médio requerido para enviar um objeto pelo enlace de acesso e β a taxa de chegada de
objetos ao enlace de acesso.
a. Determine o tempo total médio de resposta.
b. Agora, considere que um cache é instalado na LAN institucional e que a taxa de resposta local seja 0,4.
Determine o tempo total de resposta.
P10. Considere um enlace curto de 10 m através do qual um remetente pode transmitir a uma taxa de 150 bits/s
em ambas as direções. Suponha que os pacotes com dados tenham 100 mil bits de comprimento, e os pacotes
que contêm controle (por exemplo, ACK ou apresentação) tenham 200 bits de comprimento. Admita que N
conexões paralelas recebam cada 1/N da largura de banda do enlace. Agora, considere o protocolo HTTP e
suponha que cada objeto baixado tenha 100 Kbits de comprimento e que o objeto inicial baixado contenha
10 objetos referenciados do mesmo remetente. Os downloads paralelos por meio de instâncias paralelas de
HTTP não persistente fazem sentido nesse caso? Agora considere o HTTP persistente. Você espera ganhos
significativos sobre o caso não persistente? Justifique sua resposta.
P11. Considere o cenário apresentado na questão anterior. Agora suponha que o enlace é compartilhado por Bob
e mais quatro usuários. Bob usa instâncias paralelas de HTTP não persistente, e os outros quatro usam HTTP
não persistente sem downloads paralelos.
a. As conexões paralelas de Bob o ajudam a acessar páginas Web mais rapidamente? Por quê? Por que não?
b. Se cinco usuários abrirem cinco instâncias paralelas de HTTP não persistente, então as conexões paralelas
de Bob ainda seriam úteis? Por quê? Por que não?
P12. Escreva um programa TCP simples para um servidor que aceite linhas de entrada de um cliente e envie
as linhas para a saída-padrão do servidor. (Você pode fazer isso modificando o programa TCPServer.py
no texto.) Compile e execute seu programa. Em qualquer outra máquina que contenha um navegador
Web, defina o servidor proxy no navegador para a máquina que está executando seu programa servidor e
também configure o número de porta adequadamente. Seu navegador deverá agora enviar suas mensagens
de requisição GET a seu servidor, e este deverá apresentar as mensagens em sua saída-padrão. Use essa
plataforma para determinar se seu navegador gera mensagens GET condicionais para objetos que estão em
caches locais.
128 yREDES DE COMPUTADORES E A INTERNET

P13. Qual é a diferença entre MAIL FROM: em SMTP e FROM: na própria mensagem de correio?
P14. Como o SMTP marca o final de um corpo de mensagem? E o HTTP? O HTTP pode usar o mesmo método
que o SMTP para marcar o fim de um corpo de mensagem? Explique.
P15. Leia o RFC 5321 para SMTP. O que significa MTA? Considere a seguinte mensagem spam recebida
(modificada de um spam verdadeiro). Admitindo que o criador desse spam seja malicioso e que todos os
outros hospedeiros sejam honestos, identifique o hospedeiro malicioso que criou essa mensagem spam.
From - Fri Nov 07 13:41:30 2008
Return-Path: <[email protected]>
Received: from barmail.cs.umass.edu
(barmail.cs.umass.edu [128.119.240.3]) by cs.umass.edu
(8.13.1/8.12.6) for <[email protected]>; Fri, 7 Nov 2008
13:27:10 -0500
Received: from asusus-4b96 (localhost [127.0.0.1]) by
barmail.cs.umass.edu (Spam Firewall) for
<[email protected]>; Fri, 7 Nov 2008 13:27:07 -0500
(EST)
Received: from asusus-4b96 ([58.88.21.177]) by
barmail.cs.umass.edu for <[email protected]>; Fri,
07 Nov 2008 13:27:07 -0500 (EST)
Received: from [58.88.21.177] by
inbnd55.exchangeddd.com; Sat, 8 Nov 2008 01:27:07 +0700
From: “Jonny” <[email protected]>
To: <[email protected]>
Subject: How to secure your savings

P16. Leia o RFC do POP3 [RFC 1939]. Qual é a finalidade do comando UIDL do POP3?
P17. Imagine que você acesse seu e-mail com POP3.
a. Suponha que você configure seu cliente de correio POP para funcionar no modo ler-e-apagar. Conclua a
seguinte transação:
C: list
S: 1 498
S: 2 912
S: .
C: retr 1
S: blah blah ...
S: ..........blah
S: .
?
?
b. Suponha que você configure seu cliente de correio POP para funcionar no modo ler-e-guardar. Conclua a
seguinte transação:
C: list
S: 1 498
S: 2 912
S: .
C: retr 1
S: blah blah ...
S: ..........blah
S: .
?
?
c. Suponha que você configure seu cliente de correio POP para funcionar no modo ler-e-guardar. Usando
sua solução no item (b), considere que você recupere as mensagens 1 e 2, saia do POP e então, 5 minutos
mais tarde, acesse outra vez o POP para obter um novo e-mail. Imagine que nenhuma outra mensagem
foi enviada nesse intervalo de 5 minutos. Elabore uma transcrição dessa segunda sessão POP.
CAMADA DE APLICAÇÃO y
129
P18. a. O que é um banco de dados whois?
b. Use vários bancos de dados whois da Internet para obter os nomes de dois servidores DNS. Cite quais
bancos de dados whois você utilizou.
c. Use nslookup em seu hospedeiro local para enviar consultas DNS a três servidores DNS: seu servidor DNS
local e os dois servidores DNS que encontrou na parte (b). Tente consultar registros dos tipos A, NS e MX.
Faça um resumo do que encontrou.
d. Use nslookup para encontrar um servidor Web que tenha vários endereços IP. O servidor de sua instituição
(escola ou empresa) tem vários endereços IP?
e. Use o banco de dados whois ARIN para determinar a faixa de endereços IP usados por sua universidade.
f. Descreva como um invasor pode usar bancos de dados whois e a ferramenta nslookup para fazer o
reconhecimento de uma instituição antes de lançar um ataque.
g. Discuta por que bancos de dados whois devem estar disponíveis publicamente.
P19. Neste problema, utilizamos a ferramenta funcional dig disponível em hospedeiros Unix e Linux para explorar
a hierarquia dos servidores DNS. Lembre de que, na Figura 2.21, um servidor DNS de nível superior na
hierarquia do DNS delega uma consulta DNS para um servidor DNS de nível inferior na hierarquia, enviando
de volta ao cliente DNS o nome daquele servidor DNS de nível inferior. Primeiro, leia a man page sobre a
ferramenta dig e responda às seguintes questões:
a. Iniciando com o servidor DNS raiz (de um dos servidores raiz [a-m].root-servers.net), construa uma
sequência de consultas para o endereço IP para seu servidor de departamento utilizando o dig. Mostre a
relação de nomes de servidores DNS na cadeia de delegação ao responder à sua consulta.
b. Repita o item (a) com vários sites da Internet populares, como google.com, yahoo.com ou amazon.com.
P20. Suponha que você consiga acessar os caches nos servidores DNS locais do seu departamento. Você é capaz de
propor uma maneira de determinar, em linhas gerais, os servidores (fora de seu departamento) que são mais
populares entre os usuários do seu departamento? Explique.
P21. Suponha que seu departamento possua um servidor DNS local para todos os computadores do departamento.
Você é um usuário comum (ou seja, não é um administrador de rede/sistema). Você consegue encontrar um
modo de determinar se um site da Internet externo foi muito provavelmente acessado de um computador do
seu departamento alguns segundos atrás? Explique.
P22. Considere um arquivo de distribuição de F = 15 Gbits para N pares. O servidor possui uma taxa de upload
de us = 30 Mbits/s e cada par possui uma taxa de download de di = 2 Mbits/s e uma taxa de upload de u.
Para N = 10, 100 e 1.000 e u = 300 Kbits/s, 700 Kbits/s e 2 Mbits/s, prepare um gráfico apresentando o
tempo mínimo de distribuição para cada uma das combinações de N e u para o modo cliente-servidor e
para o modo distribuição P2P.
P23. Considere distribuir um arquivo de F bits para N pares utilizando uma arquitetura cliente-servidor. Admita
um modelo fluido no qual o servidor pode transmitir de modo simultâneo para diversos pares, a diferentes
taxas, desde que a taxa combinada não ultrapasse us.
a. Suponha que us/N ≤ dmin. Especifique um esquema de distribuição que possua o tempo de distribuição de
NF/us.
b. Suponha que us/N ≥ dmin. Especifique um esquema de distribuição que possua o tempo de distribuição de
F/dmin.
c. Conclua que o tempo mínimo de distribuição é, geralmente, dado por max{NF/us, F/dmin}.
P24. Considere distribuir um arquivo de F bits para N pares utilizando uma arquitetura P2P. Admita um modelo
fluido e que dmin é muito grande, de modo que a largura de banda do download do par nunca é um gargalo.
a. Suponha que us ≤ (us + u1 + ... + uN)/N. Especifique um esquema de distribuição que possua o tempo de
distribuição de F/us.
b. Suponha que us ≥ (us + u1 + ... + uN)/N. Especifique um esquema de distribuição que possua o tempo de
distribuição de NF/(us + u1 + ... + uN).
c. Conclua que o tempo mínimo de distribuição é, em geral, dado por max {F/us, NF/(us + u1 + ... + uN)}.
130 yREDES DE COMPUTADORES E A INTERNET

P25. Considere uma rede de sobreposição com N pares ativos, em que cada dupla de pares possua uma conexão
TCP. Além disso, suponha que as conexões TCP passem por um total de M roteadores. Quantos nós e
arestas há na rede de sobreposição correspondente?
P26. Suponha que Bob tenha entrado no BitTorrent, mas ele não quer fazer o upload de nenhum dado para
qualquer outro par (denominado carona).
a. Bob alega que consegue receber uma cópia completa do arquivo compartilhado pelo grupo. A alegação de
Bob é possível? Por quê?
b. Bob alega ainda que ele pode “pegar carona” de um modo mais eficiente usando um conjunto de diversos
computadores (com endereços IP distintos) no laboratório de informática de seu departamento. Como ele
pode fazer isso?

$)"15&3 t
P27. No exemplo de DHT circular na Seção 2.6.2, suponha que o par 3 descobriu que o par 5 saiu. Como o par 3
atualiza informações sobre o estado de seu sucessor? Qual par é agora seu primeiro sucessor? E seu segundo
sucessor?

P28. No exemplo de DHT circular na Seção 2.6.2, suponha que um novo par 6 queira se juntar ao DHT e
inicialmente só conheça o endereço IP do par 15. Que etapas são tomadas?
P29. Como um número inteiro em [0,2n o>QPEFTFSFYQSFTTPDPNPVNOÞNFSPCJOÈSJPEFn bit em um DHT,
cada chave pode ser expressa como k = (k0, k1, ..., kn-1), e cada identificador de par pode ser expresso como p
= (p0, p1, ..., pn-1). Vamos, agora, definir a distância XOR entre a chave k e o par p como
n-1
d 1 k, p 2 = a u k j - pj u 2j
j=0

Descreva como essa métrica pode ser usada para designar duplas (chave, valor) a pares. (Para aprender mais
sobre como construir um DHT eficiente usando essa métrica natural, consulte Maymounkov [2002], no qual
o DHT Kademlia é descrito.)
P30. Como os DHTs são redes de sobreposição, eles nem sempre se adequam bem à rede física de sobreposição
considerando que dois pares vizinhos podem estar fisicamente muito distantes; por exemplo, um par poderia
estar na Ásia e seu vizinho, na América do Norte. Se atribuirmos identificadores de maneira aleatória e
uniforme para pares recém-unidos, esse esquema de atribuição causaria essa incompatibilidade? Explique. E
como tal incompatibilidade afetaria o desempenho do DHT?
P31. Instale e compile os programas Python TCPClient e UDPClient em um hospedeiro e TCPServer e UDPServer
em outro.
a. Suponha que você execute TCPClient antes de executar TCPServer. O que acontece? Por quê?
b. Imagine que você execute UDPClient antes de UDPServer. O que acontece? Por quê?
c. O que acontece se você usar números de porta diferentes para os lados cliente e servidor?
P32. Suponha que, em UDPClient.py, depois de criarmos o socket, acrescentemos a linha:

clientSocket.bind((‘’, 5432))

Será necessário mudar UDPServer.py? Quais são os números de porta para os sockets em UDPClient e
UDPServer? Quais eram esses números antes dessa mudança?
P33. Você consegue configurar seu navegador para abrir várias conexões simultâneas com um site? Quais são as
vantagens e desvantagens de ter um grande número de conexões TCP simultâneas?
P34 Vimos que os sockets TCP da Internet tratam os dados sendo enviados como um fluxo de bytes, mas sockets
UDP reconhecem limites de mensagem. Quais são uma vantagem e uma desvantagem da API orientada a
byte em relação a fazer com que a API reconheça e preserve explicitamente os limites de mensagem definidos
pela aplicação?

Você também pode gostar