AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • Início
  • system&network
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • Início
  • system&network
    • Recentes
    • Highest score
    • tags
  • Ubuntu
    • Recentes
    • Highest score
    • tags
  • Unix
    • Recentes
    • tags
  • DBA
    • Recentes
    • tags
  • Computer
    • Recentes
    • tags
  • Coding
    • Recentes
    • tags
Início / unix / Perguntas / 527094
Accepted
KuboMD
KuboMD
Asked: 2019-06-27 10:04:47 +0800 CST2019-06-27 10:04:47 +0800 CST 2019-06-27 10:04:47 +0800 CST

Calculando a perda de pacotes do ping?

  • 772

Eu tenho uma VM ESXi que executa comandos em alguns dispositivos de 700 ~ em nossa rede. Está usando Expect, e devido à idade deste equipamento eles têm períodos de baixo desempenho. Esses dois não se misturam bem - pois o script Expect terá que esperar muito tempo para obter a saída antes de prosseguir.

Para tentar evitar isso, nossa equipe decidiu que um pingteste deveria ser feito antes de conectar ao dispositivo. Se houver perda de pacotes, voltaremos a isso mais tarde.

O problema que estamos tendo é que nosso teste de ping se parece com isso:

loss=`ping -i 0.2 -w 2 $1 | grep "packet loss" | awk '{print $6}'`
loss=${loss%?}

echo "$loss"

10 pings em dois segundos - mas recebemos muitas respostas de perda de pacotes de 9% . Por exemplo, geralmente temos testes 74/700 saindo preventivamente devido à detecção de perda de pacotes. 39/74 desses relatam 9% , enquanto o restante relata em múltiplos de 10.

Até onde podemos dizer, isso não faz sentido; há 10 pacotes sendo enviados... se um for descartado, deve haver uma perda de 10%. Isso tem sido observado com pouca frequência, mas acontece. É possível que haja algo acontecendo na memória que esteja fazendo com que o número 9 se manifeste? Se estes são casos legítimos de perda de pacotes, então é uma grande notícia para nós.

networking ping
  • 1 1 respostas
  • 3374 Views

1 respostas

  • Voted
  1. Best Answer
    user232326
    2019-06-27T12:04:08+08:002019-06-27T12:04:08+08:00

    Existem várias versões de ping. Alguns têm a -wopção. Alguns aceitam, mas não são documentados. Em algumas versões do ping, isso acontece:

    $ ping -i 0.2 -w 2 127.0.0.1
    PING 127.0.0.1 (127.0.0.1): 56 data bytes
    64 bytes from 127.0.0.1: icmp_seq=0 ttl=64 time=0.091 ms
    64 bytes from 127.0.0.1: icmp_seq=1 ttl=64 time=0.091 ms
    64 bytes from 127.0.0.1: icmp_seq=2 ttl=64 time=0.089 ms
    64 bytes from 127.0.0.1: icmp_seq=3 ttl=64 time=0.086 ms
    64 bytes from 127.0.0.1: icmp_seq=4 ttl=64 time=0.088 ms
    64 bytes from 127.0.0.1: icmp_seq=5 ttl=64 time=0.097 ms
    64 bytes from 127.0.0.1: icmp_seq=6 ttl=64 time=0.091 ms
    64 bytes from 127.0.0.1: icmp_seq=7 ttl=64 time=0.095 ms
    64 bytes from 127.0.0.1: icmp_seq=8 ttl=64 time=0.095 ms
    64 bytes from 127.0.0.1: icmp_seq=9 ttl=64 time=0.092 ms
    --- 127.0.0.1 ping statistics ---
    11 packets transmitted, 10 packets received, 9% packet loss
    round-trip min/avg/max/stddev = 0.086/0.091/0.097/0.000 ms
    

    Ou seja: um pacote é emitido, o tempo expira e nunca é recebido de volta.

    Assim: 1 pacote de 11 foi perdido, isso é 9% de perda.

    Com essas versões de ping, adicionar uma -copção deve resolver o problema:

    $ ping -i 0.2 -c 10 -w 5 127.0.0.1 
    PING 127.0.0.1 (127.0.0.1): 56 data bytes
    64 bytes from 127.0.0.1: icmp_seq=0 ttl=64 time=0.127 ms
    64 bytes from 127.0.0.1: icmp_seq=1 ttl=64 time=0.096 ms
    64 bytes from 127.0.0.1: icmp_seq=2 ttl=64 time=0.088 ms
    64 bytes from 127.0.0.1: icmp_seq=3 ttl=64 time=0.084 ms
    64 bytes from 127.0.0.1: icmp_seq=4 ttl=64 time=0.084 ms
    64 bytes from 127.0.0.1: icmp_seq=5 ttl=64 time=0.093 ms
    64 bytes from 127.0.0.1: icmp_seq=6 ttl=64 time=0.089 ms
    64 bytes from 127.0.0.1: icmp_seq=7 ttl=64 time=0.089 ms
    64 bytes from 127.0.0.1: icmp_seq=8 ttl=64 time=0.087 ms
    64 bytes from 127.0.0.1: icmp_seq=9 ttl=64 time=0.094 ms
    --- 127.0.0.1 ping statistics ---
    10 packets transmitted, 10 packets received, 0% packet loss
    round-trip min/avg/max/stddev = 0.084/0.093/0.127/0.000 ms
    

    Isso significa: tente pacotes a cada 0,2 segundos até que 10 pacotes tenham sido recebidos ou até que um limite de tempo de 5 segundos tenha decorrido.

    • 5

