Curso Superior em Redes de Computadores Camada de Transporte Prof. Sales Filho.

Slides:



Advertisements
Apresentações semelhantes
Missão da camada de enlace Serviços oferecidos TCP UDP
Advertisements

Capítulo 3: Camada de Transporte
Família tcp/ip Prof: Diovani Milhorim
Bruno Rafael de Oliveira Rodrigues
Redes I Os Protocolos Prof. Dr. Amine BERQIA
FEUPDEECRedes de Computadores, 4º Ano de EEC, ramo de ACI TCP (Transmission Control Protocol) Abril, 98Isidro Vila Verde 1 Aspectos Gerais.
Protocolos de Transporte da Pilha TCP/IP
URL: Redes Prof. Edgard Jamhour URL:
Interação Cliente Servidor
TCP Serviço de Transporte Confiável
Paulo Roberto Freire Cunha
Obtenção de IP TCP UDP.
Universidade do Vale do Rio dos Sinos - São Leopoldo -
REVISÃO MÓDULO 3(Camada de Transporte)
TCP (Transmission Control Protocol)
CCNA 1 – Camadas de Transporte e de Aplicação do TCP/IP
Escola Secundária Filipa de Vilhena Ano Lectivo 2010/ Turma IGR1
Software de Rede Willamys Araújo.
Modelo de referência OSI
Interconexão e Transporte em Redes
Disciplina: Princípios de Redes de Computadores Parte 3
URI - Santo Ângelo - DECC
Redes Aula 7 Professor: Marcelo Maia.
Aula 64 – TEC 11ºF Redes de computadores Prof. António dos Anjos.
Camada de Transporte prof. Eduardo.
Transmission Control Protocol TCP
Protocolos de Janela Deslizante
UNEMAT-FACIEX MODELOS DE REFERÊNCIA Dr. José Raúl Vento 2005.
ARQUITECTURA TCP/IP.
TCP Conexão Fiabilidade Full Duplex Entrega ordenada Controlo de fluxo
Escola Secundaria Sebastião da Gama Trabalho realizado por: André Santos 12ºL nº:2 Prof: Carlos Pereira.
Módulo 3 Implantação do IPv6.
REDES DE COMPUTADORES Camada de Transporte Professor: M.Sc. Carlos Oberdan Rolim.
Camada de Transporte: protocolo TCP Parte 1
MODELO DE REFERÊNCIA TCP/IP
Protocolo TCP e UDP Ricardo Costa Nº 10 12ºL.
Disciplina de: Comunicação de Dados Professor: Carlos Pereira Trabalho Realizado por: João Santos.
Arquitectura tcp. Camada tcp Ao contrário do protocolo UDP, o TCP representa um grande incremento de qualidade relativamente ao protocolo IP que lhe serve.
1) A camada de transporte provê comunicação lógica entre hosts.
Camada de Transporte: protocolo UDP
Redes de computadores: Camada de Transporte Prof. Dr. Amine BERQIA
Arquitetura TCP/IP Aplicação Transporte Rede Enlace Física.
TCP È um dos protocolos sob os quais assenta o núcleo da Internet nos dias de hoje. A versatilidade e robustez deste protocolo tornaram adequado para.
Escola Politécnica da USP abril de 2013 PTC 2550 – Redes de Comunicação De Dados e P1 Transporte Multimídia PTC 2550 – Redes de Comunicação De Dados e.
Rede de Computadores MAT164 – Redes de Computadores I Universidade Federal da Bahia Instituto de Matemática Departamento de Ciência da Computação.
Administração e Projeto de Redes Material de apoio Camada de Transporte Cap.4 10/02/2010.
Redes de computadores e a Internet
Protocolos de Comunicação e Passagem de Mensagens
Curso Superior em Redes de Computadores SSH Prof. Sales Filho.
Capítulo 1 Redes de computadores e a Internet Professor: Gustavo Wagner
Prof. Ivair Teixeira Redes de Computadores.
“Características e Limitações”
Curso Superior em Redes de Computadores Roteamento IP UNICAST OSPF – Parte 3 Prof. Sales Filho.
Redes de Computadores e Aplicações – Camada de Rede IGOR ALVES.
Capítulo 2 O Modelo OSI.
Curso Superior em Redes de Computadores FTP Prof. Sales Filho.
Redes de Computadores e Aplicações – Camada de Transporte IGOR ALVES.
Escola de Ciência e Tecnologia Arquitetura TCP/IP Arquitetura TCP/IP Interface entre o Nível Lógico e Físico Protocolo IP Etienne César R. de Oliveira.
Informática Industrial N8INF Prof. Dr. Cesar da Costa 4.a Aula: Rede ModBus.
Centro Federal de Educação Tecnológica do RN Redes de Computadores Curso Superior em Redes de Computadores Camada de Rede Prof. Sales Filho.
Camada 4 A Camada de Transporte
Escola de Ciência e Tecnologia Arquitetura TCP/IP Arquitetura TCP/IP Protocolos TCP, UDP e ICMP Etienne César R. de Oliveira
Escola de Ciência e Tecnologia Arquitetura TCP/IP Arquitetura TCP/IP Interface entre o Nível Lógico e Físico Protocolo IP Etienne César R. de Oliveira.
INTERNET Serviços e protocolos Escola Luís de Camões.
Endereçamento IP Básico
Curso Superior em Redes de Computadores Camada de Aplicação Prof. Sales Filho.
Redes de Computadores Camada de Rede
Redes de Computadores Arquitetura TCP/IP Prof. Alberto Felipe / Ester Ozório.
Modelo OSI Com o objetivo de efetuar uma divisão das diversas partes da rede que compõem uma transmissão, para que possam existir etapas definidas e que.
Redes de Computadores e Aplicações – Modelo OSI IGOR ALVES.
Transcrição da apresentação:

