<?xml version="1.0" encoding="UTF-8"?>
<!-- $Id: manhtml.xml 3244 2006-03-29 08:44:10Z fyodor $ -->
<!-- <?xml version="1.0" encoding="iso-8859-1"?>
<!DOCTYPE refentry PUBLIC "-//OASIS//DTD DocBook XML V4.1.2//EN"
"http://www.oasis-open.org/docbook/xml/4.1.2/docbookx.dtd"> -->
<article id="man">
  <artheader>
    <title>Guia de Referência do Nmap (Página do Manual)</title>
  </artheader>

  <refentry id="man-nmap1">
    <refmeta>
      <refentrytitle>nmap</refentrytitle>

      <manvolnum>1</manvolnum>
    </refmeta>

    <refnamediv id="man-name">
      <refname>nmap</refname>

      <refpurpose>Ferramenta de exploração de rede e segurança / scanner de
      portas</refpurpose>
    </refnamediv>

    <!-- body begins here -->

    <refsynopsisdiv id="man-synopsis">
      <cmdsynopsis>
        <command>nmap</command>

        <arg choice="opt" rep="repeat">
          <replaceable>Tipo de Scan</replaceable>
        </arg>

        <arg choice="opt">
          <replaceable>Opções</replaceable>
        </arg>

        <arg choice="req">
          <replaceable>especificação do alvo</replaceable>
        </arg>
      </cmdsynopsis>
    </refsynopsisdiv>

    <refsect1 id="man-description">
      <title>Descrição</title>

      <web>
        <note>
          <para>Este documento descreve a mais recente versão do Nmap,
          disponível em <ulink url="http://insecure.org/nmap/download.html" />
          ou em <ulink url="http://insecure.org/nmap/dist/?C=M&amp;O=D" />.
          Por favor, assegure-se de que você está utilizando a última versão
          antes de reclamar que uma opção não funciona como foi
          descrita.</para>
        </note>
      </web>

      <para>O Nmap (<quote>Network Mapper</quote>) é uma ferramenta de código
      aberto para exploração de rede e auditoria de segurança. Ela foi
      desenhada para escanear rapidamente redes amplas, embora também funcione
      muito bem contra hosts individuais. O Nmap utiliza pacotes IP em estado
      bruto (raw) de maneira inovadora para determinar quais hosts estão
      disponíveis na rede, quais serviços (nome da aplicação e versão) os
      hosts oferecem, quais sistemas operacionais (e versões de SO) eles estão
      executando, que tipos de filtro de pacotes/firewalls estão em uso, e
      dezenas de outras características. Embora o Nmap seja normalmente
      utilizado para auditorias de segurança, muitos administradores de
      sistemas e rede consideram-no útil para tarefas rotineiras tais como
      inventário de rede, gerenciamento de serviços de atualização agendados,
      e monitoramento de host ou disponibilidade de serviço.</para>

      <para>A saída do Nmap é uma lista de alvos escaneados, com informações
      adicionais de cada um dependendo das opções utilizadas. Uma informação
      chave é a <quote>tabela de portas interessantes</quote>. Essa tabela
      lista o número da porta e o protocolo, o nome do serviço e o estado. O
      estado pode ser <literal>aberto (open)</literal>, <literal>filtrado
      (filtered)</literal>, <literal>fechado (closed)</literal>, ou
      <literal>não-filtrado (unfilterd)</literal>. Aberto (open) significa que
      uma aplicação na máquina-alvo está escutando as conexões/pacotes naquela
      porta. <literal>Filtrado (filtered)</literal> significa que o firewall,
      filtro ou outro obstáculo de rede está bloqueando a porta de forma que o
      Nmap não consegue dizer se ela está <literal>aberta (open)</literal> ou
      <literal>fechada (closed)</literal>. Portas <literal>fechadas
      (closed)</literal>não possuem uma aplicação escutando nelas, embora
      possam abrir a qualquer instante. Portas são classificadas como
      <literal>não filtradas (unfiltered)</literal>quando elas respondem às
      sondagens do Nmap, mas o Nmap não consegue determinar se as portas estão
      abertas ou fechadas. O Nmap reporta as combinações
      <literal>aberta|filtrada (open|filtered)</literal>e
      <literal>fechada|filtrada (closed|filtered)</literal>quando não consegue
      determinar qual dos dois estados descrevem melhor a porta. A tabela de
      portas também pode incluir detalhes de versão de software quando a
      detecção de versão for solicitada. Quando um scan do protocolo IP é
      solicitado (<option>-sO</option>), o Nmap fornece informações dos
      protocolos IP suportados ao invés de portas que estejam abertas.</para>

      <para>Além da tabela de portas interessantes, o Nmap pode fornecer
      informações adicionais sobre os alvos, incluíndo nomes de DNS reverso,
      possível sistema operacional, tipos de dispositivos e endereços
      MAC.</para>

      <para>Um scan típico do Nmap é mostrado em <xref
      linkend="man-ex-repscan" />. Os únicos argumentos que o Nmap utiliza
      nesse exemplo são <option>-A</option>, para habilitar a detecção de SO e
      a versão, <option>-T4</option> para execução mais rápida, e os hostnames
      de dois alvos.</para>

      <example id="man-ex-repscan">
        <title>Uma amostra de scan do Nmap</title>

        <screen format="linespecific">
# nmap -A -T4 scanme.nmap.org playground

Starting nmap ( http://insecure.org/nmap/ )
Interesting ports on scanme.nmap.org (205.217.153.62):
(The 1663 ports scanned but not shown below are in state: filtered)
PORT    STATE  SERVICE VERSION
22/tcp  open   ssh     OpenSSH 3.9p1 (protocol 1.99)
53/tcp  open   domain
70/tcp  closed gopher
80/tcp  open   http    Apache httpd 2.0.52 ((Fedora))
113/tcp closed auth
Device type: general purpose
Running: Linux 2.4.X|2.5.X|2.6.X
OS details: Linux 2.4.7 - 2.6.11, Linux 2.6.0 - 2.6.11
Uptime 33.908 days (since Thu Jul 21 03:38:03 2005)

Interesting ports on playground.nmap.org (192.168.0.40):
(The 1659 ports scanned but not shown below are in state: closed)
PORT     STATE SERVICE       VERSION
135/tcp  open  msrpc         Microsoft Windows RPC
139/tcp  open  netbios-ssn
389/tcp  open  ldap?
445/tcp  open  microsoft-ds  Microsoft Windows XP microsoft-ds
1002/tcp open  windows-icfw?
1025/tcp open  msrpc         Microsoft Windows RPC
1720/tcp open  H.323/Q.931   CompTek AquaGateKeeper
5800/tcp open  vnc-http      RealVNC 4.0 (Resolution 400x250; VNC TCP port: 5900)
5900/tcp open  vnc           VNC (protocol 3.8)
MAC Address: 00:A0:CC:63:85:4B (Lite-on Communications)
Device type: general purpose
Running: Microsoft Windows NT/2K/XP
OS details: Microsoft Windows XP Pro RC1+ through final release
Service Info: OSs: Windows, Windows XP

Nmap finished: 2 IP addresses (2 hosts up) scanned in 88.392 seconds
</screen>
      </example>

      <para>A versão mais nova do Nmap pode ser obtida em <ulink
      url="http://insecure.org/nmap/" />. A versão mais nova da página do
      manual está disponível em <ulink
      url="http://insecure.org/nmap/man/" />.</para>
    </refsect1>

    <refsect1 id="translation">
      <title>Notas da Tradução</title>

      <para>Esta edição em Português (Brasil) do Guia de Referência do Nmap
      foi traduzida da versão [3244] do <ulink
      url="http://insecure.org/nmap/man/">original em Inglês</ulink> por
      Lucien Raven :&gt; (aka:ekita)
      <email>lucienraven.at.yahoo.com.br</email> e foi revisada por Humberto
      Sartini <email>humberto.at.onda.com.br</email>. Embora tenhamos a
      esperança de que esta tradução torne o Nmap mais acessível para os
      brasileiros do mundo todo, não podemos garantir que ela esteja tão
      completa ou atualizada quanto a versão original em Inglês. Este trabalho
      pode ser modificado e redistribuído sob os termos da <ulink
      url="http://creativecommons.org/licenses/by/2.5/">Licença de Atribuição
      da Creative Commons</ulink>. Algumas liberdades foram tomadas na
      tradução de expressões, jargão e gíria. Para maiores detalhes sobre a
      tradução, sugestões ou críticas, envie um e-mail para os tradutores --
      não esqueça de substituir '.at.' por '@'. [Rev:3244-01]</para>
    </refsect1>

    <refsect1 id="man-briefoptions">
      <title>Sumário das Opções</title>

      <para>Este sumário de opções é mostrado quando o Nmap é executado sem
      argumentos, e a última versão está sempre disponível em <ulink
      url="http://insecure.org/nmap/data/nmap.usage.txt" />. Ele ajuda as
      pessoas a lembrar das opções mais comuns, mas não substitui a
      documentação mais técnica do restante deste manual. Algumas opções
      obscuras não estão incluídas aqui.</para>

      <para>
        <literallayout class="normal" format="linespecific">Usage: nmap [Scan Type(s)] [Options] {target specification}
TARGET SPECIFICATION:
  Can pass hostnames, IP addresses, networks, etc.
  Ex: scanme.nmap.org, microsoft.com/24, 192.168.0.1; 10.0-255.0-255.1-254
  -iL &lt;inputfilename&gt;: Input from list of hosts/networks
  -iR &lt;num hosts&gt;: Choose random targets
  --exclude &lt;host1[,host2][,host3],...&gt;: Exclude hosts/networks
  --excludefile &lt;exclude_file&gt;: Exclude list from file
HOST DISCOVERY:
  -sL: List Scan - simply list targets to scan
  -sP: Ping Scan - go no further than determining if host is online
  -P0: Treat all hosts as online -- skip host discovery
  -PS/PA/PU [portlist]: TCP SYN/ACK or UDP discovery probes to given ports
  -PE/PP/PM: ICMP echo, timestamp, and netmask request discovery probes
  -n/-R: Never do DNS resolution/Always resolve [default: sometimes resolve]
  --dns-servers &lt;serv1[,serv2],...&gt;: Specify custom DNS servers
  --system-dns: Use OS's DNS resolver
SCAN TECHNIQUES:
  -sS/sT/sA/sW/sM: TCP SYN/Connect()/ACK/Window/Maimon scans
  -sN/sF/sX: TCP Null, FIN, and Xmas scans
  --scanflags &lt;flags&gt;: Customize TCP scan flags
  -sI &lt;zombie host[:probeport]&gt;: Idlescan
  -sO: IP protocol scan
  -b &lt;ftp relay host&gt;: FTP bounce scan
PORT SPECIFICATION AND SCAN ORDER:
  -p &lt;port ranges&gt;: Only scan specified ports
    Ex: -p22; -p1-65535; -p U:53,111,137,T:21-25,80,139,8080
  -F: Fast - Scan only the ports listed in the nmap-services file)
  -r: Scan ports consecutively - don't randomize
SERVICE/VERSION DETECTION:
  -sV: Probe open ports to determine service/version info
  --version-intensity &lt;level&gt;: Set from 0 (light) to 9 (try all probes)
  --version-light: Limit to most likely probes (intensity 2)
  --version-all: Try every single probe (intensity 9)
  --version-trace: Show detailed version scan activity (for debugging)
OS DETECTION:
  -O: Enable OS detection (try 2nd generation, then 1st if that fails)
  -O1: Only use the old (1st generation) OS detection system
  -O2: Only use the new OS detection system (no fallback)
  --osscan-limit: Limit OS detection to promising targets
  --osscan-guess: Guess OS more aggressively
TIMING AND PERFORMANCE:
  Options which take &lt;time&gt; are in milliseconds, unless you append 's'
  (seconds), 'm' (minutes), or 'h' (hours) to the value (e.g. 30m).
  -T[0-5]: Set timing template (higher is faster)
  --min-hostgroup/max-hostgroup &lt;size&gt;: Parallel host scan group sizes
  --min-parallelism/max-parallelism &lt;time&gt;: Probe parallelization
  --min-rtt-timeout/max-rtt-timeout/initial-rtt-timeout &lt;time&gt;: Specifies
      probe round trip time.
  --max-retries &lt;tries&gt;: Caps number of port scan probe retransmissions.
  --host-timeout &lt;time&gt;: Give up on target after this long
  --scan-delay/--max-scan-delay &lt;time&gt;: Adjust delay between probes
FIREWALL/IDS EVASION AND SPOOFING:
  -f; --mtu &lt;val&gt;: fragment packets (optionally w/given MTU)
  -D &lt;decoy1,decoy2[,ME],...&gt;: Cloak a scan with decoys
  -S &lt;IP_Address&gt;: Spoof source address
  -e &lt;iface&gt;: Use specified interface
  -g/--source-port &lt;portnum&gt;: Use given port number
  --data-length &lt;num&gt;: Append random data to sent packets
  --ttl &lt;val&gt;: Set IP time-to-live field
  --spoof-mac &lt;mac address, prefix, or vendor name&gt;: Spoof your MAC address
OUTPUT:
  -oN/-oX/-oS/-oG &lt;file&gt;: Output scan results in normal, XML, s|&lt;rIpt kIddi3,
     and Grepable format, respectively, to the given filename.
  -oA &lt;basename&gt;: Output in the three major formats at once
  -v: Increase verbosity level (use twice for more effect)
  -d[level]: Set or increase debugging level (Up to 9 is meaningful)
  --packet-trace: Show all packets sent and received
  --iflist: Print host interfaces and routes (for debugging)
  --log-errors: Log errors/warnings to the normal-format output file
  --append-output: Append to rather than clobber specified output files
  --resume &lt;filename&gt;: Resume an aborted scan
  --stylesheet &lt;path/URL&gt;: XSL stylesheet to transform XML output to HTML
  --webxml: Reference stylesheet from Insecure.Org for more portable XML
  --no-stylesheet: Prevent associating of XSL stylesheet w/XML output
MISC:
  -6: Enable IPv6 scanning
  -A: Enables OS detection and Version detection
  --datadir &lt;dirname&gt;: Specify custom Nmap data file location
  --send-eth/--send-ip: Send using raw ethernet frames or IP packets
  --privileged: Assume that the user is fully privileged
  -V: Print version number
  -h: Print this help summary page.
EXAMPLES:
  nmap -v -A scanme.nmap.org
  nmap -v -sP 192.168.0.0/16 10.0.0.0/8
  nmap -v -iR 10000 -P0 -p 80
</literallayout>
      </para>
    </refsect1>

    <refsect1 id="man-target-specification">
      <title>Especificação de Alvo</title>

      <para>Tudo na linha de comando do Nmap que não for uma opção (ou
      argumento de uma opção) é tratado como uma especificação de um
      host-alvo. O caso mais simples é especificar um endereço IP como alvo ou
      um hostname para ser escaneado.</para>

      <para>Algumas vezes você pode querer escanear uma rede inteira de hosts
      adjacentes. Para isso o Nmap suporta o estilo de endereçamento CIDR.
      Você pode acrescentar <indexterm significance="normal">
          <primary>endereçamentoCIDR</primary>
        </indexterm> /<replaceable>númerodebits</replaceable> em um endereço
      ou hostname e o Nmap irá escanear cada endereço IP para o qual os
      primeiros <replaceable>númerosdebits</replaceable> sejam o mesmo que o
      IP de referência ou o hostname dado. Por exemplo, 192.168.10.0/24
      escanearia os 256 hosts entre 192.168.10.0 (binário: <literal>11000000
      10101000 00001010 00000000</literal>) e 192.168.10.255 (binário:
      <literal>11000000 10101000 00001010 11111111</literal>), inclusive.
      192.168.10.40/24 faria exatamente a mesma coisa. Dado que o host
      scanme.nmap.org está no endereço IP 205.217.153.62, a especificação
      scanme.nmap.org/16 escanearia os 65.536 endereços IP entre 205.217.0.0 e
      205.217.255.255. O menor valor permitido é /1, que equivale a escanear
      metade da Internet. O maior valor é 32, que escaneia apenas o host
      nomeado ou endereço IP porque todos os bits de endereçamento estão
      fixos.</para>

      <para>A notação CIDR é curta mas nem sempre flexível o suficiente. Por
      exemplo, você pode querer escanear 192.168.0.0/16 mas desejar pular
      todos os IPs terminados em .0 ou .255 porque eles são normalmente
      endereços de broadcast. O Nmap suporta isso através de endereçamento por
      faixa de octeto. Ao invés de especificar um endereço IP normal, você
      pode especificar uma lista de números separada por vírgulas ou faixa de
      números para cada octeto. Por exemplo, 192.168.0-255.1-254 irá pular
      todos os endereços na faixa que terminarem com .0 e/ou .255. Faixas não
      precisam ser limitadas ao octeto final: o especificador
      0-255.0-255.13.37 irá executar um scan em toda a Internet buscando os
      endereços IP terminados em 13.37. Esse tipo de amostragem ampla pode ser
      útil em levantamentos e pesquisas da Internet toda.</para>

      <para>Endereços IPv6 podem apenas ser especificados utilizando o
      endereço ou hostname IPv6 completamente qualificado. Faixas CIDR e
      octetos não são suportados para o IPv6 porque eles raramente são
      úteis.</para>

      <para>O Nmap aceita múltiplas especificações de host na linha de
      comando, e elas não precisam ser do mesmo tipo. O comando <command
      moreinfo="none">nmap scanme.nmap.org 192.168.0.0/16
      10.0.0,1,3-7.0-255</command> executa o que se espera que dele.</para>

      <para>Embora os alvos sejam normalmente especificados na linha de
      comando, as seguintes opções também estão disponíveis para controlar a
      seleção de alvos:</para>

      <variablelist>
        <varlistentry>
          <term><option>-iL &lt;arquivodeentrada&gt;</option> (Entrada à
          partir de uma lista)</term>

          <listitem>
            <indexterm significance="normal">
              <primary>-iL</primary>
            </indexterm>

            <para>Lê a especificação de alvos à partir de um
            <replaceable>arquivodeentrada</replaceable>. Passar uma lista
            enorme de hosts na linha de comando é muito ruim, ainda que seja
            comumente desejável. Por exemplo, seu servidor DHCP pode exportar
            uma lista de 10.000 endereços correntes em uso que você deseja
            escanear. Ou talvez você deseje escanear todos os endereços IP
            <emphasis>exceto</emphasis> aqueles usados para localizar hosts
            que usam endereços IP estáticos não-autorizados. Simplesmente gere
            uma lista de hosts a escanear e passe o nome do arquivo para o
            Nmap como um argumento à opção <option>-iL</option>. As entradas
            podem estar em qualquer um dos formatos aceitos pelo Nmap na linha
            de comando (endereço IP, hostname, CIDR, IPv6, ou faixas de
            octetos). Cada entrada deve ser separada por um ou mais espaços em
            branco, tabulações ou quebra de linhas. Você pode especificar um
            hífen (<literal>-</literal>) como nome de arquivo se quiser que o
            Nmap leia os nomes de hosts da entrada padrão (standard input) ao
            invés de um arquivo.</para>
          </listitem>
        </varlistentry>

        <varlistentry>
          <term><option>-iR &lt;número de hosts&gt;</option> (Escolhe alvos
          aleatórios)</term>

          <listitem>
            <indexterm significance="normal">
              <primary>-iR</primary>
            </indexterm>

            <para>Para levantamentos na Internet toda e outras pesquisas, você
            pode querer escolher alvos de forma aleatória. O argumento
            <replaceable>número de hosts</replaceable> diz ao Nmap quantos IPs
            ele deverá gerar. IPs indesejáveis, tais como aqueles de certas
            redes privativas, multicast e faixas de endereços não-alocadas são
            automaticamente desconsideradas. O argumento <literal>0</literal>
            (zero) pode ser especificado caso deseje um scan sem fim. Tenha em
            mente que alguns administradores de rede "torcem o nariz" para
            scans não-autorizados de suas redes e podem reclamar. Use esta
            opção por sua conta e risco! Se você estiver realmente entediado
            em uma tarde chuvosa, tente o comando <command>nmap -sS -PS80 -iR
            0 -p 80</command> para localizar servidores web aleatórios para
            navegar.</para>
          </listitem>
        </varlistentry>

        <varlistentry>
          <term><option>--exclude &lt;host1[,host2][,host3],...&gt;</option>
          (Exclui hosts/redes)</term>

          <listitem>
            <indexterm significance="normal">
              <primary>--exclude</primary>
            </indexterm>

            <para>Especifica uma lista de alvos, separados por vírgula, a
            serem excluídos do scan mesmo que façam parte da faixa de rede
            especificada. A lista que você fornece utiliza a sintaxe normal do
            Nmap, portanto ela pode incluir nomes de hosts, blocos de rede
            CIDR, faixas de octetos, etc. Isso pode ser útil quando a rede que
            você deseja escanear inclui servidores de missão crítica
            intocáveis, sistemas que reajam contrariamente a escaneamento de
            portas ou sub-redes administradas por outras pessoas.</para>
          </listitem>
        </varlistentry>

        <varlistentry>
          <term><option>--excludefile &lt;arquivo_exclusão&gt;</option>
          (Exclui a lista do arquivo)</term>

          <listitem>
            <indexterm significance="normal">
              <primary>--excludefile</primary>
            </indexterm>

            <para>Oferece a mesma funcionalidade que a opção
            <option>--exclude</option>, exceto que os alvos a excluir são
            fornecidos em um <replaceable>"arquivo separado"</replaceable> ,
            delimitados por quebra de linhas, espaço em branco ou tabulação,
            ao invés de na linha de comando.</para>
          </listitem>
        </varlistentry>
      </variablelist>
    </refsect1>

    <refsect1 id="man-host-discovery">
      <title>Descoberta de Hosts</title>

      <para>Um dos primeiros passos em qualquer missão de reconhecimento de
      uma rede é reduzir um conjunto (às vezes enorme) de faixas de endereços
      IP, em uma lista de hosts ativos e interessantes. Escanear cada porta de
      cada endereço IP é vagaroso e normalmente desnecessário. É claro que o
      que torna um host interessante depende muito do propósito do scan.
      Administradores de rede podem estar apenas interessados em hosts que
      executam um determinado serviço, enquanto os auditores de segurança
      podem se importar com cada dispositivo que possuir um endereço IP. Um
      administrador pode se sentir à vontade em usar o ping ICMP para
      localizar os hosts na rede interna, enquanto um profissional externo de
      análise de vulnerabilidades (penetration tester) pode utilizar um
      conjunto diversificado de dezenas de sondagens em uma tentativa de
      burlar as restrições do firewall.</para>

      <para>As necessidades para o descobrimento de host são muito diversas e,
      por isso, o Nmap oferece uma ampla variedade de opções para customizar
      as técnicas utilizadas. A descoberta de host às vezes é chamada de ping
      scan, mas ela vai muito além dos simples pacotes ICMP de echo request
      associados com a ferramenta onipresente conhecida como ping. Os usuários
      podem pular a etapa do ping inteiramente com uma lista de scan
      (<option>-sL</option>) ou desabilitanto o ping (<option>-P0</option>),
      ou enfrentar a rede com combinações arbitrárias de sondagens
      multi-portas TCP SYN/ACK, UDP e ICMP. O objetivo dessas sondagens é
      solicitar respostas que mostrem que um endereço IP está realmente ativo
      (é utilizado por um host ou dispositivo de rede). Em muitas redes,
      apenas uma pequena percentagem dos endereços IP está ativa em um dado
      momento. Isso é particularmente comum com o espaço de endereçamento
      privativo abençoado pela RFC1918 como, por exemplo, 10.0.0.0/8. Essa
      rede tem 16 milhões de IPs, mas eu já a vi sendo utilizado em empresas
      com menos de mil máquinas. A descoberta de hosts pode encontrar essas
      máquinas escassamente alocadas em um mar de endereços IP.</para>

      <para>Se nenhuma opção de descoberta de hosts for dada, o Nmap envia um
      pacote TCP ACK destinado a porta 80 e uma procura ICMP Echo Request a
      cada máquina-alvo. Uma exceção a isso é que um scan ARP é utilizado para
      cada alvo localizado na rede ethernet local. Para usuários Unix sem
      privilégios, com shell, um pacote SYN é enviado ao invés do ack
      utilizando a chamada de sistema <function>connect()</function>. Esses
      valores padrão equivalem às opções <option>-PA -PE</option>. Esta
      descoberta de host freqüentemente é suficiente para escanear redes
      locais, mas um conjunto de sondagens mais abrangentes é recomendado para
      auditoria de segurança.</para>

      <para>As opções <option>-P*</option> (que selecionam tipos de ping)
      podem ser combinadas. Você pode aumentar as chances de penetrar em um
      firewall rígido enviando muitos tipos de sondagens, utilizando
      diferentes portas/flags TCP e códigos ICMP. Note também que a descoberta
      por ARP (<option>-PR</option>) é feita por padrão contra alvos na rede
      ethernet local mesmo que você especifique outras opções
      <option>-P*</option> , porque é quase sempre mais rápida e
      eficiente.</para>

      <para />

      <para>Por definição, o Nmap faz a descoberta de host e então executa um
      escaneamento de portas contra cada host que ele determina que está
      ativo. Isto é verdade mesmo que você especifique tipos de busca
      não-padronizadas de hosts, tais como sondagens UDP
      (<option>-PU</option>). Leia sobre a opção <option>-sP</option> para
      saber como executar <emphasis>apenas</emphasis> uma descoberta de hosts,
      ou utilize <option>-P0</option> para pular a descoberta de hosts e
      escanear as portas de todos os hosts-alvo. As seguintes opções controlam
      a descoberta de hosts:</para>

      <variablelist>
        <varlistentry>
          <term><option>-sL</option> (Scan Listagem)</term>

          <listitem>
            <indexterm significance="normal">
              <primary>-sL</primary>
            </indexterm>

            <indexterm significance="normal">
              <primary>Scan Listagem</primary>
            </indexterm>

            <para>O scan listagem é uma forma degenerada de descoberta de
            hosts que simplesmente lista cada host da rede especificada, sem
            enviar nenhum pacote aos hosts-alvos. Por padrão o Nmap fará a
            resolução de DNS reverso dos hosts para descobrir seus nomes.
            Ainda é surpreendente a quantidade de informações úteis que
            simples nomes de hosts podem dar. Por exemplo,
            <literal>fw.chi.playboy.com</literal> é o firewall do escritório
            de Chicago da Playboy Enterprises. Nmap também reporta o número
            total de endereços IP ao final. O scan listagem é um bom teste de
            sanidade para assegurar que você está com a lista correta de
            endereços IP dos seus alvos. Se os hosts mostrarem nomes de
            domínios que você não reconhece, vale a pena investigar melhor
            para evitar scanear a rede da empresa errada.</para>

            <para>Uma vez que a idéia é apenas mostrar uma lista dos
            hosts-alvos, as opções de funcionalidade de nível mais alto tais
            como scan de portas, detecção de SO, ou scan utilizando ping, não
            podem ser combinadas com esta opção. Se você deseja desabilitar o
            scan utilizando ping enquanto executa funções de nível elevado,
            leia a opção <option>-P0</option>.</para>
          </listitem>
        </varlistentry>

        <varlistentry>
          <term><option>-sP</option> (Scan usando Ping)</term>

          <listitem>
            <para>Esta opção diz ao Nmap para <emphasis>somente</emphasis>
            <indexterm significance="normal">
                <primary>-sP</primary>
              </indexterm> <indexterm significance="normal">
                <primary>Scan usando Ping</primary>
              </indexterm> executar um scan usando o ping (descoberta de
            hosts), e então mostrar os hosts disponíveis que responderam ao
            scan. Nenhum teste adicional (tais como escaneamento de portas e
            deteção de SO) é executado. Isto é um pouco mais intrusivo que o
            scan listagem, e pode ser usado para os mesmos propósitos. Permite
            um reconhecimento leve de uma rede-alvo sem chamar muita atenção.
            Saber quantos hosts estão ativos é mais valioso para invasores que
            a lista fornecida pelo scan listagem com cada endereço IP e seu
            nome de host.</para>

            <para>Administradores de sistemas frequentemente acham esta opção
            valiosa. Ela pode ser facilmente utilizada para contar o número de
            máquinas disponíveis em uma rede ou monitorar a disponibilidade
            dos servidores. Isto é normalmente chamado de varredura com ping
            (ping sweep), e é mais confiável do que fazer um ping em um
            endereço de broadcast, pois muitos hosts não respondem a pesquisas
            com broadcast.</para>

            <para>A opção <option>-sP</option> envia um ICMP echo request e um
            pacote TCP para a porta 80 por padrão. Quando executada por um
            usuário sem privilégios, um pacote SYN é enviado (usando uma
            chamada <function>connect()</function>) para a porta 80 no alvo.
            Quando um usuário privilegiado tenta escanear alvos na rede
            ethernet local, requisições ARP (<option>-PR</option>) são
            utilizadas, a menos que <option>--send-ip</option> tenha sido
            especificado. A opção <option>-sP</option> pode ser combinada com
            qualquer um dos tipos de sondagens de descobrimento (as opções
            <option>-P*</option> , excluindo <option>-P0</option>) para maior
            flexibilidade. Se qualquer uma dessas opções de tipos de sondagens
            e número de porta for utilizada, as sondagens padrão (ACK e echo
            request) são sobrepostas. Quando firewalls restritivos estão
            posicionados entre o host de origem que executa o Nmap e a
            rede-alvo, utilizar essas técnicas avançadas é recomendado. Do
            contrário, hosts podem ser perdidos quando o firewall ignorar as
            sondagens ou as respostas delas.</para>
          </listitem>
        </varlistentry>

        <varlistentry>
          <term><option>-P0</option> (Sem ping)</term>

          <listitem>
            <indexterm significance="normal">
              <primary>-P0</primary>
            </indexterm>

            <para>Esta opção pula completamente o estágio de descoberta do
            Nmap. Normalmente o Nmap utiliza este estágio para determinar as
            máquinas ativas para escaneamento mais agressivo. Por padrão, o
            Nmap apenas executa sondagens agressivas tais como escaneamento de
            portas, detecção de versões, ou detecções do SO contra hosts que
            foram verificados como ativos. Desabilitar a descoberta de hosts
            com <option>-P0</option> faz com que o Nmap teste as funções de
            escaneamento solicitadas contra <emphasis>todos</emphasis> os
            endereços IP alvos especificados. Portanto se um espaço de
            endereçamento alvo do tamanho de uma classe B (/16) for
            especificado na linha de comando, todos os 65.536 endereços IP
            serão escaneados. O segundo caracter da opção <option>-P0</option>
            é um zero e não a letra O. A descoberta de hosts apropriada é
            desconsiderada como no scan listagem, mas ao invés de parar e
            mostrar a lista de alvos, o Nmap continua a executar as funções
            solicitadas como se cada alvo IP estivesse ativo.</para>
          </listitem>
        </varlistentry>

        <varlistentry>
          <term><option>-PS [listadeportas]</option> (Ping usando TCP
          SYN)</term>

          <listitem>
            <indexterm significance="normal">
              <primary>-PS</primary>
            </indexterm>

            <indexterm significance="normal">
              <primary>Ping usando TCP SYN</primary>
            </indexterm>

            <para>Esta opção envia um pacote TCP vazio com a flag SYN marcada.
            A porta de destino padrão é a 80 (configurada em tempo de
            compilação pela variável DEFAULT_TCP_PROBE_PORT no
            <filename>nmap.h</filename>), mas uma porta alternativa pode ser
            especificada como um parâmetro. Até uma lista de portas separadas
            por vírgula pode ser especificada (p.ex.
            <option>-PS22,23,25,80,113,1050,35000</option>), nesse caso as
            sondagens serão tentadas contra cada porta em paralelo.</para>

            <para>A flag SYN sugere aos sistemas remotos que você está
            tentando estabelecer uma comunicação. Normalmente a porta de
            destino estará fechada e um pacote RST (reset) será enviado de
            volta. Se acontecer de a porta estar aberta, o alvo irá dar o
            segundo passo do cumprimento-de-três-vias (3-way-handshake) do TCP
            respondendo com um pacote TCP SYN/ACK TCP. A máquina executando o
            Nmap então derruba a conexão recém-nascida respondendo com um RST
            ao invés de enviar um pacote ACK que iria completar o
            cumprimento-de-três-vias e estabelecer uma conexão completa. O
            pacote RST é enviado pelo kernel da máquina que está executando o
            Nmap em resposta ao SYN/ACK inesperado, e não pelo próprio
            Nmap.</para>

            <para>O Nmap não se importa se a porta está aberta ou fechada.
            Tanto a resposta RST ou SYN/ACK discutidas anteriormente dizem ao
            Nmap se o hosts está disponível e responsivo.</para>

            <para>Em caixas UNIX, apenas o usuário privilegiado
            <literal>root</literal> é capaz, normalmente, de enviar e receber
            pacotes TCP em estado bruto. Para usuários não privilegiados um
            contorno é automaticamente empregado em concordância com a chamada
            de sistema connect() iniciada contra cada porta-alvo. Isso tem o
            efeito de enviar um pacote SYN ao host alvo, em uma tentativa de
            se estabelecer uma conexão. Se o connect() retornar com sucesso
            rápido ou com uma falha ECONNREFUSED, a pilha TCP subjacente deve
            ter recebido um SYN/ACK ou RST e o host é marcado como disponível.
            Se a tentativa de conexão for deixada largada até que um timeout
            ocorra, o host é marcado como indisponível. Esse contorno também é
            usado para conexões IPv6, pois o suporte a construção de pacotes
            IPv6 em estado bruto ainda não está disponível no Nmap.</para>
          </listitem>
        </varlistentry>

        <varlistentry>
          <term><option>-PA [listadeportas]</option> (Ping usando TCP
          ACK)</term>

          <listitem>
            <indexterm significance="normal">
              <primary>-PA</primary>
            </indexterm>

            <indexterm significance="normal">
              <primary>Ping usando TCP ACK</primary>
            </indexterm>

            <para>O ping usando TCP ACK é muito similar ao recém-discutido
            ping usando SYN. A diferença, como você poderia imaginar, é que a
            flag TCP ACK é marcada ou invés da flag SYN. Tal pacote ACK finge
            reconhecer dados de uma conexão TCP estabelecida, quando nenhuma
            conexão existe de fato. Então os hosts remotos deveriam sempre
            responder com pacotes RST, revelando sua existência no
            processo.</para>

            <para>A opção <option>-PA</option> utiliza a mesma porta padrão
            que a sondagem SYN (80) e pode também obter uma lista de portas
            destino no mesmo formato. Se um usuário privilegiado tenta isto,
            ou se um alvo IPv6 é especificado, o contorno connect() discutido
            anteriormente é utilizado. Esse contorno é imperfeito pois o
            connect() está realmente enviando um pacote SYN ao invés de um
            ACK.</para>

            <para>O motivo para oferecer ambas as sondagens ping, que utilizam
            SYN e ACK, é maximizar as chances de passar por firewalls. Muitos
            administradores configuram roteadores e outros firwalls simples
            para bloquear pacotes SYN entrantes exceto aqueles destinados a
            serviços públicos como o site web da empresa ou servidor de
            correio eletrônico. Isso evita as demais conexões entrantes na
            organização, permitindo aos usuários fazer conexões desobstruidas
            à Internet. Essa aproximação não-orientada à conexão (non-stateful
            ou stateless) consome uns poucos recursos no firewall/roteador e é
            amplamente suportada por filtros de hardware e software. O
            firewall de software Netfilter/iptables do Linux oferece a
            conveniência da opção <option>--syn</option> para implementar essa
            abordagem stateless. Quando regras stateless do firewall tais como
            essas são implementadas, sondagens de ping usando SYN
            (<option>-PS</option>) muito provavelmente serão bloqueadas quando
            forem enviadas à portas fechadas. Em tais casos, a sondagem ACK se
            destaca pois ela simplesmente passa por essas regras.</para>

            <para>Outro tipo comum de firewall utiliza regras orientadas a
            conexão que descartam pacotes inesperados. Esta característica era
            encontrada inicialmente apenas em firewalls de alto-nível, embora
            tenha se tornado mais comum com o passar dos anos. O sistema
            Netfilter/iptables do Linux suporta esta característica através da
            opção <option>--state</option>, que categoriza os pacotes baseados
            no estado da conexão. Uma sondagem SYN tem maiores chances de
            funcionar contra um sistema assim, pois pacotes ACK inesperados
            são normalmente reconhecidos como falsos e descartados. Uma
            solução para esse dilema é enviar ambas as sondagens SYN e ACK
            especificando <option>-PS</option> e <option>-PA</option>.</para>
          </listitem>
        </varlistentry>

        <varlistentry>
          <term><option>-PU [listadeportas]</option> (Ping usando UDP)</term>

          <listitem>
            <indexterm significance="normal">
              <primary>-PU</primary>
            </indexterm>

            <indexterm significance="normal">
              <primary>Ping usando UDP</primary>
            </indexterm>

            <para>Outra opção de descoberta de hosts é o ping usando UDP, que
            envia um pacote UDP vazio (a menos que
            <option>--data-length</option> seja especificado) para as portas
            informadas. O argumento "listadeportas" tem o mesmo formato que os
            discutidos anteriormente nas opções <option>-PS</option> e
            <option>-PA</option>. Se nenhuma porta for especificada, o padrão
            é 31338. Esse padrão pode ser configurado em tempo de compilação
            alterando DEFAULT_UDP_PROBE_PORT no <filename>nmap.h</filename>.
            Uma porta alta incomum é utilizada como padrão porque enviar para
            portas abertas normalmente é indesejado para este tipo particular
            de scan.</para>

            <para>Ao bater contra uma porta fechada na máquina-alvo, a
            sondagem UDP deve causar um pacote ICMP de porta inalcançável como
            resposta. Isso diz ao Nmap que a máquina está ativa e disponível.
            Muitos outros tipos de erros ICMP, tais como host/rede
            inalcançável ou TTL excedido são indicativos de um host inativo ou
            inalcançável. A falta de resposta também é interpretada dessa
            forma. Se uma porta aberta é alcançada, a maioria dos serviços
            simplesmente ignoram o pacote vazio e falham em retornar qualquer
            resposta. É por isso que a porta de sondagem padrão é 31338, que
            pouco provavelmente estará em uso. Uns poucos serviços, tal como o
            chargen, irá responder a um pacote UDP vazio, e com isso revelará
            ao Nmap que a máquina está disponível.</para>

            <para>A principal vantagem deste tipo de scan é que ele passa por
            firewalls e filtros que apenas examinam o TCP. Por exemplo, uma
            vez eu tive um roteador broadband sem-fio Linksys BEFW11S4. A
            interface externa desse dispositivo filtrava todas as portas TCP
            por padrão, mas as sondagens UDP ainda causavam mensagens de porta
            inalcançável, entregando assim o dispositivo.</para>
          </listitem>
        </varlistentry>

        <varlistentry>
          <term><option>-PE</option>; <option>-PP</option>;
          <option>-PM</option> (Tipos de Ping do ICMP)</term>

          <listitem>
            <indexterm significance="normal">
              <primary>-PE</primary>
            </indexterm>

            <indexterm significance="normal">
              <primary>-PP</primary>
            </indexterm>

            <indexterm significance="normal">
              <primary>-PM</primary>
            </indexterm>

            <indexterm significance="normal">
              <primary>ICMP ping</primary>
            </indexterm>

            <para>Além dos tipos incomuns de descoberta de hosts TCP e UDP
            discutidos anteriormente, o Nmap pode enviar os pacotes-padrão que
            normalmente são enviados pelo onipresente programa ping. O Nmap
            envia um pacote ICMP do tipo 8 (echo request) ao endereço IP alvo,
            esperando como resposta um tipo 0 (Echo Reply) do host disponível.
            Infelizmente para muitos exploradores de rede, muitos hosts e
            firewalls atualmente bloqueiam esses pacotes, ao invés de
            responder como é requerido pela <ulink
            url="http://www.rfc-editor.org/rfc/rfc1122.txt">RFC 1122</ulink>.
            Por essa razão, scans puramente ICMP são raramente confiáveis o
            suficiente contra alvos desconhecidos na Internet. Mas para
            administradores de sistemas monitorando uma rede interna eles
            podem ser uma abordagem prática e eficiente. Utilize a opção
            <option>-PE</option> para ativar esse comportamento echo
            request.</para>

            <para>Embora o echo request seja a pesquisa padrão de um ping
            ICMP, o Nmap não pára aqui. A padronização do ICMP (<ulink
            url="http://www.rfc-editor.org/rfc/rfc792.txt">RFC 792</ulink>)
            também especifica timestamp request, information request, e
            pacotes address mask request como códigos 13, 15, e 17,
            respectivamente. Apesar do propósito ostensivo dessas pesquisas
            seja obter informações tais como a máscara do endereço e hora
            corrente, eles podem ser facilmente utilizados para descoberta de
            hosts. Um sistema que responda está ativo e disponível. O Nmap não
            implementa atualmente os pacotes de requisição de informações,
            pois eles não são amplamente suportados. A RFC 1122 insiste que
            <quote>um host NÃO DEVERIA implementar essas mensagens</quote>.
            Pesquisas de marcação de hora (Timestamp) e máscara de endereço
            podem ser enviadas com as opções <option>-PP</option> e
            <option>-PM</option> , respectivamente. Uma resposta timestamp
            reply (código ICMP 14) ou uma resposta address mask reply (código
            18) revela que o host está disponível. Essas duas pesquisas podem
            ser valiosas quando os administradores bloqueiam pacotes echo
            request especificamente e esquecem que outras pesquisas ICMP podem
            ser usadas com o mesmo propósito.</para>
          </listitem>
        </varlistentry>

        <varlistentry>
          <term><option>-PR</option> (Ping usando ARP)</term>

          <listitem>
            <indexterm significance="normal">
              <primary>-PR</primary>
            </indexterm>

            <indexterm significance="normal">
              <primary>Ping usando ARP</primary>
            </indexterm>

            <para>Um dos cenários de uso mais comuns do Nmap é escanear a LAN
            ethernet. Na maioria das LANs, especialmente aquelas que utilizam
            a faixa de endereçamento privativo abençoado pela RFC1918, a vasta
            maioria dos endereços IP não são utilizados nunca. Quando o Nmap
            tenta enviar um pacote IP em estado bruto, tal como um ICMP echo
            request, o sistema operacional deve determinar o endereço físico
            de destino (ARP) correspondente ao IP-alvo de forma que ele possa
            endereçar adequadamente o frame ethernet. Isso normalmente é lento
            e problemático, pois os sistemas operacionais não foram escritos
            com a expectativa de que precisariam fazer milhões de requisições
            ARP contra hosts indisponíveis em um curto período de
            tempo.</para>

            <para>O scan ARP encarrega o Nmap e seus algoritmos otimizados de
            fazer as requisições ARP. E se ele conseguir uma resposta de
            volta, o Nmap não precisa nem se preocupar com os pacotes ping
            baseados em IP, uma vez que ele já sabe que o host está ativo.
            Isso torna o scan ARP muito mais rápido e mais confiável que os
            scans baseados em IP. Portanto isso é feito por padrão quando se
            escaneia hosts ethernet que o Nmap detecta estarem posicionados em
            uma rede ethernet local. Mesmo se tipos diferentes de ping (tais
            como <option>-PI</option> ou <option>-PS</option>) seja
            especificados, o Nmap usa o ARP no lugar para cada um dos alvos
            que estiverem na mesma LAN. Se você não quiser de forma nenhuma
            fazer um scan ARP, especifique <option>--send-ip</option>.</para>
          </listitem>
        </varlistentry>

        <varlistentry>
          <term><option>-n</option> (Não faça resolução DNS)</term>

          <listitem>
            <indexterm significance="normal">
              <primary>-n</primary>
            </indexterm>

            <para>Diz ao Nmap para <emphasis>nunca</emphasis> fazer uma
            resolução DNS reversa nos endereços IP ativos que ele encontrar.
            Uma vez que o DNS é normalmente lento, isso acelera as
            coisas.</para>
          </listitem>
        </varlistentry>

        <varlistentry>
          <term><option>-R</option> (resolução DNS para todos os alvos)</term>

          <listitem>
            <indexterm significance="normal">
              <primary>-R</primary>
            </indexterm>

            <para>Diz ao Nmap para <emphasis>sempre</emphasis> fazer uma
            resolução DNS reversa nos endereços IP-alvos. Normalmente isto
            apenas é executado quando uma máquina está ativa.</para>
          </listitem>
        </varlistentry>

        <varlistentry>
          <term><option>--system-dns</option> (Usa a resolução DNS do
          sistema)</term>

          <listitem>
            <indexterm significance="normal">
              <primary>--system-dns</primary>
            </indexterm>

            <para>Por padrão, o Nmap resolve o endereço IP através do envio de
            pesquisas (queries) diretamente aos servidores de nome
            configurados em seu host, e então escuta as respostas. Muitas das
            pesquisas (dezenas) são executadas em paralalo para um melhor
            desempenho. Especifique esta opção se desejar utilizar a resolução
            DNS do seu sistema (um endereço IP por vez, através da chamada
            getnameinfo()). Isto é mais lente e raramente útil, a não ser que
            haja um bug no código de DNS do Nmap -- por favor, entre em
            contato conosco se for o caso. A resolução DNS do sistema é sempre
            usada em escaneamento IPv6.</para>
          </listitem>
        </varlistentry>

        <varlistentry>
          <term><option>--dns-servers &lt;servidor1[,servidor2],...&gt;
          </option> (Servidores a utilizar para a pesquisa DNS reversa)</term>

          <listitem>
            <indexterm significance="normal">
              <primary>--dns-servers</primary>
            </indexterm>

            <para>Por padrão o Nmap irá tentar determinar os seus servidores
            DNS (para a resolução DNS reversa) através do arquivo resolv.conf
            (UNIX) ou do registry (Win32). Opcionalmente você pode usar esta
            opção para especificar servidores alternativos. Esta opção não é
            honrada se você estiver usando <option>--system-dns</option> ou um
            escaneamento IPv6. Utilizar múltiplos servidores DNS é,
            normalmente, mais rápido e mais furtivo do que pesquisar apenas em
            um servidor. O melhor desempenho é frequentemente obtido
            especificando-se todos os servidores que tem autoridade sobre a
            faixa de endereços IP.</para>
          </listitem>
        </varlistentry>
      </variablelist>
    </refsect1>

    <refsect1 id="man-port-scanning-basics">
      <title>Fundamentos do Escaneamento de Portas</title>

      <para>Embora o Nmap tenha crescido em funcionalidade ao longo dos anos,
      ele começou como um eficiente scanner de portas, e essa permanece sua
      função principal. O simples comando <command>nmap
      <replaceable>alvo</replaceable></command> escaneia mais de 1660 portas
      TCP no host <replaceable>alvo</replaceable>. Embora muitos scanner de
      portas tenham tradicionalmente agrupado todas as portas nos estados
      aberto ou fechado, o Nmap é muito mais granular. Ele divide as portas em
      seis estados: <literal>aberto(open)</literal>,
      <literal>fechado(closed)</literal>,<literal>filtrado(filtered)</literal>,
      <literal>não-filtrado(unfiltered)</literal>,
      <literal>open|filtered</literal>, ou
      <literal>closed|filtered</literal>.</para>

      <para>Esses estados não são propriedades intrínsecas da porta, mas
      descrevem como o Nmap as vê. Por exemplo, um scan do Nmap da mesma rede
      como alvo pode mostrar a porta 135/tcp como aberta, enquanto um scan ao
      mesmo tempo com as mesmas opções, à partir da Internet poderia mostrar
      essa porta como <literal>filtrada</literal>.</para>

      <variablelist>
        <title>Os seis estados de porta reconhecidos pelo Nmap</title>

        <varlistentry>
          <term>aberto (open)</term>

          <listitem>
            <para>Uma aplicação está ativamente aceitando conexões TCP ou
            pacotes UDP nesta porta. Encontrar esse estado é freqüentemente o
            objetivo principal de um escaneamento de portas. Pessoas
            conscientes sobre a segurança sabem que cada porta aberta é um
            convite para um ataque. Invasores e profissionais de avaliação de
            segurança querem explorar as portas abertas, enquanto os
            administradores tentam fechar ou proteger com firewalls sem
            bloquear usuários legítimos. Portas abertas são também
            interessantes para scans não-relacionados à segurança pois mostram
            os serviços disponíveis para utilização na rede.</para>
          </listitem>
        </varlistentry>

        <varlistentry>
          <term>fechado (closed)</term>

          <listitem>
            <para>Uma porta fechada está acessível (ela recebe e responde a
            pacotes de sondagens do Nmap), mas não há nenhuma aplicação
            ouvindo nela. Elas podem ser úteis para mostrar que um host está
            ativo em um determinado endereço IP (descoberta de hosts, ou scan
            usando ping), e como parte de uma deteção de SO. Pelo fato de
            portas fechadas serem alcançáveis, pode valer a pena escanear mais
            tarde no caso de alguma delas abrir. Os administradores deveriam
            considerar o bloqueio dessas portas com um firewall. Então elas
            apareceriam no estado filtrado, discutido a seguir.</para>
          </listitem>
        </varlistentry>

        <varlistentry>
          <term>filtrado (filtered)</term>

          <listitem>
            <para>O Nmap não consegue determinar se a porta está aberta porque
            uma filtragem de pacotes impede que as sondagens alcancem a porta.
            A filtragem poderia ser de um dispositivo firewall dedicado,
            regras de roteador, ou um software de firewall baseado em host.
            Essas portas frustram os atacantes pois elas fornecem poucas
            informações. às vezes elas respondem com mensagens de erro ICMP
            tais como as do tipo 3 código 13 (destino inalcançável:
            comunicação proibida administrativamente), mas os filtros que
            simplesmente descartam pacotes sem responder são bem mais comuns.
            Isso força o Nmap a tentar diversas vezes só para o caso de a
            sondagem ter sido descartada por congestionamento da rede ao invés
            de filtragem. Isso reduz a velocidade do scan
            dramaticamente.</para>
          </listitem>
        </varlistentry>

        <varlistentry>
          <term>não-filtrado (unfiltered)</term>

          <listitem>
            <para>O estado não-filtrado significa que uma porta está
            acessível, mas que o Nmap é incapaz de determinar se ela está
            aberta ou fechada. Apenas o scan ACK, que é usado para mapear
            conjuntos de regras de firewall, classifica portas com este
            estado. Escanear portas não-filtradas com outros tipos de scan,
            tal como scan Window, scan Syn, ou scan FIN, podem ajudar a
            responder se a porta está aberta.</para>
          </listitem>
        </varlistentry>

        <varlistentry>
          <term>open|filtered</term>

          <listitem>
            <para>O Nmap coloca portas neste estado quando é incapaz de
            determinar se uma porta está aberta ou filtrada. Isso acontece
            para tipos de scan onde as portas abertas não dão nenhuma
            resposta. A falta de resposta também pode significar que um filtro
            de pacotes descartou a sondagem ou qualquer resposta que ela tenha
            provocado. Portanto não sabe-se com certeza se a porta está aberta
            ou se está sendo filtrada. Os scans UDP, IP Protocol, FIN, Null, e
            Xmas classificam portas desta forma.</para>
          </listitem>
        </varlistentry>

        <varlistentry>
          <term>closed|filtered</term>

          <listitem>
            <para>Este estado é usado quando o Nmap é incapaz de determinar se
            uma porta está fechada ou filtrada. É apenas usado para o scan
            IPID Idle scan.</para>
          </listitem>
        </varlistentry>
      </variablelist>
    </refsect1>

    <refsect1 id="man-port-scanning-techniques">
      <title>Técnicas de Escaneamento de Portas</title>

      <para>Como um novato executando um reparo automotivo, posso brigar por
      horas tentando usar minhas ferramentas rudimentares (martelo, fita
      adesiva, grifo, etc.) nas tarefas. Quando eu falho miseravelmente e
      reboco minha lata-velha para um mecânico de verdade ele invariavelmente
      pesca aqui e ali em um enorme baú de ferramentas até pegar a coisa
      perfeita que torna a tarefa uma brincadeira. A arte de escanear portas é
      similar. Os experts entendem as dezenas de técnicas de escaneamento e
      escolhem as que são apropriadas (ou uma combinação) para uma dada
      tarefa. Usuários inexperientes e script kiddies, por outro lado, tentam
      resolver todos os problemas com o scan SYN padrão. Uma vez que o Nmap é
      gratuito, a única barreira para a maestria em escaneamento de portas é o
      conhecimento. Isso certamente é melhor que no mundo automotivo, onde
      pode ser necessário uma grande habilidade para determinar que você
      precisa de um compressor de molas e então você tem que pagar milhares de
      dólares por um.</para>

      <para>A maioria dos tipos de scan está disponível apenas para usuários
      privilegiados. Isso acontece porque eles enviam e recebem pacotes em
      estado bruto, o que requer acesso de root em sistemas Unix. Utilizar a
      conta de administrador no Windows é recomendado, embora o Nmap às vezes
      funcione com usuários sem privilégios nessa plataforma quando o WinPcap
      foi carregado no SO. Requerer privilégio de root era uma séria limitação
      quando o Nmap foi lançado em 1997, pois muitos usuários apenas tinham
      acesso a contas de shell compartilhadas. Agora o mundo é diferente.
      Computadores estão mais baratos, muito mais pessoas tem acesso direto e
      permanente à Internet, e computadores de mesa Unix (incluindo Linux e
      MAC OS X) são comuns. Uma versão para o Windows do Nmap se encontra
      disponível atualmente, permitindo que se rode em muito mais computadores
      de mesa. Por todas essas razões, os usuários tem menos necessidade de
      executar o Nmap à partir de contas de shell compartilhadas e limitadas.
      Isso é muito bom pois as opções privilegiadas tornam o Nmap muito mais
      poderoso e flexível.</para>

      <para>Embora o Nmap tente produzir resultados precisos, tenha em mente
      que todas as deduções são baseadas em pacotes devolvidos pelas
      máquinas-alvo (ou firewalls na frente delas). Tais hosts podem ser
      não-confiáveis e enviar respostas com o propósito de confundir ou
      enganar o Nmap. Muito mais comum são os hosts não-de-acordo-com-a-rfc
      que não respondem como deveriam às sondagens do Nmap. As sondagens FIN,
      Null e Xmas são particularmente suscetíveis a esse problema. Tais
      questões são específicas de determinados tipos de scan e portanto são
      discutidos nas entradas individuais de cada um dos tipos.</para>

      <para>Esta seção documenta as dezenas de técnicas de escaneamento de
      portas suportadas pelo Nmap. Apenas um método pode ser utilizado de cada
      vez exceto que um scan UDP (<option>-sU</option>) pode ser combinado com
      qualquer um dos tipos de scan TCP. Como uma ajuda para a memória, as
      opções dos tipos de escaneamento de portas estão no formato
      <option>-s<replaceable>C</replaceable></option>, onde
      <replaceable>C</replaceable> é um caracter proeminente no nome do scan,
      normalmente o primeiro. A única exceção a essa regra é para o scan
      depreciado FTP bounce (<option>-b</option>). Por padrão, o Nmap executa
      um scan SYN, embora ele substitua por um scan connect se o usuário não
      tiver os privilégios adequados para enviar pacotes em estado bruto
      (requer acesso de root no UNIX) ou se alvos IPv6 forem especificados.
      Dos scans listados nesta seção, os usuários não privilegiados podem
      apenas executar os scans connect e ftp bounce.</para>

      <variablelist>
        <varlistentry>
          <term><option>-sS</option> (scan TCP SYN)</term>

          <listitem>
            <indexterm significance="normal">
              <primary>-sS</primary>
            </indexterm>

            <indexterm significance="normal">
              <primary>scan TCP SYN</primary>
            </indexterm>

            <para>O scan SYN é a opção de scan padrão e mais popular por boas
            razões. Pode ser executada rapidamente, escaneando milhares de
            portas por segundo em uma rede rápida, não bloqueada por firewalls
            intrusivos. O scan SYN é relativamente não-obstrusivo e camuflado,
            uma vez que ele nunca completa uma conexão TCP. Ele também
            trabalha contra qualquer pilha TCP padronizada ao invés de
            depender de idiossincrasias de plataformas específicas como os
            scans Fin/Null/Xmas, Maimon e Idle fazem. Ele também permite uma
            diferenciação limpa e confiável entre os estados <literal>aberto
            (open)</literal>, <literal>fechado (closed)</literal>, e
            <literal>filtrado (filtered)</literal>.</para>

            <para>Esta técnica é freqüentemente chamada de escaneamento de
            porta entreaberta (half-open scanning), porque você não abre uma
            conexão TCP completamente. Você envia um pacote SYN, como se fosse
            abrir uma conexão real e então espera uma resposta. Um SYN/ACK
            indica que a porta está ouvindo (aberta), enquanto um RST (reset)
            é indicativo de uma não-ouvinte. Se nenhuma resposta é recebida
            após diversas retransmissões, a porta é marcada como filtrada. A
            porta também é marcada como filtrada se um erro ICMP de
            inalcançável é recebido (tipo 3, código 1,2, 3, 9, 10, ou
            13).</para>
          </listitem>
        </varlistentry>

        <varlistentry>
          <term><option>-sT</option> (scan TCP connect)</term>

          <listitem>
            <indexterm significance="normal">
              <primary>-sT</primary>
            </indexterm>

            <indexterm significance="normal">
              <primary>scan TCP connect</primary>
            </indexterm>

            <para>O scan TCP connect é o scan padrão do TCP quando o scan SYN
            não é uma opção. Esse é o caso quando o usuário não tem
            privilégios para criar pacotes em estado bruto ou escanear redes
            IPv6. Ao invés de criar pacotes em estado bruto como a maioria dos
            outros tipos de scan fazem, o Nmap pede ao sistema operacional
            para estabelecer uma conexão com a máquina e porta alvos enviando
            uma chamada de sistema <literal>connect()</literal>. Essa é a
            mesma chamada de alto nível que os navegadores da web, clientes
            P2P, e a maioria das outras aplicações para rede utilizam para
            estabelecer uma conexão. É parte da interface de programação
            conhecida como API de Sockets de Berkeley. Ao invés de ler as
            respostas em pacotes em estado bruto diretamente dos fios, o Nmap
            utiliza esta API para obter informações do estado de cada
            tentativa de conexão.</para>

            <para>Quando um scan SYN está disponível é normalmente a melhor
            escolha. O Nmap tem menos controle sobre a chamada de alto nível
            <literal>connect()</literal> do que sobre os pacotes em estado
            bruto, tornando-o menos eficiente. A chamada de sistema completa
            as conexões nas portas-alvo abertas ao invés de executar o reset
            de porta entreaberta que o scan SYN faz. Isso não só leva mais
            tempo e requer mais pacotes para obter a mesma informação, mas
            também torna mais provável que as máquinas-alvo registrem a
            conexão. Um sistema IDS decente irá detectar qualquer um deles,
            mas a maioria das máquinas não tem esse tipo de sistema de alarme.
            Muitos serviços na maioria dos sistema Unix irão acrescentar uma
            nota no syslog, e às vezes uma mensagem de erro obscura, quando o
            Nmap se conecta e então fecha a conexão sem enviar nenhum dado.
            Serviços verdadeiramente patéticos irão travar quando isso
            acontecer, embora isso seja incomum. Um administrador que vê um
            punhado de tentativas de conexão nos registros vindos de um único
            sistema deveria saber que foi escaneado com connect().</para>
          </listitem>
        </varlistentry>

        <varlistentry>
          <term><option>-sU</option> (scans UDP)</term>

          <listitem>
            <indexterm significance="normal">
              <primary>-sU</primary>
            </indexterm>

            <indexterm significance="normal">
              <primary>scans UDP</primary>
            </indexterm>

            <para>Embora os serviços mais populares na Internet trafeguem
            sobre o protocolo TCP, os serviços <ulink
            url="http://www.rfc-editor.org/rfc/rfc768.txt">UDP</ulink> são
            amplamente difundidos. O DNS, o SNMP, e o DHCP (registrados nas
            portas 53, 161/162, e 67/68) são três dos mais comuns. Pelo fato
            do escaneamento UDP ser normalmente mais lento e mais difícil que
            o TCP, alguns auditores de segurança ignoram essas portas. Isso é
            um erro, pois serviços UDP passíveis de exploração são bastante
            comuns e invasores certamente não ignoram o protocolo inteiro.
            Felizmente o Nmap pode ajudar a inventariar as portas UDP.</para>

            <para>O scan UDP é ativado com a opção <option>-sU</option>. Ele
            pode ser combinado com um tipo de escaneamento TCP como o scan SYN
            (<option>-sS</option>) para averigüar ambos protocolos na mesma
            execução.</para>

            <para>O scan UDP funciona enviando um cabeçalho UDP vazio (sem
            dados) para cada porta almejada. Se um erro ICMP de porta
            inalcançável (tipo 3, código 3) é retornado, a porta está
            <literal>fechada</literal>. Outros erros do tipo inalcançável
            (tipo 3, códigos 1, 2, 9, 10, ou 13) marcam a porta como
            <literal>filtrada</literal>. Ocasionalmente um serviço irá
            responder com um pacote UDP, provando que está
            <literal>aberta</literal>. Se nenhuma resposta é recebida após as
            retransmissões, a porta é classificada como
            <literal>aberta|filtrada</literal>. Isso significa que a porta
            poderia estar aberta, ou talvez que filtros de pacotes estejam
            bloqueando a comunicação. Scans de versões (<option>-sV</option>)
            podem ser utilizados para ajudar a diferenciar as portas
            verdadeiramente abertas das que estão filtradas.</para>

            <para>Um grande desafio com o escaneamento UDP é fazê-lo
            rapidamente. Portas abertas e filtradas raramente enviam alguma
            resposta, deixando o Nmap esgotar o tempo (time out) e então
            efetuar retransmissões para o caso de a sondagem ou a resposta ter
            sido perdida. Portas fechadas são, normalmente, um problema ainda
            maior. Elas costumam enviar de volta um erro ICMP de porta
            inalcançável. Mas, ao contrário dos pacotes RST enviados pelas
            portas TCP fechadas em resposta a um scan SYN ou connect, muitos
            hosts limitam a taxa de mensagens ICMP de porta inalcançável por
            padrão. O Linux e o Solaris são particularmente rigorosos quanto a
            isso. Por exemplo, o kernel 2.4.20 do Linux limita a quantidade de
            mensagens de destino inalcançável a até uma por segundo (no
            <filename>net/ipv4/icmp.c</filename>).</para>

            <para>O Nmap detecta a limitação de taxa e diminui o ritmo de
            acordo para evitar inundar a rede com pacotes inúteis que a
            máquina-alvo irá descartar. Infelizmente, um limite como o do
            Linux de um pacote por segundo faz com que um scan de 65.536
            portas leve mais de 18 horas. Idéias para acelerar o escaneamento
            UDP incluem escanear mais hosts em paralelo, fazer um scan rápido
            apenas das portas mais comuns primeiro, escanear por detrás de um
            firewall, e utilizar <option>--host-timeout</option> para pular os
            hosts lentos.</para>
          </listitem>
        </varlistentry>

        <varlistentry>
          <term><option>-sN</option>; <option>-sF</option>;
          <option>-sX</option> (scans TCP Null, FIN, e Xmas)</term>

          <listitem>
            <indexterm significance="normal">
              <primary>-sN</primary>
            </indexterm>

            <indexterm significance="normal">
              <primary>-sF</primary>
            </indexterm>

            <indexterm significance="normal">
              <primary>-sX</primary>
            </indexterm>

            <indexterm significance="normal">
              <primary>scan TCP NULL</primary>
            </indexterm>

            <indexterm significance="normal">
              <primary>scan TCP FIN</primary>
            </indexterm>

            <indexterm significance="normal">
              <primary>scan TCP Xmas</primary>
            </indexterm>

            <para>Esses três tipos de scan (existem outras opções, possíveis
            com a opção <option>--scanflags</option> descrita na próxima
            seção) exploram uma brecha sutil na <ulink
            url="http://www.rfc-editor.org/rfc/rfc793.txt">RFC do TCP</ulink>
            para diferenciarem entre portas <literal>abertas</literal> e
            <literal>fechadas</literal>. A página 65 diz que <quote>se a porta
            [destino] estiver FECHADA .... um segmento entrante que não
            contenha um RST irá causar o envio de um RST como
            resposta.</quote> Então a página seguinte discute os pacotes
            enviados à portas abertas sem os bits SYN, RST ou ACK marcados,
            afirmando que: <quote>é pouco provável que você chegue aqui, mas
            se chegar, descarte o segmento, e volte.</quote></para>

            <para>Quando se escaneia sistemas padronizados com o texto desta
            RFC, qualquer pacote que não contenha os bits SYN, RST, ou ACK irá
            resultar em um RST como resposta se a porta estiver fechada, e
            nenhuma resposta se a porta estiver aberta. Contanto que nenhum
            desses três bits estejam incluídos, qualquer combinação dos outros
            três (FIN, PSH e URG) é válida. O Nmap explora isso com três tipos
            de scan:</para>

            <variablelist>
              <varlistentry>
                <term>scan Null (<option>-sN</option>)</term>

                <listitem>
                  <para>Não marca nenhum bit (o cabeçalho de flag do tcp é
                  0)</para>
                </listitem>
              </varlistentry>

              <varlistentry>
                <term>scan FIN (<option>-sF</option>)</term>

                <listitem>
                  <para>Marca apenas o bit FIN do TCP.</para>
                </listitem>
              </varlistentry>

              <varlistentry>
                <term>scan Xmas(<option>-sX</option>)</term>

                <listitem>
                  <para>Marca as flags FIN, PSH e URG, iluminando o pacote
                  como uma árvore de Natal.</para>
                </listitem>
              </varlistentry>
            </variablelist>

            <para>Esses três tipos de scan são exatamente os mesmos em termos
            de comportamento, exceto pelas flags TCP marcadas no pacotes de
            sondagem. Se um pacote RST for recebido, a porta é considerada
            <literal>fechada</literal>, e nenhuma resposta significa que está
            <literal>aberta|filtrada</literal>. A porta é marcada como
            <literal>filtrada</literal> se um erro ICMP do tipo inalcançável
            (tipo 3, código 1, 2, 3, 9, 10, ou 13) for recebido.</para>

            <para>A vantagem principal desses tipos de scan é que eles podem
            bisbilhotar através de alguns firewalls não-orientados à conexão e
            de roteadores que filtram pacotes. Outra vantagem é que esses
            tipos de scan são um pouco mais camuflados do que o scan SYN. Mas,
            não conte com isso -- a maioria dos produtos IDS modernos podem
            ser configurados para detectá-los. O maior problema é que nem
            todos os sistemas seguem a RFC 793 ao pé-da-letra. Diversos
            sistemas enviam respostas RST para as sondagens independentemente
            do fato da porta estar aberta ou não. Isso faz com que todas as
            portas sejam classificadas como <literal>fechadas</literal>. A
            maioria dos sistemas operacionais que fazem isso são Microsoft
            Windows, muitos dispositivos Cisco, BSDI, e o IBM OS/400. Esse
            scan realmente funciona contra a maioria dos sistemas baseados em
            Unix. Outro ponto negativo desses scans é que eles não conseguem
            diferenciar portas <literal>abertas</literal> de alguns tipos de
            portas <literal>filtradas</literal>, deixando você com a resposta
            <literal>abera|filtrada</literal>.</para>
          </listitem>
        </varlistentry>

        <varlistentry>
          <term><option>-sA</option> (scan TCP ACK)</term>

          <listitem>
            <indexterm significance="normal">
              <primary>-sA</primary>
            </indexterm>

            <indexterm significance="normal">
              <primary>scan TCP ACK</primary>
            </indexterm>

            <para>Esse scan é diferente dos outros discutidos até agora pelo
            fato de que ele nunca determina se uma porta está
            <literal>aberta</literal> (ou mesmo
            <literal>aberta|filtrada</literal>). Ele é utilizado para mapear
            conjuntos de regras do firewall, determinando se eles são
            orientados à conexão ou não e quais portas estão filtradas.</para>

            <para>O pacote de sondagem do scan ACK tem apenas a flag ACK
            marcada (a menos que você use <option>--scanflags</option>).
            Quando se escaneia sistemas não-filtrados, as portas
            <literal>abertas</literal> e <literal>fechadas</literal> irão
            devolver um pacote RST. O Nmap então coloca nelas o rótulo
            <literal>não-filtradas (unfiltered)</literal>, significando que
            elas estão alcançáveis pelo pacote ACK, mas se elas estão
            <literal>abertas</literal> ou <literal>fechadas</literal> é
            indeterminado. Portas que não respondem, ou que devolvem certas
            mensagens de erro ICMP (tipo 3, código 1, 2, 3, 9, 10, ou 13), são
            rotuladas como <literal>filtradas</literal>.</para>
          </listitem>
        </varlistentry>

        <varlistentry>
          <term><option>-sW</option> (scan da Janela TCP)</term>

          <listitem>
            <indexterm significance="normal">
              <primary>-sW</primary>
            </indexterm>

            <indexterm significance="normal">
              <primary>Scan da Janela TCP</primary>
            </indexterm>

            <para>Scan da Janela é exatamente o mesmo que o scan ACK, exceto
            que ele explora um detalhe da implementação de certos sistemas de
            forma a diferenciar as portas abertas das fechadas, ao invés de
            sempre mostrar <literal>não-filtrada</literal> quando um RST é
            devolvido. Ele faz isso examinando o campo Janela TCP (TCP Window)
            do pacote RST devolvido. Em alguns sistemas, as portas abertas
            usam um valor positivo de tamanho de janela (mesmo para pacotes
            RST), enquanto que as portas fechadas tem um valor igual a zero.
            Então, ao invés de sempre mostrar uma porta como
            <literal>não-filtrada</literal> quando se recebe um RST de volta,
            o scan da Janela mostra a porta como <literal>aberta</literal> ou
            <literal>fechada</literal> se o valor da Janela TCP no reset for
            positivo ou zero, respectivamente.</para>

            <para>Este scan se baseia em um detalhe de implementação de uma
            minoria de sistemas na Internet, portanto não se pode confiar
            sempre nele. Sistemas que não suportam isso irão normalmente
            devolver todas as portas como <literal>fechadas</literal>. É claro
            que é possível que a máquina realmente não tenha nenhuma porta
            aberta. Se a maioria das portas escaneadas estiver
            <literal>fechada</literal> mas uns poucos números de portas comuns
            (tais como 22, 25, 53) estão <literal>filtrados</literal>, o
            sistema muito provavelmente está vulnerável. De vez em quando, os
            sistemas irão mostrar exatamente o comportamento oposto. Se o seu
            scan mostrar 1000 portas abertas e 3 fechadas ou filtradas, então
            essas três podem muito bem ser as verdadeiramente abertas.</para>
          </listitem>
        </varlistentry>

        <varlistentry>
          <term><option>-sM</option> (scan TCP Maimon)</term>

          <listitem>
            <indexterm significance="normal">
              <primary>-sM</primary>
            </indexterm>

            <indexterm significance="normal">
              <primary>scan TCP Maimon</primary>
            </indexterm>

            <para>O scan Maimon recebeu o nome de seu descobridor, Uriel
            Maimon. Ele descreveu a técnica na Phrack Magazine, edição 49
            (Novembro de 1996). O Nmap, que incluiu essa técnica, foi lançado
            duas edições mais tarde. A técnica é exatamente a mesma que os
            scans Null, FIN e Xmas, exceto que a sondagem é FIN/ACK. De acordo
            com a RFC 793 (TCP), um pacote RST deveria ser gerado em resposta
            a tal sondagem se a porta estiver aberta ou fechada. Entretanto,
            Uriel notou que muitos sistemas derivados do BSD simplesmente
            descartavam o pacote se a porta estivesse aberta.</para>
          </listitem>
        </varlistentry>

        <varlistentry>
          <term><option>--scanflags</option> (scan TCP Personalizado)</term>

          <listitem>
            <indexterm significance="normal">
              <primary>--scanflags</primary>
            </indexterm>

            <para>Usuários verdadeiramente avançados do Nmap não precisam se
            limitar aos tipos de scans enlatados oferecidos. A opção
            <option>--scanflags</option> permite que você desenhe seu próprio
            scan permitindo a especificação de flags TCP arbitrárias. Deixe
            sua imaginação correr solta enquanto dribla sistemas de detecção
            de intrusão, cujos fabricantes apenas olharam rapidamente a página
            man do Nmap adicionando regras específicas!</para>

            <para>O argumento do <option>--scanflags</option> pode ser um
            valor numérico da marca (flag) como o 9 (PSH e FIN), mas usar
            nomes simbólicos é mais fácil. Apenas esprema alguma combinação de
            <literal>URG</literal>, <literal>ACK</literal>,
            <literal>PSH</literal>, <literal>RST</literal>,
            <literal>SYN</literal>, e <literal>FIN</literal>. Por exemplo,
            <option>--scanflags URGACKPSHRSTSYNFIN</option> marca tudo, embora
            não seja muito útil para escaneamento. A ordem em que essas marcas
            são especificadas é irrelevante.</para>

            <para>Além de especificar as marcas desejadas, você pode
            especificar um tipo de scan TCP (como o <option>-sA</option> ou
            <option>-sF</option>). Esse tipo-base diz ao Nmap como interpretar
            as respostas. Por exemplo, um scan SYN considera nenhuma-resposta
            como uma indicação de porta <literal>filtrada</literal>, enquanto
            que um scan FIN trata a mesma como
            <literal>aberta|filtrada</literal>. O Nmap irá se comportar da
            mesma forma que o tipo de scan-base escolhido, exceto que ele irá
            usar as marcas TCP que você especificar. Se você não escolher um
            tipo-base, o scan SYN é utilizado.</para>
          </listitem>
        </varlistentry>

        <varlistentry>
          <term><option>-sI &lt;hostzumbi[:portadesondagem]&gt;</option> (scan
          Idle)</term>

          <listitem>
            <indexterm significance="normal">
              <primary>-sI</primary>
            </indexterm>

            <indexterm significance="normal">
              <primary>scan Idle</primary>
            </indexterm>

            <para>Este método avançado de scan permite um scan TCP realmente
            cego das portas do alvo (significando que nenhum pacote é enviado
            para o alvo do seu endereço IP real). Ao invés disso, um ataque
            canal-lateral (side-channel) explora a previsível geração de
            seqüencia de ID, conseqüencia da fragmentação do IP, no host
            zumbi, para juntar informações sobre as portas abertas no alvo.
            Sistemas IDS irão mostrar o scan como se viessem da máquina zumbi
            que você especificou (que deve estar ativa e obedecer a alguns
            critérios). Este tipo fascinante de scan é complexo demais para se
            descrever completamente aqui, neste guia de referência, então eu
            escrevi e postei um trabalho informal com detalhes completos em
            <ulink url="http://nmap.org/book/idlescan.html" />.</para>

            <para>Além de ser extraordinariamente camuflado (devido à sua
            natureza cega), este tipo de scan permite mapear relações de
            confiança baseadas em IP entre máquinas. A listagem de portas
            mostra as portas abertas <emphasis>da perspectiva do host
            zumbi.</emphasis> Portanto você pode tentar escanear algo usando
            vários zumbis que você acha que podem ser confiáveis (via regras
            de roteador/filtro de pacotes).</para>

            <para>Você pode adicionar o sinal "dois-pontos", seguido do número
            da porta, ao nome do host zumbi se quiser sondar uma porta em
            particular no zumbi, verificando as mudanças de IPID. Do contrário
            o Nmap irá utilizar a porta que ele normalmente usa por padrão
            para pings tcp (80).</para>
          </listitem>
        </varlistentry>

        <varlistentry>
          <term><option>-sO</option> (Scans do protocolo IP)</term>

          <listitem>
            <indexterm significance="normal">
              <primary>-sO</primary>
            </indexterm>

            <indexterm significance="normal">
              <primary>Scans do protocolo IP</primary>
            </indexterm>

            <para>Scans do Protocolo IP permitem que você determine quais
            protocolos IP (TCP, ICMP, IGMP, etc.) são suportados pelas
            máquina-alvo. Isso não é, tecnicamente, um scan de portas, pois
            ele varia os números do protocolo IP ao invés dos números de
            portas TCP e UDP. Ainda assim, ele utiliza a opção
            <option>-p</option> para selecionar os números de protocolos a
            escanear, mostra os resultados dentro do formato normal da tabela
            de portas e usa o mesmo mecanismo de escaneamento dos métodos de
            descoberta de portas. Portanto ele é parecido o suficiente com um
            scan de portas e por isso pertence à este lugar.</para>

            <para>Além de ser útil de seu jeito, o scan de protocolo mostra o
            poder do software de código aberto. Embora a idéia fundamental
            seja bastante simples, eu não havia pensado em adicioná-la e nem
            havia recebido nenhuma solicitação para essa funcionalidade.
            Então, no verão de 2000, Gerhard Rieger concebeu a idéia, escreveu
            uma excelente alteração (patch) implementando-a, e a enviou para a
            lista de discussão nmap-hackers. Eu incorporei a alteração na
            árvore do Nmap e lancei uma nova versão no dia seguinte. Poucos
            produtos de software comercial tem usuários entusiasmados o
            suficiente para desenhar e contribuir com melhorias!</para>

            <para>O scan de protocolo funciona de uma forma similar a um scan
            UDP. Ao invés de ficar repetindo alternando o campo de número de
            porta de um pacote UDP, ele envia cabeçalhos de pacote IP e faz a
            repetição alternando o campo de protocolo IP de 8 bits. Os
            cabeçalhos normalmente estão vazios, sem conter dados, e nem mesmo
            contendo o cabeçalho apropriado do suposto protocolo. As três
            exceções são o TCP, o UDP e o ICMP. Um cabeçalho de protocolo
            apropriado para estes é incluído, uma vez que alguns sistemas não
            os enviarão caso não tenham, e porque o Nmap tem as funções para
            criá-los Ao invés de observar as mensagens de erro ICMP de porta
            inalcançável, o scan de protocolo fica de olho nas mensagens ICMP
            de <emphasis>protocolo</emphasis> inalcançável. Se o Nmap recebe
            qualquer resposta de qualquer protocolo do host-alvo, o Nmap marca
            esse protocolo como <literal>aberto</literal>. Um erro ICMP de
            protocolo não-alcançável (tipo 3, código 2) faz com que o
            protocolo seja marcado como <literal>fechado</literal>. Outros
            erros ICMP do tipo inalcançável (tipo 3, código 1, 3, 9, 10, ou
            13) fazem com que o protocolo seja marcado como
            <literal>filtrado</literal> (embora eles provem, ao mesmo tempo,
            que o ICMP está <literal>aberto</literal>). Se nenhuma resposta
            for recebida após as retransmissões, o protocolo é marcado como
            <literal>aberto|filtrado.</literal></para>
          </listitem>
        </varlistentry>

        <varlistentry>
          <term><option>-b &lt;host para relay de ftp&gt;</option> (Scan de
          FTP bounce)</term>

          <listitem>
            <indexterm significance="normal">
              <primary>-b</primary>
            </indexterm>

            <indexterm significance="normal">
              <primary>Scan de FTP bounce</primary>
            </indexterm>

            <para>Uma característica interessante do protocolo FTP (<ulink
            url="http://www.rfc-editor.org/rfc/rfc959.txt">RFC 959</ulink>) é
            o suporte à conexões denominadas proxy ftp. Isso permite que um
            usuário conecte-se a um servidor FTP, e então solicite que
            arquivos sejam enviados a um terceiro servidor. Tal característica
            é sujeita a abusos em diversos níveis, por isso a maioria dos
            servidores parou de suportá-la. Um dos abusos permitidos é fazer
            com que o servidor FTP escaneie as portas de outros hosts.
            Simplesmente solicite que o servidor FTP envie um arquivo para
            cada porta interessante do host-alvo. A mensagem de erro irá
            descrever se a porta está aberta ou não. Esta é uma boa forma de
            passar por cima de firewalls porque os servidores FTP de empresas
            normalmente são posicionados onde tem mais acesso a outros hosts
            internos que os velhos servidores da Internet teriam. O Nmap
            suporta o scan de ftp bounce com a opção <option>-b</option>. Ela
            recebe um argumento no formato
            <replaceable>nomedousuário</replaceable>:<replaceable>senha</replaceable>@<replaceable>servidor</replaceable>:<replaceable>porta</replaceable>.
            <replaceable>Servidor</replaceable> é o nome ou endereço IP de um
            servidor FTP vulnerável. Assim como em uma URL normal, você pode
            omitir
            <replaceable>nomedousuário</replaceable>:<replaceable>senha</replaceable>,
            neste caso as credenciais de login anônimo (usuário:
            <literal>anonymous</literal> senha:<literal>-wwwuser@</literal>)
            serão usados. O número da porta (e os dois-pontos) podem ser
            omitidos, e então a porta FTP padrão (21) no
            <replaceable>servidor</replaceable> será utilizada.</para>

            <para>Esta vulnerabilidade espalhou-se em 1997 quando o Nmap foi
            lançado, mas foi corrigida amplamente. Servidores vulneráveis
            ainda estão por aí, então pode valer a pena tentar se tudo o mais
            falhar. Se passar por cima de um firewall é o seu objetivo,
            escaneie a rede-alvo procurando por uma porta 21 aberta (ou mesmo
            por qualquer serviço FTP se você escanear todas as portas com a
            detecção de versão), então tente um scan bounce usando-as. O Nmap
            irá dizer se o host é vulnerável ou não. Se você estiver apenas
            tentando encobrir suas pegadas, você não precisa (e, na verdade,
            não deveria) limitar-se a hosts na rede-alvo. Antes de sair
            escaneando endereços aleatórios na Internet, procurando por
            servidores FTP, considere que os administradores de sistemas podem
            não apreciar o seu abuso nos servidores deles.</para>
          </listitem>
        </varlistentry>
      </variablelist>
    </refsect1>

    <refsect1 id="man-port-specification">
      <title>Especificação de Portas e Ordem de Scan</title>

      <para>Somado a todos os métodos de scan discutidos anteriormente, o Nmap
      oferece opções para especificar quais portas são escaneadas e se a ordem
      de escaneamento é aleatória ou sequencial. Por padrão, o Nmap escaneia
      todas as portas até, e incluindo, 1024, bem como portas com numeração
      alta listadas no arquivo the <filename>nmap-services</filename> para
      o(s) protocolo(s) escaneados.</para>

      <variablelist>
        <varlistentry>
          <term><option>-p &lt;faixa de portas&gt;</option> (Escaneia apenas
          as portas especificadas)</term>

          <listitem>
            <indexterm significance="normal">
              <primary>-p</primary>
            </indexterm>

            <para>Esta opção especifica quais portas que você deseja escanear
            e prevalece sobre o padrão. Números de portas individuais são
            suportadas, bem como as faixas separadas por um hífen (p.ex.:
            1-1023). Os valores iniciais e/ou finais da faixa podem ser
            omitidos, o que faz com que o Nmap use 1 e 65535, respectivamente.
            Portanto, você pode especificar <option>-p-</option> para escanear
            as portas de 1 até 65535. Escanear a porta zero é permitido se
            você especificar explicitamente. Para o escaneamento do protocolo
            IP (<option>-sO</option>), esta opção especifica os números dos
            protocolos que você deseja escanear (0-255).</para>

            <para>Quando escanear ambas as portas TCP e UDP, você pode
            especificar um protocolo em particular, precedendo os números de
            portas com <literal>T:</literal> ou <literal>U:</literal>. O
            qualificador dura até que você especifique um novo qualificador.
            Por exemplo, o argumento <option>-p
            U:53,111,137,T:21-25,80,139,8080</option> escanearia as portas UDP
            53, 111 e 137, bem como as portas TCP listadas. Note que para
            escanear ambas as portas UDP e TCP, você tem que especificar
            <option>-sU</option> e pelo menos um tipo de scan TCP (tal como
            <option>-sS</option>, <option>-sF</option> ou
            <option>-sT</option>). Se nenhum qualificador de protocolo for
            informado, os números de portas serão acrescentados à todas as
            listas de protocolos.</para>
          </listitem>
        </varlistentry>

        <varlistentry>
          <term><option>-F</option> (Scan Rápido (portas limitadas))</term>

          <listitem>
            <indexterm significance="normal">
              <primary>-F</primary>
            </indexterm>

            <para>Especifica que você deseja apenas escanear as portas
            listadas no arquivo <filename>nmap-services</filename> que vem com
            o nmap (ou o arquivo de protocolos para o <option>-sO</option>).
            Isto é muito mais rápido do que escanear todas as 65535 portas de
            um host. Pelo fato desta lista conter tantas portas TCP (mais de
            1200), a diferença de velocidade de um scan TCP padrão (cerca de
            1650 portas) não é dramática. A diferença pode ser enorme se você
            especificar seu próprio minúsculo arquivo
            <filename>nmap-services</filename> usando a opção
            <option>--datadir</option>.</para>
          </listitem>
        </varlistentry>

        <varlistentry>
          <term><option>-r</option> (Não usa as portas de forma
          aleatória)</term>

          <listitem>
            <indexterm significance="normal">
              <primary>-r</primary>
            </indexterm>

            <para>Por padrão, o Nmap usa a ordem das portas a serem escaneadas
            de forma aleatória (exceto aquelas portas normalmente certamente
            acessíveis que são movidas próximas ao início por motivos de
            eficiência). Essa técnica de busca aleatória normalmente é
            desejável, mas você pode especificar <option>-r</option> para um
            escaneamento de portas sequencial.</para>
          </listitem>
        </varlistentry>
      </variablelist>
    </refsect1>

    <refsect1 id="man-version-detection">
      <title>Detecção de Serviço e Versão</title>

      <indexterm significance="normal">
        <primary>scan de Versão</primary>
      </indexterm>

      <para>Aponte o Nmap para uma máquina remota e ele poderá lhe dizer que
      as portas 25/tcp, 80/tcp e 53/udp estão abertas. Utilizar o banco de
      dados <filename>nmap-services</filename>, com cerca de 2.200 serviços
      bastante conhecidos, do Nmap iria relatar que aquelas portas
      provavelmente correspondem a um servidor de correio eletrônico (SMTP), a
      um servidor de páginas web (HTTP) e a um servidor de nomes (DNS)
      respectivamente. Essa pesquisa normalmente é precisa -- a grande maioria
      de daemons escutando na porta TCP 25 é, de fato, de servidores de
      correio eletrônico. Entretanto, você não deveria apostar a sua segurança
      nesta informação! As pessoas podem e executam serviços em portas
      estranhas.</para>

      <para>Mesmo que o Nmap esteja certo, e o servidor hipotético acima
      esteja executando os serviços SMTP, HTTP e DNS, isso não é informação o
      bastante. Quando fizer uma avaliação de vulnerabilidades (ou mesmo um
      simples inventário da rede) de sua empresa ou clientes, você realmente
      deseja saber qual o programa-servidor de correio eletrônico ou de nomes
      e as versões que estão rodando. Ter um número de versão exato ajuda
      substancialmente na determinação de quais explorações (exploits) o
      servidor está vulnerável. A detecção de versão ajuda a obter esta
      informação.</para>

      <para>Depois que as portas TCP e/ou UDP forem descobertas usando
      qualquer um dos outros métodos de scan, a detecção de versão interroga
      essas portas para determinar mais informações sobre o que realmente está
      sendo executado nessas portas. O banco de dados
      <filename>nmap-service-probes</filename> do Nmap contém sondagens para
      pesquisar diversos serviços e expressões de acerto (match expressions)
      para reconhecer e destrinchar as respostas. O Nmap tenta determinar os
      protocolos de serviços (p.ex.: ftp, ssh, telnet, http), o nome da
      aplicação (p.ex.: ISC Bind, Apache httpd, Solaris telnetd), o número da
      versão, o nome do host, tipo de dispositivo (p.ex.: impressora,
      roteador), a família do SO (p.ex.: Windows, Linux) e às vezes detalhes
      diversos do tipo, se um servidor X está aberto para conexões, a versão
      do protocolo SSH ou o nome do usuário do KaZaA. É claro que a maioria
      dos serviços não fornece todas essas informações. Se o Nmap foi
      compilado com o suporte ao OpenSSL, ele irá se conectar aos servidores
      SSL para deduzir qual o serviço que está escutando por trás da camada
      criptografada. Quando os serviços RPC são descobertos, o "amolador" de
      RPC (RPC grinder) do Nmap (<option>-sR</option>) é automaticamente
      utilizado para determinar o nome do programa RPC e o número da versão.
      Algumas portas UDP são deixadas no estado
      <literal>aberta|filtrada</literal> depois que scan de porta UDP não
      consegue determinar se a porta está aberta ou filtrada. A detecção de
      versão irá tentar provocar uma resposta dessas portas (do mesmo jeito
      que faz com as portas abertas), e alterar o estado para aberta se
      conseguir. Portas TCP do tipo <literal>aberta|filtrada</literal> são
      tratadas da mesma forma. Note que a opção <option>-A</option> do Nmap
      habilita a detecção de versão, entre outras coisas. Um trabalho
      documentando o funcionamento, uso e customização da detecção de versão
      está disponível em <ulink
      url="http://insecure.org/nmap/vscan/" />.</para>

      <para>Quando o Nmap recebe uma resposta de um serviço mas não consegue
      encontrá-la em seu banco de dados, ele mostra uma identificação
      (fingerprint) especial e uma URL para que você envie informações se
      souber com certeza o que está rodando nessa porta. Por favor, considere
      dispor de alguns minutos para mandar essa informação de forma que sua
      descoberta possa beneficiar a todos. Graças a esses envios, o Nmap tem
      cerca de 3.000 padrões de acerto para mais de 350 protocolos, tais como
      o smtp, ftp, http, etc.</para>

      <para>A detecção de versão é habilitada e controlada com as seguintes
      opções:</para>

      <variablelist>
        <varlistentry>
          <term><option>-sV</option> (detecção de versão)</term>

          <listitem>
            <indexterm significance="normal">
              <primary>-sV</primary>
            </indexterm>

            <para>Habilita a detecção de versão, conforme discutido acima.
            Alternativamente, você pode usar a opção <option>-A</option> para
            habilitar tanto a detecção de SO como a detecção de versão.</para>
          </listitem>
        </varlistentry>

        <varlistentry>
          <term><option>--allports</option> (Não exclui nenhuma porta da
          detecção de versão)</term>

          <listitem>
            <indexterm significance="normal">
              <primary>--allports</primary>
            </indexterm>

            <para>Por padrão, a detecção de versão do Nmap pula a porta TCP
            9100 por causa de algumas impressoras que imprimem qualquer coisa
            que seja enviada para essa porta, levando a dezenas de páginas com
            requisições HTTP, requisições de sessões SSL binárias, etc. Esse
            comportamento pode ser alterado modificando-se ou removendo a
            diretiva <literal>Exclude</literal> no
            <filename>nmap-service-probes</filename>, ou você pode especificar
            <option>--allports</option> para escanear todas as portas
            independente de qualquer diretiva
            <literal>Exclude</literal>.</para>
          </listitem>
        </varlistentry>

        <varlistentry>
          <term><option>--version-intensity &lt;intensidade&gt;</option>
          (Estabelece a intensidade do scan de versão)</term>

          <listitem>
            <indexterm significance="normal">
              <primary>--version-intensity</primary>
            </indexterm>

            <para>Quando está executando um scan de versão
            (<option>-sV</option>), o nmap envia uma série de sondagens, cada
            qual com um valor atribuído de raridade, entre 1 e 9. As sondagens
            com números baixos são efetivas contra uma ampla variedade de
            serviços comuns, enquanto as com números altos são raramente
            úteis. O nível de intensidade especifica quais sondagens devem ser
            utilizadas. Quando mais alto o número, maiores as chances de o
            serviço ser corretamente identificado. Entretanto, scans de alta
            intensidade levam mais tempo. A intensidade deve estar entre 0 e
            9. O padrão é 7. Quando uma sondagem é registrada na porta-alvo
            através da diretiva <filename>nmap-service-probes</filename>
            <literal>ports</literal>, essa sondagem é tentada
            independentemente do nível de intensidade. Isso assegura que as
            sondagens DNS sempre serão tentadas contra qualquer porta 53
            aberta, e a sondagem SSL será realizada contra a 443, etc.</para>
          </listitem>
        </varlistentry>

        <varlistentry>
          <term><option>--version-light</option> (Habilita o modo leve
          (light))</term>

          <listitem>
            <indexterm significance="normal">
              <primary>--version-light</primary>
            </indexterm>

            <para>Esse é um apelido conveniente para
            <option>--version-intensity 2</option>. Esse modo leve torna o
            escaneamento de versão muito mais rápido, mas é ligeiramente menos
            provável que identifique os serviços.</para>
          </listitem>
        </varlistentry>

        <varlistentry>
          <term><option>--version-all</option> (Tenta simplesmente todas as
          sondagens)</term>

          <listitem>
            <indexterm significance="normal">
              <primary>--version-all</primary>
            </indexterm>

            <para>Um apelido para <option>--version-intensity 9</option>,
            assegurando que todas as sondagens sejam tentadas contra cada
            porta.</para>
          </listitem>
        </varlistentry>

        <varlistentry>
          <term><option>--version-trace</option> (Monitora as atividades do
          scan de versão)</term>

          <listitem>
            <indexterm significance="normal">
              <primary>--version-trace</primary>
            </indexterm>

            <para>Isto faz com que o Nmap mostre informações de depuração
            extensivas sobre o que o escaneamento de versão está fazendo. É um
            sub-conjunto do que você obteria com
            <option>--packet-trace</option>.</para>
          </listitem>
        </varlistentry>

        <varlistentry>
          <term><option>-sR</option> (Scan RPC)</term>

          <listitem>
            <indexterm significance="normal">
              <primary>--sR</primary>
            </indexterm>

            <para>Este método trabalha em conjunto com os vários métodos de
            escaneamento de portas do Nmap. Ele pega todas as portas TCP/UDP
            descobertas no estado aberta e inunda-as com comandos NULL do
            programa SunRPC, em uma tentativa de determinar se elas são portas
            RPC e, se forem, quais programas e números de versão elas mostram.
            Dessa forma você pode obter efetivamente a mesma informação que o
            <command>rpcinfo -p</command> mesmo se o portmapper do alvo
            estiver atrás de um firewall (ou protegido por TCP wrappers).
            Chamarizes não funcionam ainda com o scan RPC. Isso é habilitado
            automaticamente como parte do scan de versão
            (<option>-sV</option>) se você o solicitar. Como a detecção de
            versão inclui isso e é muito mais abrangente, o
            <option>-sR</option> raramente é necessário.</para>
          </listitem>
        </varlistentry>
      </variablelist>
    </refsect1>

    <refsect1 id="man-os-detection">
      <title>Detecção de SO</title>

      <indexterm significance="normal">
        <primary>Detecção de SO</primary>
      </indexterm>

      <para>Uma das características mais conhecidas do Nmap é a detecção
      remota de SO utilizando a identificação da pilha (stack fingerprinting)
      do TCP/IP. O Nmap envia uma série de pacotes TCP e UDP ao host remoto e
      examina praticamente todos os bits das respostas. Após executar dezenas
      de testes como a amostragem TCP ISN, suporte e ordenamento das opções do
      TCP, amostragem IPID e a checagem do tamanho inicial da janela, o Nmap
      compara os resultados com o banco de dados
      <filename>nmap-os-fingerprints</filename> com mais de 1500
      identificações de SO conhecidas e mostra os detalhes do SO se houver uma
      correspondência. Cada identificação inclui uma descrição textual livre
      do SO e uma classificação que fornece o nome do fabricante (p.ex.: Sun),
      SO base (p.ex.: Solaris), geração do SO (p.ex.: 10) e tipo de
      dispositivo (genérico, roteador, switch, console de jogo, etc.).</para>

      <para>Se o Nmap não conseguir identificar o SO da máquina, e as
      condições forem favoráveis (p.ex.: pelo menos uma porta aberta e uma
      porta fechada foram encontradas), o Nmap irá fornecer uma URL onde você
      poderá enviar a identificação se souber (com certeza) o SO em execução
      na máquina. Fazendo isso, você contribui para a gama de sistemas
      operacionais conhecidos pelo Nmap e, com isso, ele será mais preciso
      para todos.</para>

      <para>A detecção de SO habilita diversos outros testes que usam as
      informações coletadas durante o processo. Um deles é a medição de
      uptime, que utiliza a opção timestamp do TCP (RFC 1323) para supor
      quando uma máquina foi reiniciada pela última vez. Isso apenas é
      mostrado para as máquinas que fornecem essa informação. Outro é a
      Classificação de Previsibilidade da Seqüencia do TCP. Ele mede
      aproximadamente o grau de dificuldade de se estabelecer uma conexão TCP
      forjada contra um host remoto. É útil para se explorar relações de
      confiança baseadas no IP de origem (rlogin, filtros de firewall, etc.)
      ou para ocultar a origem de um ataque. Esse tipo de enganação (spoofing)
      raramente é executada hoje em dia, mas muitas máquinas ainda estão
      vulneráveis a ele. O número de dificuldade real é baseado em amostragens
      estatísticas e pode variar. Normalmente é melhor usar a classificação em
      inglês, do tipo <quote>worthy challenge</quote> (um desafio que vale a
      pena) ou <quote>trivial joke</quote> (uma piada, muito fácil). Isso só é
      mostrado na saída normal do modo verbose (<option>-v</option>). Quando o
      modo verbose é habilitado juntamente com o <option>-O</option>, a
      Geração de Seqüencia IPID também é mostrada. A maioria das máquinas é
      classificada como <quote>incremental</quote> , o que significa que elas
      incrementam o campo ID no cabeçalho IP para cada pacote que envia. Isso
      torna-as vulnerável a diversos ataques avançados de levantamento e
      forjamento de informações.</para>

      <para>Um trabalho documentando o funcionamento, utilização e
      customização da detecção de SO está disponível em mais de uma dezena de
      línguas em <ulink url="http://insecure.org/nmap/osdetect/" />.</para>

      <para>A detecção de SO é habilitada e controlada com as seguintes
      opções:</para>

      <variablelist>
        <varlistentry>
          <term><option>-O</option> (Habilita a detecção de SO)</term>

          <listitem>
            <indexterm significance="normal">
              <primary>-O</primary>
            </indexterm>

            <para>Habilita a deteção de SO, como discutido acima.
            Alternativamente, você pode usar <option>-A</option> para
            habilitar tanto a detecção de SO quanto a detecção de
            versão.</para>
          </listitem>
        </varlistentry>

        <varlistentry>
          <term><option>--osscan-limit</option> (Limitar a detecção de SO a
          alvos promissores)</term>

          <listitem>
            <indexterm significance="normal">
              <primary>--osscan-limit</primary>
            </indexterm>

            <para>A detecção de SO é bem mais eficiente se ao menos uma porta
            TCP aberta e uma fechada for encontrada. Escolha esta opção e o
            Nmap não irá nem tentar a detecção de SO contra hosts que não
            correspondam a este critério. Isso pode economizar um tempo
            considerável, particularmente em scans <option>-P0</option> contra
            muitos hosts. Isso só importa quando a detecção de SO é solicitada
            através de <option>-O</option> ou <option>-A</option>.</para>
          </listitem>
        </varlistentry>

        <varlistentry>
          <term><option>--osscan-guess</option>; <option>--fuzzy</option>
          (Resultados de tentativas de detecção de SO)</term>

          <listitem>
            <indexterm significance="normal">
              <primary>--osscan-guess</primary>
            </indexterm>

            <para>Quano o Nmap não é capaz de detectar uma correspondência
            exata de SO, às vezes ele oferece possibilidades aproximada. A
            correspondência tem que ser muito próxima para o Nmap fazer isso
            por padrão. Qualquer uma dessas opções (equivalentes) tornam as
            tentativas do Nmap mais agressivas. O Nmap ainda assim irá dizer
            quando uma correspondência imperfeita é mostrada e o nível de
            confiança (porcentagem) de cada suposição.</para>
          </listitem>
        </varlistentry>
      </variablelist>
    </refsect1>

    <refsect1 id="man-performance">
      <title>Temporização (Timing) e Desempenho</title>

      <para>Uma das minhas prioridades mais altas no desenvolvimento do Nmap
      tem sido o desempenho. Um scan padrão (<command>nmap
      <replaceable>hostname</replaceable></command>) de um host em minha rede
      local leva apenas um quinto de segundo. Isso mal dá tempo de piscar o
      olho, mas esse tempo aumenta conforme você está escaneando dezenas ou
      centenas de milhares de hosts. Além disso, certos tipos de scan, como o
      escaneamento UDP ou a detecção de versão, aumentam o tempo de
      escaneamento substancialmente. Da mesma forma algumas configurações de
      firewall fazem o mesmo, particularmente quando limitam a taxa de
      resposta. Embora o Nmap se utilize de paralelismo e muitos outros
      algoritmos avançados para acelerar esses scans, o usuário tem o controle
      final sobre como o Nmap executa. Usuários avançados elaboram comandos do
      Nmap cuidadosamente para obter apenas as informações que importam,
      sempre se preocupando com as restrições de tempo.</para>

      <para>Técnicas para melhorar os tempos de scan incluem omitir testes
      não-críticos e atualizar até a versão mais recente do Nmap (melhorias de
      desempenho são feitas freqüentemente). Otimizar os parâmetros de tempo
      também podem fazer uma grande diferença. Essas opções estão listadas
      abaixo.</para>

      <para>Algumas opções aceitam um parâmetro de <literal
      moreinfo="none">tempo</literal>. É especificado em milissegundos por
      padrão, embora você possa acrescentar ‘s’, ‘m’ ou ‘h’ ao valor para
      especificar segundos, minutos ou horas. Dessa forma, os argumentos
      <option>--host-timeout</option> arguments <literal
      moreinfo="none">900000</literal>, <literal
      moreinfo="none">900s</literal> e <literal moreinfo="none">15m</literal>
      fazem a mesma coisa.</para>

      <variablelist>
        <varlistentry>
          <term><option>--min-hostgroup &lt;númerodehosts&gt;</option>;
          <option>--max-hostgroup &lt;númerodehosts&gt;</option> (Ajuste dos
          tamanhos dos grupos de scan paralelos)</term>

          <listitem>
            <indexterm significance="normal">
              <primary>--min-hostgroup</primary>
            </indexterm>

            <indexterm significance="normal">
              <primary>--max-hostgroup</primary>
            </indexterm>

            <para>O Nmap tem a habilidade de fazer um scan de portas ou de
            versões em múltiplos hosts em paralelo. O Nmap faz isso dividindo
            a faixa de endereços IP-alvo em grupos, e então escaneando um
            grupo de cada vez. No geral, grupos maiores são mais eficientes. A
            contrapartida é que os resultados dos hosts não pode ser fornecido
            até que o grupo inteiro tenha terminado. Portanto, se o Nmap
            começou com um tamanho de grupo igual a 50, o usuário não
            receberia nenhum relatório (exceto pelas atualizações mostradas no
            modo verbose) até que os primeiros 50 hosts tivessem
            completado.</para>

            <para>Por padrão, o Nmap assume um compromisso para resolver esse
            conflito. Ele começa com um tamanho de grupo pequeno, igual a
            cinco, para que os primeiros resultados venham rápido, e então
            aumenta o tamanho até que chegue em 1024. O número padrão exato
            depende das opções fornecidas. Por questões de eficiência, o Nmap
            usa tamanhos de grupo maiores para o UDP ou para scans TCP com
            poucas portas.</para>

            <para>Quando o tamanho de grupo máximo é especificado com
            <option>--max-hostgroup</option>, o Nmap nunca irá exceder esse
            tamanho. Especifique um tamanho mínimo com
            <option>--min-hostgroup</option> e o Nmap irá tentar manter o
            tamanho dos grupos acima desse nível. O Nmap pode ter que usar
            tamanhos menores do que você especificou, se não houverem
            hosts-alvo suficientes restantes em uma dada interface, para
            completar o mínimo especificado. Ambos podem ser configurados para
            manter o tamanho do grupo dentro de uma faixa específica, embora
            isso raramente seja desejado.</para>

            <para>O uso primário destas opções é especificar um tamanho de
            grupo mínimo grande de forma que o scan completo rode mais
            rapidamente. Uma escolha comum é 256 para escanear uma rede em
            blocos de tamanho Classe C. Para um scan com muitas portas,
            exceder esse número não irá ajudar muito. Para scans com poucos
            números de portas, um tamanho de grupo de hosts de 2048 ou mais
            pode ser útil.</para>
          </listitem>
        </varlistentry>

        <varlistentry>
          <term><option>--min-parallelism &lt;numprobes&gt;</option>;
          <option>--max-parallelism &lt;numprobes&gt;</option> (Ajuste da
          paralelização das sondagens)</term>

          <listitem>
            <indexterm significance="normal">
              <primary>--min-parallelism</primary>
            </indexterm>

            <indexterm significance="normal">
              <primary>--max-parallelism</primary>
            </indexterm>

            <para>Estas opções controlam o número total de sondagens que podem
            estar pendentes para um grupo de hosts. Elas são usadas para o
            escaneamento de portas e para a descoberta de hosts. Por padrão, o
            Nmap calcula um paralelismo ideal e constantemente atualizado
            baseado no desempenho da rede. Se os pacotes estiverem sendo
            descartados, o Nmap reduz o ritmo e libera menos sondagens
            pendentes. O número de sondagens ideal aumenta vagarosamente
            conforme a rede se mostre mais confiável. Estas opções estabelecem
            limites mínimo e máximo nessa variável. Por padrão, o paralelismo
            ideal pode cair até 1 se a rede se mostrar não-confiável e subir
            até diversas centenas em condições perfeitas.</para>

            <para>O uso mais comum é estabelecer
            <option>--min-parallelism</option> em um número maior que 1 para
            melhorar a velocidade dos scans de hosts ou redes com desempenho
            ruim. Esta é uma opção arriscada para se ficar brincando pois
            configurar um valor alto demais pode afetar a precisão. Configurar
            isso também reduz a habilidade do Nmap de controlar o paralelismo
            dinamicamente baseado nas condições da rede. Um valor igual a dez
            pode ser razoável, embora eu só ajuste esse valor como última
            alternativa.</para>

            <para>A opção <option>--max-parallelism</option> às vezes é
            configurada para evitar que o Nmap envie aos hosts mais do que uma
            sondagem por vez. Isso pode ser útil em conjunto com
            <option>--scan-delay</option> (discutido mais tarde), embora esta
            última normalmente sirva bem ao propósito por si só.</para>
          </listitem>
        </varlistentry>

        <varlistentry>
          <term><option>--min-rtt_timeout &lt;tempo&gt;</option>,
          <option>--max_rtt-timeout &lt;tempo&gt;</option>,
          <option>--initial-rtt-timeout &lt;tempo&gt;</option> (Ajuste de
          tempo de expiração (timeouts) das sondagens)</term>

          <listitem>
            <indexterm significance="normal">
              <primary>--min-rtt-timeout</primary>
            </indexterm>

            <indexterm significance="normal">
              <primary>--max-rtt-timeout</primary>
            </indexterm>

            <indexterm significance="normal">
              <primary>--initial-rtt-timeout</primary>
            </indexterm>

            <para>O Nmap mantém um valor de tempo de expiração (timeout) de
            execução para determinar quanto tempo ele deve esperar por uma
            resposta de uma sondagem antes de desistir ou retransmitir essa
            sondagem. Isso é calculado com base nos tempos de resposta de
            sondagens anteriores. Se a latência da rede se mostrar
            significativa e variável, esse tempo de expiração pode subir para
            diversos segundos. Ele também começa com um nível conservador
            (alto) e pode ficar desse jeito por um tempo, enquanto o Nmap
            escaneia hosts não-responsivos.</para>

            <para>Especificar valores <option>--max-rtt-timeout</option> e
            <option>--initial-rtt-timeout</option> mais baixos que o padrão
            pode reduzir o tempo de scan significativamente. Isso é
            particularmente verdadeiro para scans sem ping
            (<option>-P0</option>), e para aqueles contra redes bastante
            filtradas. Mas não se torne muito agressivo. O scan pode acabar
            levando mais tempo se você especificar um valor tão baixo que
            muitas sondagens irão expirar o tempo e serem retransmitidas
            enquanto a resposta ainda está em trânsito.</para>

            <para>Se todos os hosts estão em uma rede local, 100 milissegundos
            é um valor de <option>--max-rtt-timeout</option> razoavelmente
            agressivo. Se houver roteamento envolvido, faça um ping de um host
            da rede primeiro com o utilitário ICMP ping, ou com um formatador
            de pacotes customizados como o hping2, que pode passar por um
            firewall mais facilmente. Descubra o tempo máximo de round trip em
            dez pacotes, mais ou menos. Coloque o dobro desse valor em
            <option>--initial-rtt-timeout</option> e o triplo ou quádruplo
            para o <option>--max-rtt-timeout</option>. Normalmente eu não
            configuro o rtt máximo abaixo de 100ms, não importa quais os
            tempos de ping. Eu também não excedo o valor 1000ms.</para>

            <para><option>--min-rtt-timeout</option> é uma opção raramente
            utilizada que poderia ser útil quando uma rede é tão não-confiável
            que mesmo o padrão do Nmap é muito agressivo. Considerando que o
            Nmap apenas reduz o tempo de expiração para um valor mínimo quando
            a rede parece ser confiável, esta necessidade não é comum e
            deveria ser reportada à lista de discussão nmap-dev como um
            bug.</para>
          </listitem>
        </varlistentry>

        <varlistentry>
          <term><option>--max-retries &lt;númerodetentativas&gt;</option>
          (Especifica o número máximo de retransmissões de sondagens de scan
          de portas)</term>

          <listitem>
            <indexterm significance="normal">
              <primary>--max-retries</primary>
            </indexterm>

            <para>Quando o Nmap não recebe nenhuma resposta a uma sondagem de
            escaneamento de portas, isso pode significar que a porta está
            filtrada. Ou talvez a sondagem ou a resposta simplesmente se
            perdeu na rede. Também é possível que o host-alvo tenha habilitado
            uma limitação de tráfego que tenha bloqueado temporariamente a
            resposta. Então o Nmap tenta novamente retransmitindo a sondagem
            inicial. Se o Nmap perceber que a confiabilidade da rede está
            baixa, ele poderá tentar muitas vezes ainda, antes de desistir de
            uma porta. Embora isso beneficie a exatidão, isso também aumenta o
            tempo de escaneamento. Quando o desempenho é crítico, os
            escaneamentos podem ser acelerados através da limitação do número
            de retransmissões permitidas. Você pode até especificar
            <option>--max-retries 0</option> para evitar qualquer
            retransmissão, embora isto seja raramente recomendado.</para>

            <para>O normal (sem nenhum padrão <option>-T</option>) é permitir
            dez retransmissões. Se a rede aparentar ser confiável e os
            hosts-alvo não estiverem limitando o tráfego, o Nmap normalmente
            fará apenas uma retransmissão. Portanto, a maioria dos
            escaneamentos de alvos não serão sequer afetados com a redução do
            <option>--max-retries</option> para um valor baixo, como por
            exemplo três. Tais valores podem acelerar significativamente o
            escaneamento de hosts lentos (com limitação de tráfego). Você
            normalmente perde alguma informação quando o Nmap desiste das
            portas rapidamente, embora isso seja preferível a permitir que o
            <option>--host-timeout</option> expire e você perca todas as
            informações sobre o alvo.</para>
          </listitem>
        </varlistentry>

        <varlistentry>
          <term><option>--host-timeout &lt;tempo&gt;</option> (Desiste de
          hosts-alvo lentos)</term>

          <listitem>
            <indexterm significance="normal">
              <primary>--host-timeout</primary>
            </indexterm>

            <para>Alguns hosts simplesmente levam tempo
            <emphasis>demais</emphasis> para serem escaneados. Isso pode ser
            causado por um hardware ou software de rede com fraco desempenho
            ou pouco confiável, limitação na taxa dos pacotes ou por um
            firewall restritivo. Os poucos hosts mais lentos de todos os hosts
            escaneados podem acabar sendo responsáveis pela maior parte do
            tempo total gasto com o scan. Às vezes é melhor cortar fora o
            prejuízo e pular esses hosts logo no início. Especifique a opção
            <option>--host-timeout</option> com o valor máximo de tempo que
            você tolera esperar. Eu normalmente especifico <literal
            moreinfo="none">30m</literal> para ter certeza de que o Nmap não
            gaste mais do que meia hora em um único host. Note que o Nmap pode
            estar escaneando outros hosts ao mesmo tempo em que essa meia hora
            desse único host está correndo, então não é uma perda de tempo
            total. Um host que expira o tempo é pulado. Nenhum resultado de
            tabela de portas, detecção de SO ou detecção de versão é mostrado
            para esse host.</para>
          </listitem>
        </varlistentry>

        <varlistentry>
          <term><option>--scan-delay &lt;tempo&gt;</option>;
          <option>--max-scan-delay &lt;tempo&gt;</option> (Ajusta o atraso
          entre sondagens)</term>

          <listitem>
            <indexterm significance="normal">
              <primary>--scan-delay</primary>
            </indexterm>

            <indexterm significance="normal">
              <primary>--max-scan-delay</primary>
            </indexterm>

            <para>Esta opção faz com que o Nmap aguarde um tempo determinado
            entre cada sondagem enviada a um dado host. Isto é particularmente
            útil no caso de limitação de taxas de transferência. Máquinas
            Solaris (entre muitas outras) irão normalmente responder à pacotes
            de sondagens de scans UDP com apenas uma mensagem ICMP por
            segundo. Qualquer número maior que isso, enviado pelo Nmap, será
            um desperdício. Um <option>--scan-delay</option> de <literal
            moreinfo="none">1s</literal> irá manter uma taxa de transferência
            baixa. O Nmap tenta detectar a limitação de taxa e ajusta o atraso
            no scan de acordo, mas não dói especificar explicitamente se você
            já sabe qual a taxa que funciona melhor.</para>

            <para>Quando o Nmap ajusta o atraso no scan aumentando para tentar
            igualar com a limitação na taxa de transferência, o scan fica
            consideravelmente mais lento. A opção
            <option>--max-scan-delay</option> especifica o maior atraso que o
            Nmap irá permitir. Estabelecer um valor muito baixo pode levar à
            uma retransmissão de pacotes inútil e à possíveis portas perdidas,
            quando o alvo utiliza limitação rígida de taxa de
            transferência.</para>

            <para>Outro uso do <option>--scan-delay</option> é para evitar os
            sistemas de prevenção e detecção de intrusão (IDS/IPS) baseados em
            limites.</para>
          </listitem>
        </varlistentry>

        <varlistentry>
          <term>
            <option>--defeat-rst-ratelimit</option>
          </term>

          <listitem>
            <indexterm significance="normal">
              <primary>--defeat-rst-ratelimit</primary>
            </indexterm>

            <para>Muitos hosts usam há bastante tempo a limitação de taxa de
            transferência para reduzir o número de mensagens de erro ICMP
            (tais como os erros de porta-inalcançavel) enviados. Alguns
            sistemas agora aplicam limitações de taxa similares aos pacotes
            RST (reset) que eles geram. Isso pode tornar o Nmap
            consideravelmente mais lento pois o obriga a ajustar seu tempo de
            forma a refletir essas limitações de taxa. Você pode dizer ao Nmap
            para ignorar essas limitações de taxa (para scans de porta como o
            Scan SYN que <emphasis>não</emphasis> trata portas que não
            respondem como <literal moreinfo="none">abertas</literal>)
            especificando <option>--defeat-rst-ratelimit</option>.</para>

            <para>Utilizar esta opção pode reduzir a precisão, pois algumas
            portas irão aparecer como não-respondendo porque o Nmap não
            esperou tempo suficiente para uma resposta RST com taxa limitada.
            No caso de um scan SYN, o "não-respondendo" resulta na porta sendo
            rotulada como <literal moreinfo="none">filtrada</literal> ao invés
            de no estado <literal moreinfo="none">fechada</literal> que vemos
            quando os pacotes RST são recebidos. Esta opção é útil quando você
            se importa apenas com as portas abertas e distinguir entre
            portas<literal moreinfo="none">fechadas</literal> e <literal
            moreinfo="none">filtradas</literal> não vale o tempo extra.</para>
          </listitem>
        </varlistentry>

        <varlistentry>
          <term><option>-T
          &lt;Paranoid|Sneaky|Polite|Normal|Aggressive|Insane&gt;</option>
          (Estabelece um padrão de temporização)</term>

          <listitem>
            <indexterm significance="normal">
              <primary>--T</primary>
            </indexterm>

            <para>Embora os controles de temporização de ajuste fino
            discutidos nas seções anteriores sejam poderosos e efetivos,
            algumas pessoas os consideram confusos. Ainda mais, escolher os
            valores apropriados pode, às vezes, tomar mais tempo do que o
            próprio scan que você está tentando otimizar. Por isso, o Nmap
            oferece uma aproximação mais simples, com seis padrões de
            temporização. Você pode especificá-los com a opção
            <option>-T</option> e os números (0 - 5) ou os nomes. Os nomes de
            padrões são paranóico (paranoid, 0), furtivo (sneaky, 1), educado
            (polite, 2), normal (3), agressivo (agressive, 4) e insano
            (insane, 5). Os dois primeiros são para evitar um IDS. O modo
            educado (ou polido), diminui o ritmo de escaneamento para usar
            menos banda e recursos da máquina alvo. O modo normal é o padrão
            e, portanto, <option>-T3</option> não faz nada. O modo agressivo
            acelera os scans assumindo que você está em uma rede razoavelmente
            rápida e confiável. Finalmente, o modo insano assume que você está
            em uma rede extraordinariamente rápida ou está disposto a
            sacrificar alguma precisão pela velocidade.</par