Iperf 001 PDF
Iperf 001 PDF
Iperf 001 PDF
003
Notas Técnicas, v. 4, n. 2, p. 1–13, 2014
Resumo: Este trabalho demonstra a utilização da ferramenta de medição e geração de tráfego de dados Trans-
port Control Protocol (TCP) e User Datagram Protocol (UDP) conhecida como IPERF. Uma ferramenta útil
para engenheiros e administradores de rede, do tipo cliente/servidor, desenvolvida com código livre e gratuita.
Ela permite, como uma de suas principais vantagens, a alteração de parâmetros TCP, tal como o tamanho da
janela TCP, além de exibir relatórios de banda nos modos TCP e UDP, e relatórios de jitter e perda de pacotes
no modo UDP. Neste documento, são exibidos alguns casos em que a ferramenta é útil e como ela pode ser
utilizada para auxiliar na análise de desempenho de redes TCP/IP.
Palavras-chave: Redes de computadores; Medição de desempenho de redes de computadores; Geração de
tráfego TCP e UDP.
Abstract: This work demonstrates the use of Transport Control Protocol (TCP) and User Datagram Protocol
(UDP) data traffic measurement and generation tool known as IPERF. This tool is useful for network engineers
and administrators, developed based on the client/server, open source and free models. It allows you, as one
of its main advantages, to modify TCP parameters such as the TCP window size, in addition to view reports of
bandwidth in TCP and UDP modes, and reports of jitter and packet loss in UDP mode. In this document, we
report some cases where the IPERF tool is useful and how it can be used to assist in analyzing the performance
of TCP/IP networks.
Keywords: Computer networks; Performance evaluation of computer networks; TCP and UDP traffic genera-
tion.
comunicação fim a fim. Pesquisar e avaliar o desempenho de e alta disponibilidade, é que desenvolvemos o presente docu-
redes de computadores, especialmente aquelas dedicadas a mento. Com este projeto pretendemos pesquisar e desenvol-
grandes experimentos colaborativos de física, envolve a aná- ver as ferramentas para avaliação de desempenho inter-redes,
lise de métricas que caracterizem seu comportamento, desde com o objetivo de melhorar a taxa de utilização dos recursos
a sua topologia física (fim a fim) quanto todas as especifi- computacionais disponíveis fim a fim dos projetos desenvol-
cações operacionais e projetos lógicos. Para isto devem ser vidos no CBPF. Dessa forma, este documento surge como
feitas escolhas corretas e análises de diversas métricas nos uma necessidade de se compreender o funcionamento da fer-
diferentes níveis funcionais de uma rede. Essas métricas po- ramenta de medição ativa de rede IPERF, como uma solução
dem ser obtidas através de técnicas de medição ativa(vide de código aberto, para realizar medições de vazão dos enla-
seção 2) que consistem na injeção de pacotes de controle na ces da RedeRio/FAPERJ e do projeto REDECOMEP-Rio.
rede, ou passivas3 , em que são apenas observados os paco- Apesar de haverem disponíveis na Internet diversos
tes que trafegam pela rede. As características da rede que tutorias sobre a ferramenta IPERF, além de páginas Web que
são geralmente medidas e analisadas pelas ferramentas para demonstrem o seu funcionamento, há a carência de artigos
a análise de desempenho de rede são: científicos que abordem de uma maneira clara e objetiva o
seu funcionamento e utilização. Ademais, não há na litera-
1. Largura de banda e taxa de uso dos canais de comuni- tura científica textos que demonstrem em conjunto explica-
cação envolvidos (throughput ou vazão): a largura de ções sobre a ferramenta e suas métricas observáveis, além de
banda indica a capacidade máxima de transmissão no- casos práticos da vida profissional de administradores e en-
minal de uma conexão, enquanto que o throughput ou genheiros de rede em que essa aplicação seja bem adequada
vazão trata-se da quantidade de dados transferidos de e simples de ser utilizada. Desse modo, neste trabalho, es-
um ponto a outro da rede em um determinado período tamos interessados em demonstrar o funcionamento da fer-
de tempo. ramenta IPERF e alguns casos específicos de sua utilização,
que sejam úteis à vida prática de engenheiros e administra-
2. Perda de pacotes: trata-se do número de pacotes envi- dores de redes, inclusive para os responsáveis pelo CEO da
ados por um emissor, mas não recebidos pelo recep- RedeRio/FAPERJ.
tor, sendo, geralmente, obtido como um percentual de Nas próximas seções, são dadas uma visão geral
perda de pacotes na rede. Esse percentual é estimado das ferramentas de medição ativas de rede e da ferramenta
com base no número total de pacotes perdidos dividido IPERF. Em sequência, são abordados alguns tópicos essen-
pelo total de pacotes enviados. Para uma boa análise ciais para a compreensão do funcionamento da ferramenta
dessa métrica deve-se levar em consideração diversos em relação aos protocolos da camada de transporte da pi-
fatores como a caracterização do tamanho dos buffers lha de protocolos TCP/IP, o UDP e o TCP. Em seguida, são
de armazenamento temporário, a análise da saturação apresentados os procedimentos de instalação e de utilização
de enlaces e o congestionamento da rede fim a fim. da ferramenta IPERF e também são expostos alguns casos
específicos de políticas de controle de banda, testes de ba-
3. Tempo de resposta (latência ou atraso da rede): es- lanceamento de carga e geração de fluxos UDP de altas taxas
tima o tempo que um pacote demora para sair de sua de transferência. Por fim, são apresentadas as conclusões re-
origem e chegar ao seu destino. Em geral, a latência ferentes à análise do funcionamento da ferramenta IPERF e
da rede é medida como o atraso de ida e volta de um dos estudos de casos.
pacote na rede, também conhecido como Round Trip
Time (RTT).
4. Jitter: é obtido como o desvio padrão do atraso de pa- 2. VISÃO GERAL DAS FERRAMENTAS DE MEDIÇÃO
cotes enviados em sequência. A medição da variação ATIVAS DE REDE
da latência impacta no uso da rede para transferência
de grandes volumes de dados, em especial para apli- As ferramentas de medição ativa de rede proveem
cações que necessitem de alto desempenho em tempo a abordagem mais simples e mais flexível para a estimação
real. da vazão da rede [11]. Essas ferramentas são fundamentais,
pois permitem analisar o tráfego de dados e os pontos críti-
Como parte integrante de um projeto coordenado cos de uma rede, avaliando a sua topologia a fim de verificar
pela Coordenação de Atividades Técnicas (CAT) do CBPF, se a qualidade dos serviços oferecidos pela rede está sendo
cujo objetivo principal é garantir e otimizar o acesso do atendida, além de auxiliar no planejamento futuro da rede.
CBPF aos grandes experimentos internacionais e a troca de Esse tipo de ferramenta de medição tem como ob-
grandes volumes de dados sob a Internet em alta velocidade jetivo injetar pacotes de teste na rede, para a partir de então
medir o desempenho da rede avaliando como esse tráfego de
teste se comporta na rede.
É nesse contexto que se inserem os geradores de trá-
3 O método de medição passivo analisa o desempenho de redes através fego como ferramentas de medição ativas de redes de com-
do uso de dispositivos passivos, que não interferem no tráfego da rede putadores, assim como a ferramenta IPERF. Os geradores de
quando realizam suas medições, i.e., esses dispositivos apenas observam
o tráfego corrente que passa pelo ponto de observação. Exemplos de tráfego permitem que sejam gerados fluxos de dados com
ferramentas de medição passiva são as que utilizam o protocolo Simple características específicas para simular o acesso a uma apli-
Network Management Protocol (SNMP), como CACTI [9] e MRTG [10]. cação, como o tráfego de voz ou vídeo, por exemplo. Com
CBPF-NT-003/14 3
isso, é possível testar a eficiência das configurações de Qua- como open source compilável ou binário executável para di-
lity of Service(QoS), Access Control List (ACLs), traffic- versas plataformas incluindo Windows, Linux, Solaris, Mac
shapping4 , Virtual Private Networks (VPNs), dentre muitas OS, OpenBSD e FreeBSD.
outras. Os testes de performance realizados pelo IPERF po-
Diversas são as ferramentas de medição ativa dis- dem ser utilizados para validar uma rede, tanto em segmentos
poníveis na Internet, tanto de código aberto como Clink cabeados quanto sem fio. Os testes podem ser utilizados, por
[12], IPERF [13], Netperf [14], Pathrate [15], NUTTCP [16], exemplo, para identificar o mau desempenho de uma rede ou
quanto pagas como PathView [17]. Cada uma dessas ferra- até mesmo para desqualificar a porta de um switch ou rotea-
mentas utiliza técnicas diferentes para determinar a capaci- dor defeituoso.
dade de tráfego, porém não é objetivo desse documento rea- Por padrão, o protocolo utilizado pelos testes com
lizar a análise nem comparação de todas essas ferramentas. IPERF é o TCP, porém o protocolo UDP pode ser também
Portanto, é apresentado, a partir da seção 3, uma análise do utilizado. Dentre as principais características da ferramenta
funcionamento da ferramenta IPERF. em relação a cada um dos protocolos citados podem ser des-
tacadas:
O UDP utiliza o protocolo IP para transportar men- zante pode ser visto como uma sequência de pacotes a serem
sagens, mas adiciona a capacidade de distinguir entre múlti- transmitidos, como pode ser visualizado na Figura 4.2. O
plos destinos dentro de um determinado host, através de me- protocolo implementa uma pequena janela de tamanho fixo
canismos conhecidos como portas. As portas, em conjunto na sequência de dados a serem transmitidos e transmite todos
com o endereço IP, identificam a fonte e o destino de cada os pacotes que se encontram nessa janela.
mensagem. Em suma, ele nada mais é do que uma interface
para o protocolo IP, cuja função básica é servir como mul-
tiplexador e demultiplexador de processos para o tráfego de Remetente Mensagens de Rede Destinatário
informações do protocolo IP.
Assim sendo, os programas aplicativos que depen- pct 0 enviado
0 1 2 3 4 5 6 7 8 9
dem de UDP funcionam muito bem em um ambiente local, pct 1 enviado
pct 0 recebido, entregue ACK 0
0 1 2 3 4 5 6 7 8 9
mas falham de modo dramático quando são utilizados na In- 0 1 2 3 4 5 6 7 8 9
pct 1 recebido, entregue ACK 1
ternet. Desse modo, é onde o IPERF se faz presente, per- pct 2 enviado
0 1 2 3 4 5 6 7 8 9
0 1 2 3 4 5 6 7 8 9
mitindo aos profissionais de Tecnologia da Informação (TI) pct 2 recebido, entregue ACK 2
pct 3 enviado, janela cheia
testarem a conectividade UDP. 0 1 2 3 4 5 6 7 8 9
0 1 2 3 4 5 6 7 8 9
Além do mecanismo de janela deslizante o TCP im- ada na taxa de perda de pacotes, e do lado do receptor é uti-
plementa também um mecanismo de controle de congestio- lizada uma janela de recepção (TCP RWND) que informa ao
namento que visa adaptar a taxa de envio de dados à carga transmissor quantos bytes ele (receptor) é capaz de aceitar
da rede. Esse mecanismo é, basicamente, composto por dois em um dado momento. Por fim, o menor valor entre a TCP
algoritmos: o algoritmo de partida lenta e o de prevenção de CWND e a TCP RWND anunciada determina quantos bytes
congestionamento [22]. podem ser realmente transmitidos pelo transmissor em um
O algoritmo de partida lenta é utilizado no estabele- dado momento.
cimento de uma conexão TCP, com o objetivo de fazer com
que a taxa de transmissão do transmissor convirja para a ca-
pacidade de transmissão disponível na rede. Em seguida, é
iniciada a fase de prevenção de congestionamento, utilizada 4.1. Ajustando a Janela TCP
para controlar o tamanho da janela de transmissão dinamica-
mente [23]. Segundo a RFC 6349 [24], para que se evite a limi-
Com o auxílio dos algoritmos de partida lenta e con- tação da performance TCP ambas as janelas TCP (RWND e
trole de congestionamento, do lado do transmissor uma ja- CWND) devem ser maiores do que o produto do atraso de
nela de congestionamento (TCP CWND) é calculada base- largura de banda ou Bandwidth-Delay Product (BDP):
A Figura 4.3 auxilia na compreensão de como a onde FPSmx é o número máximo de quadros por segundo
configuração incorreta da janela TCP pode influenciar na para o enlace em questão e o MTU é o tamanho máximo do
performance TCP. quadro. Além disso, esse cálculo é baseado no protocolo IP
versão 4 com cabeçalhos TCP/IP de 20 bytes cada (20 para
TCP e 20 para IP) dentro do MTU, onde cada byte representa
8 bits.
Por exemplo, levando em consideração o FPS má-
ximo de uma conexão Fast Ethernet de 100 Mbps valendo
8127 quadros por segundo e o MTU Ethernet de 1500 Bytes,
logo a Vazão TCP máxima é de 94,9 Mbps.
Enfim, para se calcular a Vazão TCP em função do
tamanho da janela TCP, a seguinte fórmula pode ser utili-
zada:
Figura 4. 3: Exemplo para o cálculo do produto da largura de banda pelo tamanho da janela TCP [Bytes] · 8
atraso.
Vazão TCP [bps] =
RTT[segundos]
(4)
Supondo um enlace Wide Area Network (WAN) de Vale ainda ressaltar que pacotes perdidos podem de-
60 Mbps com atraso de ida e volta de 50 ms (RT T = 50ms) e gradar seriamente uma conexão TCP. Por exemplo, em uma
tamanho de janela do transmissor de 64 KB, o BDP seria de LAN Gigabit Ethernet conectada a uma WAN a 10 Mbps
384 KB. Esse BDP representa seis vezes o tamanho da janela pode resultar em casos em que a WAN operará de modo in-
do transmissor. Dessa forma, o transmissor alcançaria uma devido, com rajadas de gigabits, gerando perdas de pacotes e
vazão de, aproximadamente, 10 Mbps. retransmissões TCP.
Porém, quando o tamanho da janela TCP excede o
BDP, o limite máximo de FPS (Frames Per Second) do en-
lace é atingido, e então a fórmula para o cálculo da Vazão
5
máxima TCP alcançável é [24]: O presente documento não visa demonstrar os métodos para se obter o
FPS de cada tipo de enlace, porém a RFC 6349 [24] demonstra os princi-
Vazão TCPmáx [bps] = FPS5máx × (MTU[Bytes]-40) × 8 (3) pais casos práticos de sua obtenção.
6 Pedro Henrique Diniz da Silva e Nilton Alves Júnior
5.1. GNU/Linux
Assim como para o GNU/Linux, no Windows, o Segundo a seção de ajuda do IPERF podemos veri-
IPERF também pode ser encontrado como um arquivo exe- ficar todas as possíveis opções disponíveis pela aplicação:
cutável. Para utilizá-lo basta realizar o download da ferra-
menta em: http://iperf.fr/download/iperf_2.0.5/iperf-2.0.5-
2-win32.zip, extrair o arquivo e executá-lo.
6. PARÂMETROS DISPONÍVEIS
Cliente/Servidor:
Opções Descrição
-f, –format Formato do relatório: Kbits,Mbits, Kbytes, MBytes
-i, –interval Segundos entre os relatórios periódicos de vazão
-l, –len Comprimento do buffer para se ler ou escrever (padrão de 8 KB)
-m, –print_mss Imprime o tamanho máximo do segmento TCP (MTU – cabeçalho TCP/IP)
-o, –output <arquivo> Emite o relatório ou a mensagem de erro para o arquivo especificado
-p, –port Porta do servidor a escutar/ se conectar
-u, –udp Utiliza UDP em vez de TCP
-w, –window Tamanho da janela TCP (tamanho do buffer de socket6 )
-B, –bind <host> Se liga a um <host>, uma interface ou endereço multicast
-C, –compatibility Para utilizar com versões antigas, não envia mensagens extras
-M, –mss Estabelece o tamanho máximo do segmento TCP (MTU – 40 bytes)
-N, –nodelay Estabelece nenhum atraso TCP, desabilitando o algoritmo de Nagle7
-V, –IPv6Version Estabelece o domínio para IPv6
Servidor:
Opções Descrição
-s, –server Roda em modo servidor
-U, –single_udp Roda em mode UDP single thread
-D, –daemon Roda o servidor como um daemon
Cliente:
Opções Descrição
-b, –bandwidth Para UDP, largura de banda para enviar em bits/s (padrão de 1 Mbit/s, implica a
opção –u)
-c, –client <host> Roda em modo cliente, conectando-se ao <host>
-d, –dualtest Realiza um teste bidirecional simultaneamente
-n, –num Número de bytes a serem transmitidos (em vez de –t)
-r, –tradeoff Realiza um teste bidirecional individualmente
-t, –time Tempo em segundos para transmitir dados (padrão de 10 segundos)
-F, –fileinput <name> Entra com os dados a serem transmitidos de um arquivo
-I, –stdin Entra com os dados a serem transmitidos do stdin
-L, –listenport Porta para receber testes bidirecionais de volta
-P, –parallel Número de threads de clientes em paralelo para serem executadas
-T, –ttl Time-to-Live, para multicast (padrão 1)
-Z, –linux-congestion Estabelece o algoritmo de controle de congestionamento (somente para Linux)
<algo>
Diversos:
Opções Descrição
-x, –reportexclude Exclui os relatórios C (conexão) D (dados) M (multicast) S (definições) V
[CDMSV] (servidor)
-y, –reportstyle C Relatório com valores separados por vírgulas
-h, –help Imprime a mensagem de ajuda e sai
-v, –version Imprime as informações de versão e sai
6 Um socket de redes TCP estabelece um elo de comunicação entre duas Figura 6. 1: Configuração de cliente/servidor.
aplicações que estão conectadas em uma rede. São definidos como a
combinação de um endereço IP e o número de uma porta do protocolo
TCP [25].
7 O algoritmo TCP/IP de Nagle foi projetado para evitar problemas com
pacotes pequenos, chamados de tinygrams, em redes lentas. O algoritmo 6.2.1. Configurações Padrão
diz que uma conexão TCP/IP pode ter somente um segmento pequeno
pendente que ainda não fora confirmado. A definição de "pequeno"varia,
mas geralmente é definido como "inferior ao tamanho do segmento"que Por padrão, o cliente IPERF se conecta ao servidor
para redes ethernet é de cerca de 1500 bytes. IPERF na porta TCP 5001.
8 Pedro Henrique Diniz da Silva e Nilton Alves Júnior
Servidor Cliente
#iperf -s #iperf -c 192.168.0.3
6.2.5. Alteração do Tamanho da Janela TCP
-------------------------------------------- -----------------------------------------------
Server listening on TCP port 5001 Client connecting to 192.168.0.3,TCP port 5001
TCP window size: 85.3 KByte (default) TCP window size: 16.0 KByte (default) O tamanho da janela TCP pode variar entre 2 e
-------------------------------------------- ----------------------------------------------
[ 4] local 192.168.0.4 port 5001 connected with [ 3] local 192.168.0.4 port 38110 connected with
65.535 bytes, de acordo com o cabeçalho TCP. Em especial,
192.168.0.3 port 38110 192.168.0.3 port 5001 em sistemas Linux quando especificado o tamanho do buffer
[ ID] Interval Transfer Bandwidth [ ID] Interval Transfer Bandwidth
[ 4] 0.0-10.0 sec 112 MBytes 93.9 Mbits/sec [ 3] 0.0-10.0 sec 112 MBytes 94.2 Mbits/sec
TCP com argumento –w, o kernel aloca o dobro do tamanho
especificado.
Servidor Cliente
6.2.2. Formatação da Saída
#iperf –s –w 13KB #iperf -c 192.168.0.3–w 13KB
---------------------------------------------- ----------------------------------------------
Server listening on TCP port 5001 Client connecting to 192.168.0.3,TCP port 5001
A opção –f permite exibir a saída nos seguintes for- TCP window size: 13.0 KByte TCP window size: 13.0 Kbyte
matos: (b) bits, (B) bytes, (k) kilobits, (K) kilobytes, (m) ---------------------------------------------- ----------------------------------------------
[324] local 192.168.0.3 port 5001 connected [136] local 192.168.0.4 port 38120 connected
megabits, (M) megabytes, (g) gigabits e (G) gigabytes. with 192.168.0.4 port 38120 with 192.168.0.3 port 5001
[ ID] Interval Transfer Bandwidth [ ID] Interval Transfer Bandwidth
[324] 0.0-10.0 sec 104 MBytes 87.1 Mbits/sec [136] 0.0-10.0 sec 104 MBytes 87.1 Mbits/sec
Servidor Cliente
#iperf -s #iperf -c 192.168.0.3 -f M
---------------------------------------------- ----------------------------------------------
Server listening on TCP port 5001 Client connecting to 192.168.0.3, TCP port 5001
TCP window size: 85.3 KByte (default) TCP window size: 0.02 MByte (default)
---------------------------------------------- ----------------------------------------------
[ 4] local 192.168.0.3 port 5001 connected with [ 3] local 192.168.0.4 port 38111 connected
192.168.0.4 port 38111 with 192.168.0.3 port 5001
6.2.6. Alteração da Porta TCP, Intervalo de Relatórios e Tempo
[ ID] Interval Transfer Bandwidth [ ID] Interval Transfer Bandwidth de Transmissão de Dados
[ 4] 0.0-10.0 sec 112 MBytes 93.9 Mbits/sec [ 3] 0.0-10.0 sec 112 MBytes 11.2 MBytes/sec
#iperf -s #iperf -c 192.168.0.3–r Server listening on TCP port 10000 Client connecting to 192.168.0.3, TCP port
Server listening on TCP port 5001 Server listening on TCP port 5001 ---------------------------------------------- TCPwindow size: 8.00 KByte (default)
TCP window size: 85.3 KByte (default) TCP window size: 85.3 KByte (default) [ 4] local 192.168.0.3 port 10000 connected ----------------------------------------------
---------------------------------------------- ---------------------------------------------- with 192.168.0.4 port 57008 [ 136] local 192.168.0.4 port 57008 connected
[ 4] local 192.168.0.3 port 5001 connected with ---------------------------------------------- [ ID] Interval Transfer Bandwidth with 192.168.0.3 port 10000
[ 4] 0.0-20.3 sec 1.14 MBytes 471 Kbits/sec [ ID] Interval Transfer Bandwidth
192.168.0.4 port 56648 Client connecting to 192.168.0.3, TCP port 5001
[ 136] 0.0-5.0 sec 296 KBytes 485 Kbits/sec
[ ID] Interval Transfer Bandwidth TCP window size: 66.8 KByte (default)
[ 136] 5.0-10.0 sec 288 Kbytes 472 Kbits/sec
[ 4] 0.0-10.1 sec 113 MBytes 93.9 Mbits/sec ----------------------------------------------
[ 136] 10.0-15.0 sec 288 KBytes 472 Kbits/sec
---------------------------------------------- [ 5] local 192.168.0.4 port 56648 connected
[ 136] 15.0-20.0 sec 288KBytes 472 Kbits/sec
Client connecting to 192.168.0.4, TCP port 5001 with 192.168.0.3 port 5001
[ 136] 0.0-20.4 sec 1.14 Mbytes470 Kbits/sec
TCP window size: 65.2 KByte (default) [ ID] Interval Transfer Bandwidth
---------------------------------------------- [ 5] 0.0-10.0 sec 113 MBytes 94.9 Mbits/sec
[ 4] local 200.20.94.60 port 38335 connected [ 4] local 192.168.0.4 port 5001 connected with
with 200.20.94.64 port 5001 192.168.0.3 port 38335
[ 4] 0.0-10.0 sec 112 MBytes 93.6 Mbits/sec [ 4] 0.0-10.0 sec 112 MBytes 93.4 Mbits/sec
6.2.4. Medição da Largura de Banda Bidirecional Simultânea A opção de testes UDP fornece informações sobre
o jitter e a perda de pacotes. O jitter é a variação (desvio-
Por padrão, somente a largura de banda do cliente padrão) dos tempos de chegada de pacotes, ou seja, o jit-
para o servidor é mensurada. Para realizar medições bidire- ter pode ser considerado como a variação da latência [26].
cionais simultâneas, utiliza-se o argumento –d. Para aplicações como transmissão de vídeo e áudio (VoIP por
exemplo), não importa se pacotes demoram 10ms, 20ms ou
Servidor Cliente 100ms para chegarem ao receptor contanto que o tempo de
#iperf -s #iperf -c 192.168.0.3–d
---------------------------------------------- ---------------------------------------------- transmissão seja constante. Para o caso de chamadas VoIP,
Server listening on TCP port 5001 Server listening on TCP port 5001
TCP window size: 85.3 KByte (default) TCP window size: 85.3 KByte (default) altas taxas de jitter podem interromper uma ligação. O pro-
---------------------------------------------- ----------------------------------------------
[ 4] local 192.168.0.3 port 5001 connected with ---------------------------------------------- blema de jitter é, em geral, atenuado com o armazenamento
192.168.0.4 port 38118 Client connecting to 192.168.0.3, TCP port 5001
----------------------------------------------
Client connecting to 192.168.0.4, TCP port 5001
TCP window size: 72.9 KByte (default)
----------------------------------------------
dos fluxos em buffers do lado do receptor, o que não afeta a
TCP window size: 42.2 KByte (default)
----------------------------------------------
[ 3] local 192.168.0.4 port 38118 connected
with 192.168.0.3 port 5001
largura de banda, mas aumenta o retardo suavizando a flutu-
[ 6] local 192.168.0.3 port 35503 connected
with 192.168.0.4 port 5001
[ 5] local 192.168.0.4 port 5001 connected with
192.168.0.3 port 35503
ação.
[ ID] Interval
[ 4] 0.0-10.0 sec
Transfer Bandwidth
111 MBytes 92.9 Mbits/sec
[ ID] Interval
[ 3] 0.0-10.0 sec
Transfer Bandwidth
111 MBytes 93.1 Mbits/sec
Vale ressaltar que os resultados reportados pelo ser-
[ 6] 0.0-10.0 sec 31.4 MBytes 26.2 Mbits/sec [ 5] 0.0-10.1 sec 31.4 MBytes 26.2 Mbits/sec
vidor são ligeiramente mais precisos, uma vez que o trans-
missor pode calcular a taxa de transmissão logo após realizar
CBPF-NT-003/14 9
Servidor
#iperf –s –u
Cliente
#iperf -c 192.168.0.3–u –b 50m
7. ESTUDOS DE CASO
---------------------------------------------- ----------------------------------------------
Server listening on UDP port 5001 Client connecting to 192.168.0.3, UDP port 5001
Receiving 1470 byte datagrams Sending 1470 byte datagrams Nesta seção, são apresentados alguns casos reais em
UDP buffer size: 110 KByte (default) UDP buffer size: 110 KByte (default)
---------------------------------------------- ---------------------------------------------- que a utilização do IPERF auxilia na homologação de redes
[ 3] local 192.168.0.3 port 5001 connected with
192.168.0.4 port 54729
[ 3] local 192.168.0.4 port 54729 connected with
192.168.0.3 port 5001
que fazem uso de técnicas de políticas de controle de banda
[ ID] Interval Transfer Bandwidth [ ID] Interval Transfer Bandwidth e de técnicas de balanceamento de carga, e auxilia também
Jitter Lost/Total Datagrams [ 3] 0.0-10.0 sec 59.6 MBytes 50.0 Mbits/sec
[ 3] 0.0-10.0 sec 59.6 MBytes 50.0 Mbits/sec [ 3] Sent 42532 datagrams na geração de fluxos UDP de altas taxas de transmissão para
0.126 ms 0/42531 (0%)
[ 3] 0.0-10.0 sec 1 datagrams received out-of-
[ 3] Server Report:
[ 3] 0.0-10.0 sec 59.6 MBytes 50.0 Mbits/sec
medição de largura de banda em enlaces onde não é possível
order 0.125 ms 0/42531 (0%) utilizar um servidor IPERF.
[ 3] 0.0-10.0 sec 1 datagrams received out-of-
order
Servidor Cliente
#iperf –s #iperf -c 192.168.0.3–m
---------------------------------------------- ----------------------------------------------
Server listening on TCP port 5001 Client connecting to 192.168.0.3,TCP port 5001
TCP window size: 85.3 KByte (default) TCP window size: 16.0 KByte (default)
---------------------------------------------- ----------------------------------------------
[ 3] local 192.168.0.4 port 41053 connected
with 192.168.0.3 port 5001
[ ID] Interval Transfer Bandwidth
[ 3] 0.0-10.0 sec 2967912595171227 bits 0.00 Figura 7. 1: Layout da rede para testes de política de controle de banda.
(null)s/sec
[ 3] MSS size 1448 bytes (MTU 1500 bytes,
ethernet)
Na Figura 7.2, podemos verificar o comando apli-
cado no cliente e a sua respectiva saída antes de serem apli-
cadas as políticas de controle. É possível observar que foram
gerados 94,5 Mbps de tráfego UDP pelo cliente e foram re-
6.2.9. Testes em Paralelo portados 94,4 Mbps e nenhuma perda pelo servidor.
monstra as políticas de limitação fazendo com que os pacotes de que o servidor envie confirmações ao cliente ao receber
entrantes na interface f0/2 sejam perdidos. os dados, não há a necessidade de um servidor escutando
na porta UDP especificada pelo cliente. Portanto, podemos
utilizar somente um cliente IPERF gerando tráfego em modo
UDP e utilizar alguma outra ferramenta passiva de monitora-
mento de redes para checar as taxas de transmissão atingidas
em cada enlace.
No teste demonstrado na Figura 7.4 foram utiliza-
dos 6 switches/roteadores Cisco ME 3400E e um cliente
IPERF gerando tráfego UDP. Nesse caso, 4 roteadores (R1,
R2, R3 e R4) foram utilizados para simular um backbone
Figura 7. 3: Comando IPERF aplicado ao cliente após a aplicação das com Interior Gateway Protocol (IGP), especificamente o
políticas ao roteador. OSPF, com balanceamento de carga por fluxos e 2 deles (R5
e R6) foram utilizados para simular dois enlaces com opera-
doras distintas. Dois fluxos distintos de 50 Mbps foram gera-
dos no mesmo cliente com destino para R5 e R6, durante 12
7.2. Testes de Balanceamento de Carga horas (43200 segundos). Cada um dos comandos utilizados
para gerar cada um dos fluxos pode ser encontrado a seguir:
As técnicas de balanceamento de carga ou load ba-
lancing são amplamente utilizadas por provedores de servi- Fluxo 1:$iperf –c 10.0.40.2 –u –b 50m –t 43200 –i 2
ços de Internet de modo a tornar mais eficiente o uso da lar- Fluxo 2:$iperf –c 10.0.40.2 –u –b 50m –t 43200 –i 2
gura de banda disponível. Essas técnicas remetem a uma
funcionalidade dos roteadores de distribuir pacotes através Desse modo, podemos verificar as técnicas de ba-
de múltiplos enlaces baseado em informações de roteamento. lanceamento de tráfego operando através da utilização da fer-
Um balanceamento de carga efetivo tenta fazer o ramenta IPERF, por meio da geração de tráfego UDP, sem a
uso mais eficiente da banda disponível e distribui o tráfego necessidade de um servidor em operação. Casos similares a
entre diversas rotas, baseando-se em protocolos de rotea- esse podem ser de grande valia quando for necessário testar
mento, e/ou interfaces distintas, baseando-se em protoco- enlaces, mas não for possível o acesso a um servidor IPERF
los de agregação de enlaces como Link Aggregation Control para responder às solicitações.
Protocol (LACP), por exemplo [27]. O algoritmo respon- Esse documento não visa demonstrar as técnicas de
sável por realizar a distribuição de tráfego depende de cada balanceamento utilizadas nem como implementá-las, porém
implementação individualmente e, com isso, sua eficiência as mesmas podem ser encontradas em [28]. Para obtermos as
pode variar. Especificamente, tratando-se de equipamentos imagens referentes às taxas de transmissão em cada uma das
Cisco, equipamentos esses que são utilizados no backbone interfaces de R1 foi utilizada a ferramenta RRDTool [29].
da RedeRio/FAPERJ e REDECOMEP Rio de Janeiro, são Essa ferramenta é simples e fácil de utilizar, sendo ampla-
suportados dois modos de balanceamento de carga. São eles: mente utilizada para monitoramento de redes de computado-
o balanceamento baseado em pacotes e o baseado em fluxos res.
(ou destinos).
Cada um dos modos citados acima possui uma apli-
cabilidade diferente. No modo por destino todos os pacotes 7.3. Geração de Tráfego UDP de Altas Taxas
destinados a um dado IP são entregues através de um mesmo
caminho, preservando assim a ordem dos pacotes, mas com Para caminhos em que sejam necessários um espaço
um uso desigual dos enlaces. No modo por pacotes, cada de buffers grande, como é o caso de caminhos em que o RTT
pacote é entregue através de enlaces diferentes, garantindo é alto por exemplo, é necessário que algumas opções de alta
um uso igual de cada um dos enlaces. Porém, nesse caso performance, discutidas a seguir, sejam ativadas.
os pacotes podem chegar fora de ordem ao destino, devido a A maioria dos sistemas operacionais suportam li-
atrasos diferentes em cada um dos enlaces da rede. mites de buffer de transmissão e recepção por conexão se-
O modo de balanceamento padrão apresentado pe- parados, os quais podem ser configurados pelo usuário, pela
los roteadores Cisco através dos mecanismos de roteamento aplicação ou outro mecanismo, contanto que estejam dentro
dinâmico como os Open Shortest Path First (OSPF), Interior dos limites máximos de memória.
Gateway Routing Protocol (IGRP) e Intermediate System to Os tamanhos dos socket buffers padrões podem ser
Intermediate System (IS-IS) é o modo por destino. Como o alterados por controles globais do sistema operacional. O
backbone da RedeRio/FAPERJ e REDECOMEP opera atra- ajuste manual desses buffers é a maneira mais simples de
vés de uma dessas configurações, vamos exemplificar um se aumentar o desempenho de aplicações quaisquer, como o
método simples para verificar o funcionamento do balancea- caso do IPERF.
mento utilizando a ferramenta IPERF. Nessa seção, são exemplificados como os parâme-
Como em modo UDP, o IPERF não possui controle tros de buffers em um sistema Linux devem ser alterados
de fluxo nem controle de congestionamento, então o cliente para aumentarmos a taxa de geração de tráfego UDP com
tenta enviar dados ao servidor somente a taxa especificada o IPERF. O ajuste desses parâmetros em outros tipos de sis-
pelo parâmetro –b. Assim, como em modo UDP não ocorre a temas e uma explicação mais detalhada sobre transferência
transmissão confiável de dados, não existindo a necessidade de alto desempenho podem ser encontrados em [30].
CBPF-NT-003/14 11
R2
R6
10
/ 24 .0 .
0.0 /1 g0 30 g0/1 Roteador R6
.0 . g0 /2 .0 / .1 Destino do tráfego
10 .1 .2 24 R4
g0/4
.1 /24
g0
/3 g0
/1 .50.0
Cliente Iperf .2 .1 10.0
Gerador de tráfego 10.0
192.168.0.0/24 10 .40.0 R5
.0. 24 /24
eth0 g0/1 g0 1 .0 / g0/3
.105 fluxo 1 .50 R1 .2
/2 0.0
/ 24 . 0 .20 g0
/2 .1
10 .1 g0/1 Roteador R5
fluxo 1: iperf -c 10.0.40.2 -u -b 50m -t 43200 -i 2 fluxo 2 g0 .2 Destino do tráfego
/1 /2
.1 g0
fluxo 2: iperf -c 10.0.50.2 -u -b 50m -t 43200 -i 2 .2
R3
Em um sistema Linux, os parâmetros do sistema po- riormente, temos um tamanho de buffer de cerca de:
dem ser lidos ou alterados pela ferramenta sysctl, como em:
1.000.000.000 bits 1 byte
Leitura de todos os parâmetros: #sysctl –a Buffer UDP=BDP × ×
1 segundo 8 bits
Ajuste de parâmetro: #sysctl –w [parâmetro]=[valor]
×0, 001691 segundo = 211375 bytes
Os parâmetros responsáveis por alterar o tamanho +overhead = 307200 bytes
dos buffers padrão para sockets UDP para transmissão e
recepção são, respectivamente: net.core.wmem_default e
net.core.rmem_default[30]. Ao ajustarmos esses parâme- Buffer Default(110 KB) Buffer Alterado (300 KB)
tros conseguimos aumentar ou diminuir o tamanho do buffer Cliente # iperf -c 192.168.250.1 -u -b 1000m -t # iperf -c 192.168.250.1 -u -b 1000m -t 20 -i
IPERF 20 -i 5 5
UDP, de acordo com as necessidades. Por exemplo, podemos Geração --------------------------------------- -------------------------------------------
ajustar ambos os buffers para 1 MB da seguinte forma: de Client connecting to 192.168.250.1, UDP Client connecting to 192.168.250.1, UDP port
=1048576 ---------------------------------------
[ 3] local 192.168.200.2 port 39549
-------------------------------------------
[ 3] local 192.168.200.2 port 50355
connected with 192.168.250.1 port 5001 connected with 192.168.250.1 port 5001
root@iperf_server:˜ # sysctl –w net.core.rmem_default [ ID] Interval Transfer Bandwidth [ ID] Interval Transfer Bandwidth
[ 3] 0.0- 5.0 sec 218 MBytes 365 [ 3] 0.0- 5.0 sec 337 MBytes 565
=1048576 Mbits/sec Mbits/sec
[ 3] 5.0-10.0 sec 220 MBytes 370 [ 3] 5.0-10.0 sec 352 MBytes 591
Como valor inicial para ajuste do tamanho dos buf- Mbits/sec Mbits/sec
[ 3] 10.0-15.0 sec 220 MBytes 369 [ 3] 10.0-15.0 sec 358 MBytes 600
fers o valor do BDP pode ser utilizado acrescentado de um Mbits/sec Mbits/sec
valor adicional referente a um overhead específico do sis- [ 3] 15.0-20.0 sec 198 MBytes 332 [ 3] 0.0-20.0 sec 1.37 GBytes 587
Mbits/sec Mbits/sec
tema operacional. [ 3] 0.0-20.0 sec 855 MBytes 359 [ 3] Sent 998107 datagrams
Mbits/sec [ 3] WARNING: did not receive ack of last
ratório, em que dois roteadores modelos Cisco ME3400 E datagram after 10 tries.
xima UDP que conseguimos obter para um determinado en- Devido a esses e outros fatores, tais como: rotas
lace. assimétricas do cliente para o servidor e do servidor para o
cliente; e a compressão de dados em função dos protocolos
utilizados pela aplicação, os testes de largura de banda devem
8. CONCLUSÃO ser realizados de forma bidirecional. Isso permite verificar
se a banda disponível é comparável em ambos os sentidos
dependendo de que nó esteja sendo usado como servidor.
O presente trabalho visou demonstrar a utilização
Além disso, vale ainda ressaltar que os testes UDP
da ferramenta de geração e medição de tráfego IPERF. Pri-
realizados utilizando somente o cliente IPERF é útil para ca-
meiramente, foram apresentadas uma visão geral das ferra-
sos em que somente se deseja saturar enlaces e se tem co-
mentas de medição ativa de redes e da ferramenta IPERF. Em
nhecimento da banda de cada enlace em todo o caminho.
seguida, foi apresentada uma breve introdução sobre os prin-
Para casos em que se deseja medir a banda útil, reportando
cipais conceitos referentes aos protocolos UDP e TCP, pri-
a perda de pacotes e o jitter, é necessário a utilização do ser-
mordiais para compreender o funcionamento da ferramenta.
vidor IPERF, sendo possível assim notar congestionamentos
Em sequência, foram apresentados os procedimentos de ins-
na rede.
talação da ferramenta, os parâmetros principais de utilização
e, por fim, alguns casos práticos em que pode ser utilizada. Contudo, o IPERF ainda apresentou como princi-
pais características:
Em suma, dentre os protocolos de transporte o TCP
fragmenta as mensagens da aplicação em pacotes IP, po-
1. Simplicidade de uso;
dendo realizar a detecção e correção de erros, o controle de
fluxo fim-a-fim (da origem ao destino), além de ser um pro- 2. Eficácia no que se propõe, que é gerar e medir o trá-
tocolo orientado a conexões. O UDP é não orientado a co- fego;
nexão, não faz controle de fluxo nem de congestionamento e
não garante que os pacotes sejam entregues ao destino. Ba- 3. Permissão de utilizar dados reais para simular a trans-
sicamente, ele serve para transações que envolvem apenas ferência confiável de dados, simulando o envio através
mensagens curtas, rápidas e do tipo pergunta/resposta. Ou de um protocolo de transferência confiável de dados
seja, é útil para situações em que a rapidez é mais importante como o FTP;
do que a precisão. Apesar de servir, essencialmente, para
transmissão de mensagens curtas, o que implica em baixa 4. Auxílio na compreensão de como a alteração dos pa-
utilização de banda, muito se tem estudado para otimização râmetros do TCP, como a janela TCP e a utilização do
da pilha de protocolos UDP/IP sobre redes de altas velocida- algoritmo de Nagle, podem influenciar na utilização da
des [31]. largura de banda disponível;
Em se tratando da ferramenta IPERF, os procedi-
5. Auxílio a administradores de rede a dimensionar as
mentos de instalação apresentados na seção 5 demonstraram
aplicações que fazem uso da rede, como por exemplo
ser bastante simples e rápidos, tanto para plataformas Win-
a vazão de servidores.
dows quanto Linux. O mesmo se aplica a outras plataformas
como MAC e Solaris, não tendo sido apresentados nesse do- 6. Possibilidade de gerar tráfego UDP de altas taxas, sem
cumento. a necessidade de um servidor para receber o tráfego,
O IPERF se mostrou uma ferramenta simples, po- simplificando os testes na rede.
rém muito útil. Ela pode ser utilizada para testar o desem-
penho de conexões TCP e sessões UDP, além da perda de Entretanto, apesar das características positivas que a
pacotes e jitter através do modo UDP. Provê informações ferramenta apresenta, ela ainda carece de algumas melhorias
básicas necessárias para a solução de problemas relaciona- para o seu aprimoramento. Dentre elas, podemos citar as que
dos aos protocolos UDP e TCP. foram consideradas como mais pertinentes:
Como a banda disponível pode ser influenciada por
diversos fatores, como os citados a seguir, o IPERF demons- 1. Medição do atraso de ida e volta dos pacotes direta-
tra ser mais útil para testes em ambientes fora de produção: mente pela aplicação IPERF, para auxiliar no cálculo
do BDP.
1. os horários do dia e dias da semana em que as medi-
ções são realizadas; 2. Método de detecção da largura de banda de cada um
dos enlaces no caminho dos pacotes na rede, a fim de
2. carga muito alta de utilização de CPU, o que pode im- detectar gargalos fim a fim, para auxiliar na detecção
pedir que a aplicação e a pilha de protocolos de rede de congestionamentos na rede.
CBPF-NT-003/14 13
3. Método de detecção do modo Duplex (Half ou Full) Em síntese, pode-se afirmar que o IPERF torna sim-
de cada um dos enlaces fim a fim. ples medir o desempenho de aplicações baseadas em fluxos
TCP e UDP, apesar de não ser possível simular e testar o
Cada uma dessas considerações tornam-se relevan- desempenho de todo tipo de aplicação, como é o caso de
tes para melhorar a análise e desempenho de redes através da aplicações Web interativas.
ferramenta IPERF.
[1] KISSEL, E. et al. Efficient wide area data transfer proto- the capacity of network paths. 2006. Disponível em:
cols for 100 Gbps networks and beyond. Proceedings of the <http://www.cc.gatech.edu/˜dovrolis/bw-est/pathrate.html>.
Third International Workshop on Network-Aware Data Mana- Acesso em: 28 de julho de 2014.
gement. Denver, Colorado: ACM: 1-10 p. 2013.2 [16] NUTTCP DEVELOPMENT TEAM. NUTTCP
[2] GARZOGLIO, G. et al. Big Data Over a 100G Network Welcome Page. 2014. Disponível em:
at Fermilab. Journal of Physics: Conference Series, v. <http://www.nuttcp.net/nuttcp/Welcome%20Page.html>.
513, n. 6, p. 7, 2014. ISSN 1742-6596. Disponível em: Acesso em: 28 de julho de 2014.
<http://stacks.iop.org/1742-6596/513/i=6/a=062017>. [17] APPNETA. PathView - Network health monitoring over any
[3] PINTO, J. D. O. et al. DWDM em Redes Metropolitanas. Nota network. 2014. Disponível em:
Técnica do CBPF – NT001/02. Rio de Janeiro, Brasil 2002. <http://www.appneta.com/products/pathview/>. Acesso em:
[4] ESTEVES, A. M. B. Sistema de monitoramento de redes 28 de julho de 2014.
baseado nos protocolos SNMP e SpanningTree 2013. (Disser- [18] NCSA NEWS REPORT TEAM. NLANR DAST Team Re-
tação de Mestrado em Física - Instrumentação Científica). leases New Software. NCSA NEWS, 2001. Disponível em:
Centro Brasileiro de Pesquisas Físicas, Rio de Janeiro, RJ, <http://access.ncsa.illinois.edu/Briefs/01Briefs/
Brasil. 010508.NLANR.html>. Acesso em: 12 de maio de 2014.
[5] MIRANDA, E. F. Desenvolvimento de Sitema para Moni- [19] POSTEL, J. RFC 768 - User Datagram Protocol. Internet En-
toramento de Redes de Computadores e Servidor Looking gineering Task Force (IETF), p.3. 1980.
Glass 2013. (Dissertação de Mestrado em Física - Instrumen- [20] COMMER, D. E. Redes de Computadores e Internet. 4a edi-
tação Científica). Centro Brasileiro de Pesquisas Físicas, Rio ção. ed. Porto Alegre: Artmed/Bookman, 2007.
de Janeiro, RJ, Brasil. [21] POSTEL, J. RFC 793 - Transmission Control Protocol. Inter-
[6] MIRANDA, E. F.; ALVES JR., N.; SOUZA, M. G. M. Desen- net Engineering Task Force (IETF), p.85. 1981.
volvimento de um Repositório RIB-BGP. Notas Técnicas do [22] REZENDE, J. F. D.; COSTA, L. H. M. K.; RUBINSTEIN,
CBPF, Rio de Janeiro, RJ, Brasil, v. 3, n. 2, p. 6, 2013. ISSN M. G. Avaliação Experimental e Simulação do Protocolo TCP
0101-9201. Disponível em: em Redes de Alta Velocidade XXII Simpósio Brasileiro de
<http://cbpfindex.cbpf.br/publication_pdfs/ Telecomunicações - SBrT’05 Campinas, SP, Brasil: 6 p. 2005.
nt00413apub.2013_08_02_09_04_39.pdf>. [23] ALLMAN, M.; PAXSON, V.; BLANTON, E. RFC 5681 -
[7] ALVES JR., N. et al. Topologia e Modelagem Relacional da TCP Congestion Control. Internet Engineering Task Force
Internet Brasileira. Nota Técnica do CBPF - NT-004/4. Rio de (IETF), p.18. 2009.
Janeiro, RJ, Brasil 2004. [24] CONSTANTINE, B. et al. RFC 6349 - Framework for TCP
[8] ALVES JR., N. Caracterização de redes complexas aplicação Throughput Testing. Internet Engineering Task Force (IETF),
à modelagem relacional entre Sistemas Autônomos da Inter- p.27. 2011.
net 2007. (Tese de Doutorado em Modelagem Computacio- [25] KUROSE, J. F.; ROSS, K. W. Redes de computadores e a In-
nal). IPRJ, Universidade do Estado do Rio de Janeiro, Nova ternet: uma abordagem top-down. 5a edição. São Paulo: Ad-
Friburgo, RJ, Brasil. dison Wesley, 2010.
[9] CACTI GROUP INC. Cacti - The complete RRDTool- [26] TANEMBAUM, A. S. Redes de Computadores. 3a edição. São
based graphing solution. 2014. Disponível em: Paulo: Elsevier, 2003.
<http://www.cacti.net/>. Acesso em: 27 de julho de [27] CISCO SYSTEMS INC. Configuring EtherChannels. In:
2014. (Ed.). Cisco ME 3400 Switch Software Configuration Guide,
[10] OETIKER, T. MRTG - Tobi Oetiker’s MRTG - The Rel. 12.2(25)EX. San Jose, California, Estados Unidos, 2005.
Multi Router Traffic Grapher. 2011. Disponível em: cap. 31, p.602 - 623.
<http://oss.oetiker.ch/mrtg/>. Acesso em: 28 de julho [28] CISCO SYSTEMS INC. Configuring a Load-Balancing
de 2014. Scheme. In: (Ed.). IP Switching Cisco Express Forwarding
[11] LABIT, Y.; OWEZARSKI, P.; LARRIEU, N. Evaluation of Configuration Guide. San Jose, California, Estados Unidos,
Active Measurement Tools for Bandwidth Estimation in Real 2012. cap. 5, p.47 - 58.
Environment. Third IEEE/IFIP Workshop on End-to-End Mo- [29] OETIKER, T. About RRDtool - Logging and graphing 2013.
nitoring Techniques and Services, E2EMON. Nice, França: Disponível em: <http://oss.oetiker.ch/rrdtool/>. Acesso em:
IEEE: 71 - 85 p. 2005. 12 de maio de 2014.
[12] DOWNEY, A. B. Clink: a tool for estimating In- [30] PITTSBURGH SUPERCOMPUTING CENTER. Ena-
ternet link characteristics. 1999. Disponível em: bling High Performance Data Transfers. 2014. Disponível
<http://allendowney.com/research/clink/>. Acesso em: em: <http://www.psc.edu/index.php/networking/641-tcp-
28 de julho de 2014. tune#detailed>. Acesso em: 12 de maio de 2014.
[13] FRENCH FORUM FOR IPERF. Iperf. 2014. Disponível em: [31] JIN, H.-W.; YOO, C. Impact of protocol overheads on
< https://iperf.fr/ >. Acesso em: 28 de julho de 2014. network throughput over high-speed interconnects: measure-
[14] JONES, R. Netperf Homepage. 2014. Disponível em: ment, analysis, and improvement. J. Supercomput., v. 41, n. 1,
<http://www.netperf.org/netperf/NetperfPage.html>. Acesso p. 17-40, 2007. ISSN 0920-8542.
em: 28 de julho de 2014.
[15] DOVROLIS, C. Pathrate - A measurement tool for