Curso Superior em Redes de Computadores Camada de Transporte Prof. Sales Filho

2 Objetivo Apresentar as características da camada de transporte da arquitetura TCP/IP Apresentar os serviços fornecidos pela camada de transporte Estudar os protocolos da camada de transporte Serviço de datagramas Serviço de circuito virtual

3 Camada de transporte Objetivo Prover a comunicação fim-a-fim entre os processos de aplicação Funcionalidades Serviço de datagrama Serviço de circuito virtual Identificação de processos

4 Serviço de datagrama Característica Serviço não confiável Não garante a entrega dos datagramas Pode perder e retardar datagramas Provê apenas a detecção de erros, garantindo a integridade dos dados Serviço sem conexão Datagramas são individuais e independentes Seqüência dos datagramas não é assegurada

5 Serviço de circuito virtual Característica Serviço orientado a fluxo Divide o fluxo de dados eem seguimentos Serviço confiável Garante a entrega do fluxo de dados na seqüência correta e sem erros Prevê controle de erro, seqüência e fluxo Serviço orientado à conexão Negocia parâmetros operacionais na abertura da conexão Conexões full-duplex

6 Identificação de processos Portas Número inteiro positivo que representa um ponto de comunicação Processos são associados à portas Par (endereço IP, Porta) identifica unicamente cada ponto de comunicação P1 Porta 25 P2 Porta 53 P2 Porta 161Porta 162 Aplicação Transporte

7 Composição Protocolos UDP (User Datagram Protocol)‏ Provê o serviço de datagramas não confiável e sem conexão Pode ser visto como uma extensão do protocolo IP que entrega datagramas entre processos TCP (Transfer Control Protocol)‏ Provê o serviço de circuito virtual confiável e orientado à conexão

8 Protocolo UDP Fundamentos Define a unidade de dados do serviço de datagramas, denominada datagrama UDP Especifica o formato e a função dos campos Multiplexa mensagens geradas nos processos na camada de rede Encapsula datagramas UDP em datagramas IP Demultiplexa datagramas UDP para os respectivos processos destino Extrai mensagens dos datagramas UDP

9 Formato do datagrama Cada datagrama é tratado de forma individual e independente Pode ser enviados por diferentes rotas Protocolo UDP Source portDestination port LengthChecksum Data

10 Campos do datagrama Length Tamanho total do datagrama em bytes (cabeçalho + dados)‏ Checksum Assegura a integridade do datagrama Inclui o cabeçalho e os dados Detecção de erros é opcional Data Dados do datagrama Protocolo UDP Source portDestination port LengthChecksum Data

11 Cálculo do Checksum Considera um pseudocabeçalho Assegura que a entrega é realizada à estação e ao processo destino Pode incluir um byte pad (0)‏ Torna par o tamanho do datagrama Não são transmitidos com o datagrama Protocolo UDP Destination IP address Source IP address ProtocolLength 17

12 Protocolo TCP Fundamentos Define a unidade de dados do serviço de circuito virtual, denominada seguimento TCP Especifica o formato e a função dos campos Multiplexa mensagens geradas pelos processos no serviço da camada de rede Encapsula segmentos em datagramas IP Demultiplexa segmentos para os respectivos processos destino Extrai mensagens dos segmentos

13 Protocolo TCP Fundamentos Adota uma abordagem baseada em fluxo de dados (data stream)‏ Trata o fluxo de dados como uma cadeia contínua de bytes Decide como agrupar bytes em segmentos Adota uma abordagem orientada à conexão full- duplex Estabelecimento da conexão Transferência de dados Fechamento da conexão

14 Protocolo TCP Fundamentos Define mecanismos integrados de controle de erro e seqüência Asseguram a entrega do fluxo de dados na seqüência correta e sem erros Define mecanismo de controle de fluxo Regula e compatibiliza a taxa de transmissão das unidades envolvidas Evita descarte de segmentos por falta de recursos da estação destino

15 Protocolo TCP Formato do segmento TCP Source portDestination port Hlen Checksum Data Sequence number Acknowledgement number ReservedCode bitsWindow Urgent point OptionsPad

16 Campos do segmento Hlen Tamanho do cabeçalho em unidades de 4 bytes Reserved Reservado para uso futuro (Não utilizado)‏ Checksum Assegura a integridade do segmento Considera um pseudocabeçalho e pode incluir um pad (0)‏ Protocolo TCP

17 Campos do segmento Code bits Indica propósito e conteúdo do segmento URG: Dados urgentes ACK: reconhecimento PSH: mecanismo de push RST: abordo de conexão (reset)‏ SYN: Abertura de conexão FIN: fechamento de conexão Protocolo TCP Code bitsURG 0 5 ACKPSHRSTSYNFIN

18 Campos do segmento Options Lista variável de informações opcionais MSS – Maximum Segment Size Torna o tamanho do cabeçalho variável Padding Bits 0 que tornam o segmento múltiplo de 32 bits Data Dados do segmento Protocolo TCP

19 Portas Source port Porta associada ao processo de origem Destination port Porta associada ao processo de destino Endpoint Definido pelo par (Endereço IP, porta)‏ Identifica de forma única cada porta ou ponto de comunicação na inter-rede Também conhecido como Socket Protocolo TCP

20 Conexão Cada conexão é identificada por um par de endpoints Também conhecida como Socket pair Várias conexões por estação Protocolo TCP P1P2P3P Porta 1800Porta 25Porta 80Porta 5000 ( , 5000) e ( , 80) ( , 80) e ( , 1800)‏

21 Conexão Cada endpoint local pode participar de diversas conexões com endpoints remotos Compartilhamento de endpoints O Sistema Operacional deve garantir que o par de endpoint da conexão é único Protocolo TCP P1P2P5P Porta 2000Porta 80 Porta 5000 ( , 5000) e ( , 80) ( , 80) e ( , 2000)‏

22 Demultiplexação de mensagens Segmentos recebidos são associados às conexões, não apenas as portas Avalia o par de endpoints da conexão Portas origem e destino são obtidas do segmento recebido Endereço IP origem e destino são obtidos do datagrama IP Cada conexão possui um buffer de transmissão e um Buffer de recepção em cada extremidade Protocolo TCP

23 Controle de seqüência Fluxo de dados é tratado como uma seqüência de bytes Cada byte possui um número de seqüência Numeração nem sempre começa em 0 (zero)‏ Negociado no estabelecimento da conexão Campo Sequence number Indica o número de seqüência do primeiro byte de dados contido no seguimento Protocolo TCP Segmento Segmento Segmento 350

24 Controle de seqüência Protocolo TCP Números de seqüência:  Número do primeiro byte nos segmentos de dados ACKs:  Número do próximo byte esperado do outro lado  ACK cumulativo P.: Como o receptor trata segmentos fora de ordem?  A especificação do TCP não define, fica a critério do implementador

25 Controle de erros Reconhecimento positivo Destino retorna uma mensagem indicando o correto recebimento do segmento Reconhecimento pode pegar carona no segmento de dados do fluxo inverso Reconhecimento cumulativo Diversos segmentos consecutivos podem ser reconhecidos em uma única mensagem Protocolo TCP Segmento Segmento Segmento 350

26 Controle de erros Acknowledgment number Indica o número de sequência do próximo byte que espera receber Indica o correto recebimento dos bytes com número de seqüência anterior Bit ACK do Code Bits deve ser ativado Protocolo TCP Seq. number Seq. number ACK number 200 ACK number 350 Seq. number 350 ACK number 450

27 Controle de erros Realizado através de Retransmissão Origem adota um temporizador para cada segmento enviado Segmento é retransmitido quando a origem não recebe o reconhecimento (ack) antes de expirar o temporizador Temporizador é reativado em cada retransmissão Protocolo TCP

28 Controle de erros - Cenários Protocolo TCP Cenário com perda do ACK Temporização prematura, ACKs cumulativos

29 Controle de erros - Cenários Protocolo TCP Cenário de ACK cumulativo

30 Controle de fluxo Objetivo Transmissor não deve esgotar os buffers de recepção enviando dados rápido demais Implementação Janela deslizante Entidades negociam o número de bytes adicionais que podem ser recebidos a partir do último reconhecimento Destino define o tamanho de sua janela de recepção em cada segmento Origem atualiza o tamanho de sua janela de transmissão a cada reconhecimento Reconhecimento deslocam a janela de transmissão da origem para o primeiro byte sem reconhecimento Protocolo TCP

31  lado receptor da conexão TCP possui um buffer de recepção:  Serviço de speed-matching: encontra a taxa de envio adequada à taxa de vazão da aplicação receptora  Processos de aplicação podem ser lentos para ler o buffer Controle de fluxo Transmissor não deve esgotar os buffers de recepção enviando dados rápido demais Protocolo TCP - Controle de fluxo

32 (suponha que o receptor TCP descarte segmentos fora de ordem) ‏  Espaço disponível no buffer = RcvWindow = RcvBuffer-[LastByteRcvd - LastByteRead]  Receptor informa a área disponível incluindo valor RcvWindow nos segmentos  Transmissor limita os dados não confimados ao RcvWindow  Garantia contra overflow no buffer do receptor Protocolo TCP - Controle de fluxo

33 Controle de fluxo Campo Window Sinaliza o tamanho da janela de recepção da entidade em cada segmento enviado Applet on-line 71/ cw/index.html 71/ cw/index.html Protocolo TCP

34 Protocolo TCP Processo de estabelecimento de conexões

35 Estabelecimento de conexões Three way handshake Negocia e sincroniza o valor inicial dos números de seqüência em ambas as direções Baseado na arquitetura cliente-servidor O servidor deve está com a porta aberta em estado de escuta (Listening)‏ Protocolo TCP

36 Protocolo TCP Estabelecimento de conexões

37 Transmissão de dados Entrega de dados “fora-de-banda” Campo Urgent Point o transmissor transmite o dado urgente na área de dados e seta o bit URG (campo Codebits), indicando a posição no segmento onde o dado urgente terminou O receptor deve notificar a aplicação sobre a chegada do dado urgente tão logo quanto possível Mecanismo de Push Aplicação avisa ao TCP para enviar o dado imediatamente Força a geração de um segmento com os dados já presentes no Buffer Não aguarda o preenchimento do Buffer Segmentos gerados pelo mecanismo de PUSH são marcados com o flag PSH no campo codebits Protocolo TCP

38 Protocolo TCP Fechamento de conexão (Liberação ordenada)‏ Ocorre separadamente em cada direção da conexão

39 Protocolo TCP Fechamento de conexão (Término abrupto)‏

40 Estados do clienteEstados do servidor Protocolo TCP Estados das conexões

41 Protocolo TCP Atividade prática Utilizando o simulador, monte a uma estrutura contendo um servidor web e dois clientes, conforme exemplo abaixo Realize as configurações de endereçamento adequadas para a perfeita comunicação entre os clientes e o servidor Servidor Web ( , 80)‏ Cliente Web ( , X)‏

42 Protocolo TCP Atividade prática Configure o servidor web conforme exemplo abaixo A página index.html será carregada automaticamente no web browser do cliente quando não especificada nenhum outro parâmetro.

43 Protocolo TCP Atividade prática Teste o acesso utilizando o web browser do cliente PC0 Conteúdo da página “index.html” contida no servidor Observe que não foi preciso colocar o nome da página

44 Protocolo TCP Atividade prática SIMULADA No modo de simulação, configure os filtros de protocolos para TCP, ICMP, HTTP Inicie a simulação, o objetivo é identifica hree way handshake durante o estabelecimento e fechamento da conexão, bem como a análise dos números de seqüência, bits SYN, ACK, FIN contidos nos segmentos TCP

45 Protocolo TCP Atividades de laboratório utilizando o analisador de protocolos wireshark, antigo projeto ethereal. Obtenha e instale o arquivo instalador do wireshark em: Obtenha o arquivo de captura para análise: Abra o arquivo no Wireshark e responda as perguntas que se seguem

46 Protocolo TCP Tela do Wireshark Pacotes capturados Detalhes das camadas de protocolos Conteúdo em formato bruto

47 Protocolo TCP ATIVIDADE 1) Qual o IP da entidade servidora e da entidade cliente 2) Em quais linhas da captura estão os fragmentos TCP que estabelecem a conexão ? (Three way handshake) 3) Identifique os números de seqüência da entidade cliente, explicitando seus valores. 4) Por que o número de seqüência do cliente varia MUITO menos que o número de seqüência do servidor? 5) Qual é a porta de origem e de destino da conexão visto do lado do servidor ? 6) Identifique os fragmentos em que é encerrada a conexão. 7) Qual é o protocolo (e versão) de camada de aplicação utilizado na comunicação ? 8) Reproduza a captura baixando o seguinte arquivo:

48 Referências Comer, Douglas E., Interligação de Redes Com Tcp/ip James F. Kurose, Redes de Computadores e a Internet Escola Superior de Redes, Arquitetura e Protocolos de Redes TCP/IP