relate perguntas

  • Encontrar threads/scripts associados a uma porta?

  • Pergunta sobre arquivos montados em rede

  • Um endereço IP pode terminar em 255 e não ser um endereço IP de transmissão?

  • Incapaz de identificar qual saída de endereço MAC do comando arp ou comando ip está correta

  • Roteador estranho funciona com centos 6 [fechado]

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    Possível firmware ausente /lib/firmware/i915/* para o módulo i915

    • 3 respostas
  • Marko Smith

    Falha ao buscar o repositório de backports jessie

    • 4 respostas
  • Marko Smith

    Como exportar uma chave privada GPG e uma chave pública para um arquivo

    • 4 respostas
  • Marko Smith

    Como podemos executar um comando armazenado em uma variável?

    • 5 respostas
  • Marko Smith

    Como configurar o systemd-resolved e o systemd-networkd para usar o servidor DNS local para resolver domínios locais e o servidor DNS remoto para domínios remotos?

    • 3 respostas
  • Marko Smith

    apt-get update error no Kali Linux após a atualização do dist [duplicado]

    • 2 respostas
  • Marko Smith

    Como ver as últimas linhas x do log de serviço systemctl

    • 5 respostas
  • Marko Smith

    Nano - pule para o final do arquivo

    • 8 respostas
  • Marko Smith

    erro grub: você precisa carregar o kernel primeiro

    • 4 respostas
  • Marko Smith

    Como baixar o pacote não instalá-lo com o comando apt-get?

    • 7 respostas
  • Martin Hope
    user12345 Falha ao buscar o repositório de backports jessie 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl Por que a maioria dos exemplos do systemd contém WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky Como exportar uma chave privada GPG e uma chave pública para um arquivo 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Evan Carroll status systemctl mostra: "Estado: degradado" 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim Como podemos executar um comando armazenado em uma variável? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S Por que /dev/null é um arquivo? Por que sua função não é implementada como um programa simples? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 Como ver as últimas linhas x do log de serviço systemctl 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - pule para o final do arquivo 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla Por que verdadeiro e falso são tão grandes? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis Substitua a string em um arquivo de texto enorme (70 GB), uma linha 2017-12-30 06:58:33 +0800 CST

Hot tag

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • Início
  • Perguntas
    • Recentes
    • Highest score
  • tag
  • help

Footer

AskOverflow.Dev

About Us

  • About Us
  • Contact Us

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve