Introducció a Tcpdump

Introducció a Tcpdump

Si feu servir un servidor, sens dubte arribareu a un punt en què haureu de resoldre alguns problemes relacionats amb la xarxa. Per descomptat, seria fàcil enviar un correu al departament d'assistència, però de vegades cal embrutar-se les mans. En aquest cas, tcpdumpés l'eina per a aquesta feina. Tcpdump és un analitzador de paquets de xarxa que s'executa sota la línia d'ordres.

Aquest article es dividirà en tres parts:

  • Característiques bàsiques.
  • Filtrat en funció de determinades característiques del trànsit.
  • Un breu fragment de les funcions més avançades (com ara expressions lògiques, filtratge per senyaladors TCP).

Com que tcpdump no s'inclou a la majoria de sistemes bàsics, haureu d'instal·lar-lo. Tanmateix, gairebé totes les distribucions de Linux tenen tcpdump als seus repositoris bàsics. Per a les distribucions basades en Debian, l'ordre per instal·lar tcpdump és:

apt-get install tcpdump

Per a CentOS/RedHat, utilitzeu l'ordre següent:

yum install tcpdump

FreeBSD ofereix un paquet preconstruït que es pot instal·lar emetent:

pkg install tcpdump

També hi ha un port disponible, net/tcpdumpque es pot instal·lar mitjançant:

cd /usr/ports/net/tcpdump
make install clean

Si corres tcpdumpsense cap argument, et veuran maltractats amb resultats. Si l'executeu en una instància recentment creada aquí a Vultr durant menys de cinc segons, es donen els resultats següents:

2661 packets captured
2663 packets received by filter
0 packets dropped by kernel

Abans d'entrar en més detalls sobre com filtrar l'entrada, hauríeu de fer una ullada a alguns paràmetres que es poden passar a tcpdump:

  • -i- Especifica la interfície on voleu escoltar, per exemple: tcpdump -i eth0.
  • -n- No intenteu fer cerques inverses a les adreces IP, per exemple: tcpdump -n(si afegiu un altre ntcpdump us mostrarà números de port en lloc de noms).
  • -X- Mostra el contingut dels paquets recollits: tcpdump -X.
  • -c- Només captura xpaquets, xsent un nombre arbitrari, per exemple tcpdump -c 10captura exactament 10 paquets.
  • -v- Augmenta la quantitat d'informació del paquet que se't mostra, més vs afegeix més detall.

Cadascun d'aquests paràmetres esmentats aquí es poden combinar. Si volíeu capturar 100 paquets, però només a la vostra interfície VPN tun0, l'ordre tcpdump seria així:

tcpdump -i tun0 -c 100 -X

Hi ha desenes (si no centenars) d'opcions a més d'aquestes poques, però són les més habituals. No dubteu a llegir la pàgina de manual de tcpdump al vostre sistema.

Ara que teniu una comprensió bàsica de tcpdump, és hora de mirar una de les característiques més impressionants de tcpdump: les expressions. Les expressions et faran la vida molt més fàcil. També es coneixen com a filtres de paquets BPF o Berkeley. L'ús d'expressions us permet mostrar (o ignorar) paquets de manera selectiva en funció de determinades característiques, com ara l'origen, la destinació, la mida o fins i tot el número de seqüència TCP.

Fins ara, heu aconseguit limitar la cerca a una certa quantitat de paquets en una interfície determinada, però siguem sincers: això encara deixa massa soroll de fons per treballar eficaçment amb les dades recollides. És aquí on entren en joc les expressions. El concepte és bastant senzill, així que deixarem de banda la teoria seca aquí i donarem suport a la comprensió amb alguns exemples pràctics.

Les expressions que probablement utilitzareu més són:

  • host - Busqueu trànsit basat en noms d'amfitrió o adreces IP.
  • srco dst- Cerqueu trànsit des de o cap a un amfitrió específic.
  • proto- Cercar trànsit d'un protocol determinat. Funciona per a tcp, udp, icmp i altres. protoTambé és possible ometre la paraula clau.
  • net - Busqueu trànsit cap a / des d'un determinat rang d'adreces IP.
  • port - Busqueu trànsit cap a / des d'un port determinat.
  • greatero less- Cerqueu trànsit més gran o menor que una determinada quantitat de bytes.

Tot i que la pàgina de manual de tcpdumpnomés conté uns quants exemples, la pàgina de manual de pcap-filterté explicacions molt detallades sobre com funciona i es pot aplicar cada filtre.

Si voleu veure com va la vostra comunicació amb un determinat servidor, podeu utilitzar la hostparaula clau, per exemple (inclosos alguns dels paràmetres anteriors):

tcpdump -i eth0 host vultr.com

De vegades hi ha ordinadors a la xarxa que no respecten la MTU o us envien correu brossa amb paquets grans; filtrar-los pot ser difícil de vegades. Les expressions us permeten filtrar paquets que són més grans o més petits que un nombre determinat de bytes:

tcpdump -i eth0 -nn greater 128
or
tcpdump -i eth0 -nn less 32

Potser només un port determinat us interessa. En aquest cas, utilitzeu l' portexpressió:

tcpdump -i eth0 -X port 21

També podeu buscar els intervals de ports:

tcdump -i eth0 -X portrange 22-25

Com que les passarel·les NAT són força habituals, només podeu cercar ports de destinació:

tcpdump dst port 80

Si esteu observant el trànsit al vostre servidor web, és possible que només vulgueu mirar el trànsit TCP al port 80:

tcpdump tcp and dst port 80

Probablement us esteu preguntant què fa la paraula clau andallà. Bona pregunta. Això ens porta a l'última part d'aquest article.

tcpdump ofereix suport bàsic per a expressions lògiques, més concretament:

  • and/ &&- "i" lògic.
  • or/ ||- "o" lògic.
  • not/ !- "no" lògic.

Juntament amb la possibilitat d'agrupar expressions, això us permet crear cerques molt potents per al trànsit entrant i sortint. Per tant, filtrem el trànsit procedent de vultr.com al port 22 o 443:

tcpdump -i eth0 src host vultr.com and (dst port 22 or 443)

Si executeu això a la línia d'ordres, us donarà l'error següent:

bash: syntax error near unexpected token `('

Això és perquè hi ha una advertència: bashintenta avaluar tots els personatges que pugui. Això inclou els personatges (i ). Per evitar aquest error, hauríeu d'utilitzar cometes simples al voltant de l'expressió combinada:

tcpdump -i eth0 'src host vultr.com and (dst port 22 or 443)'

Un altre exemple útil: quan depureu problemes SSH amb un dels vostres usuaris, és possible que vulgueu ignorar tot el que està relacionat amb la vostra sessió SSH:

tcpdump '!(host $youripaddress) && port 22)'

De nou, els casos d'ús són infinits i podeu especificar a profunditats extremes quin tipus de trànsit voleu veure. L'ordre següent us mostraria només els paquets SYNACK d'una encaixada de mans TCP:

tcpdump -i eth0 'tcp[13]=18'

Això funciona mirant el tretzè desplaçament de la capçalera TCP i el divuitè byte que hi ha dins.

Si ho heu fet fins aquí, ja esteu preparat per a la majoria dels casos d'ús que es presentaran. Amb prou feines puc tocar la superfície sense entrar en massa detalls. Us recomano que experimenteu una mica més amb les diferents opcions i expressions; i com és habitual: fes referència a la pàgina de manual quan et perdis.

Per últim, però no menys important, una ràpida mirada enrere. Recordeu l'inici d'aquest article? Amb els milers de paquets capturats en qüestió de segons? El poder de tcpdumppot reduir-ho molt:

tcpdump -i eth0 tcp port 22

El resultat és ara:

81 packets captured
114 packets received by filter
0 packets dropped by kerne

Això és molt més lògic i més fàcil de depurar. Feliç treball en xarxa!


Instal·leu Plesk a CentOS 7

Instal·leu Plesk a CentOS 7

Utilitzeu un sistema diferent? Plesk és un tauler de control d'amfitrió web propietari que permet als usuaris administrar els seus llocs web personals i/o de clients, bases de dades

Instal·leu Lets Encrypt SSL a laplicació de WordPress dun sol clic

Instal·leu Lets Encrypt SSL a laplicació de WordPress dun sol clic

Introducció Lets Encrypt és un servei d'autoritat de certificació que ofereix certificats TLS/SSL gratuïts. El procés d'instal·lació està simplificat per Certbot,

Com configurar un servidor Tekkit Classic a Ubuntu 16.10

Com configurar un servidor Tekkit Classic a Ubuntu 16.10

Utilitzeu un sistema diferent? Què és Tekkit Classic? Tekkit Classic és un modpack per al joc que tothom coneix i estima; Minecraft. Conté algunes de la ver

Creació dun bloc Jekyll a Ubuntu 16.04

Creació dun bloc Jekyll a Ubuntu 16.04

Utilitzeu un sistema diferent? Jekyll és una gran alternativa a WordPress per crear blocs o compartir contingut. No requereix cap base de dades i és molt fàcil

Com configurar actualitzacions desateses a Debian 9 (Stretch)

Com configurar actualitzacions desateses a Debian 9 (Stretch)

Utilitzeu un sistema diferent? Si compres un servidor Debian, sempre hauríeu de tenir els darrers pedaços i actualitzacions de seguretat, tant si esteu adormit com si no.

Com instal·lar i configurar PHP 7.0 o PHP 7.1 a Ubuntu 16.04

Com instal·lar i configurar PHP 7.0 o PHP 7.1 a Ubuntu 16.04

PHP i els paquets relacionats són els components més utilitzats quan es desplega un servidor web. En aquest article, aprendrem a configurar PHP 7.0 o PHP 7.1 o

Com instal·lar Squid Proxy a CentOS

Com instal·lar Squid Proxy a CentOS

Squid és un popular programa Linux gratuït que us permet crear un servidor intermediari web de reenviament. En aquesta guia, veureu com instal·lar Squid a CentOS per convertir-vos-hi

Com instal·lar Lighttpd (LLMP Stack) a CentOS 6

Com instal·lar Lighttpd (LLMP Stack) a CentOS 6

Introducció Lighttpd és una bifurcació d'Apache destinada a ser molt menys intensiu en recursos. És lleuger, d'aquí el seu nom, i és bastant senzill d'utilitzar. Instal·lant

Tres panells de control de servidor gratuïts (instal·lació ràpida)

Tres panells de control de servidor gratuïts (instal·lació ràpida)

1. Virtualmin/Webmin Virtualmin és un tauler de control d'allotjament web potent i flexible per a sistemes Linux i UNIX basat en la coneguda base web de codi obert

Configuració duna aplicació Yii a Ubuntu 14.04

Configuració duna aplicació Yii a Ubuntu 14.04

Yii és un framework PHP que permet desenvolupar aplicacions de manera més ràpida i senzilla. Instal·lar Yii a Ubuntu és senzill, ja que aprendràs exactament

Ús de Screen a Ubuntu 14.04

Ús de Screen a Ubuntu 14.04

Screen és una aplicació que permet l'ús múltiple de sessions de terminal dins d'una finestra. Això us permet simular diverses finestres de terminal on es fa

Configura el teu propi servidor DNS a Debian/Ubuntu

Configura el teu propi servidor DNS a Debian/Ubuntu

Aquest tutorial explica com configurar un servidor DNS amb Bind9 a Debian o Ubuntu. Al llarg de l'article, substituïu el vostre-nom-domini.com en conseqüència. Al th

Ús de Logrotate per gestionar fitxers de registre

Ús de Logrotate per gestionar fitxers de registre

Introducció Logrotate és una utilitat Linux que simplifica l'administració dels fitxers de registre. Normalment s'executa un cop al dia mitjançant un treball cron i gestiona la base de registres

Configuració de xarxes estàtiques i IPv6 a CentOS 7

Configuració de xarxes estàtiques i IPv6 a CentOS 7

Recentment, VULTR ha fet canvis al seu extrem, i ara tot hauria de funcionar bé des de la caixa amb NetworkManager habilitat. Si voleu desactivar

Modificació dIcinga2 per utilitzar el model mestre/client a CentOS 6 o CentOS 7

Modificació dIcinga2 per utilitzar el model mestre/client a CentOS 6 o CentOS 7

Icinga2 és un sistema de supervisió potent i, quan s'utilitza en un model de client mestre, pot substituir la necessitat de controls de monitoratge basats en NRPE. El mestre-client

Configura Red5 Media Server a Ubuntu 16.04

Configura Red5 Media Server a Ubuntu 16.04

Utilitzeu un sistema diferent? Red5 és un servidor multimèdia de codi obert implementat a Java que us permet executar aplicacions Flash multiusuari com ara la transmissió en directe.

Compileu i instal·leu Nginx amb el mòdul PageSpeed ​​a Debian 8

Compileu i instal·leu Nginx amb el mòdul PageSpeed ​​a Debian 8

En aquest article, veurem com compilar i instal·lar la línia principal de Nginx des de les fonts oficials de Nginx amb el mòdul PageSpeed, que us permet

Com instal·lar Apache Cassandra 3.11.x a Ubuntu 16.04 LTS

Com instal·lar Apache Cassandra 3.11.x a Ubuntu 16.04 LTS

Utilitzeu un sistema diferent? Apache Cassandra és un sistema de gestió de bases de dades NoSQL gratuït i de codi obert dissenyat per proporcionar escalabilitat, alta

Com instal·lar Apache Cassandra 3.11.x a CentOS 7

Com instal·lar Apache Cassandra 3.11.x a CentOS 7

Utilitzeu un sistema diferent? Apache Cassandra és un sistema de gestió de bases de dades NoSQL gratuït i de codi obert dissenyat per proporcionar escalabilitat, alta

Com instal·lar Vanilla Forum a Ubuntu 16.04

Com instal·lar Vanilla Forum a Ubuntu 16.04

Utilitzeu un sistema diferent? Vanilla Forum és una aplicació de fòrum de codi obert escrita en PHP. És totalment personalitzable, fàcil d'utilitzar i admet externa

The Rise of Machines: Real World Applications of AI

The Rise of Machines: Real World Applications of AI

La Intel·ligència Artificial no està en el futur, és aquí mateix en el present. En aquest bloc Llegiu com les aplicacions d'Intel·ligència Artificial han afectat diversos sectors.

Atacs DDOS: una breu visió general

Atacs DDOS: una breu visió general

També ets víctima d'atacs DDOS i estàs confós sobre els mètodes de prevenció? Llegiu aquest article per resoldre les vostres consultes.

Us heu preguntat mai com guanyen diners els pirates informàtics?

Us heu preguntat mai com guanyen diners els pirates informàtics?

Potser haureu sentit que els pirates informàtics guanyen molts diners, però us heu preguntat mai com guanyen aquest tipus de diners? anem a discutir.

Invents revolucionaris de Google que us facilitaran la vida.

Invents revolucionaris de Google que us facilitaran la vida.

Vols veure els invents revolucionaris de Google i com aquests invents van canviar la vida de tots els éssers humans actuals? A continuació, llegiu al bloc per veure els invents de Google.

Divendres essencial: què va passar amb els cotxes impulsats per IA?

Divendres essencial: què va passar amb els cotxes impulsats per IA?

El concepte de cotxes autònoms per sortir a les carreteres amb l'ajuda de la intel·ligència artificial és un somni que tenim des de fa temps. Però malgrat les diverses promeses, no es veuen enlloc. Llegeix aquest blog per saber-ne més...

Singularitat tecnològica: un futur llunyà de la civilització humana?

Singularitat tecnològica: un futur llunyà de la civilització humana?

A mesura que la ciència evoluciona a un ritme ràpid, fent-se càrrec de molts dels nostres esforços, també augmenten els riscos de sotmetre'ns a una singularitat inexplicable. Llegeix, què pot significar per a nosaltres la singularitat.

Evolució de lemmagatzematge de dades – Infografia

Evolució de lemmagatzematge de dades – Infografia

Els mètodes d'emmagatzematge de les dades que han anat evolucionant poden ser des del naixement de les dades. Aquest bloc tracta l'evolució de l'emmagatzematge de dades a partir d'una infografia.

Funcionalitats de les capes darquitectura de referència de Big Data

Funcionalitats de les capes darquitectura de referència de Big Data

Llegeix el blog per conèixer de la manera més senzilla les diferents capes de l'Arquitectura Big Data i les seves funcionalitats.

6 avantatges sorprenents de tenir dispositius domèstics intel·ligents a les nostres vides

6 avantatges sorprenents de tenir dispositius domèstics intel·ligents a les nostres vides

En aquest món digital, els dispositius domèstics intel·ligents s'han convertit en una part crucial de les vides. A continuació, es mostren alguns avantatges sorprenents dels dispositius domèstics intel·ligents sobre com fan que la nostra vida valgui la pena i sigui més senzilla.

Lactualització del suplement de macOS Catalina 10.15.4 està causant més problemes que no pas solucions

Lactualització del suplement de macOS Catalina 10.15.4 està causant més problemes que no pas solucions

Recentment, Apple va llançar macOS Catalina 10.15.4, una actualització de suplements per solucionar problemes, però sembla que l'actualització està causant més problemes que provoquen el bloqueig de les màquines Mac. Llegiu aquest article per obtenir més informació