Introduktion till Tcpdump

Introduktion till Tcpdump

Om du kör en server kommer du utan tvekan att komma till en punkt där du behöver reda ut några nätverksrelaterade problem. Naturligtvis skulle det vara lätt att bara skicka ett mail till supportavdelningen, men ibland behöver man smutsa ner händerna. I det här fallet tcpdumpär verktyget för det jobbet. Tcpdump är en nätverkspaketanalysator som körs under kommandoraden.

Den här artikeln kommer att delas upp i tre delar:

  • Grundläggande funktioner.
  • Filtrering baserat på vissa trafikegenskaper.
  • Ett kort utdrag av de mer avancerade funktionerna (som logiska uttryck, filtrering med TCP-flaggor).

Eftersom tcpdump inte ingår i de flesta bassystem måste du installera det. Men nästan alla Linux-distributioner har tcpdump i sina kärnlager. För Debianbaserade distributioner är kommandot för att installera tcpdump:

apt-get install tcpdump

För CentOS/RedHat, använd följande kommando:

yum install tcpdump

FreeBSD erbjuder ett förbyggt paket som kan installeras genom att utfärda:

pkg install tcpdump

Det finns också en port tillgänglig, net/tcpdumpsom kan installeras via:

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

Om du kör tcpdumputan några argument, kommer du att bli misshandlad med resultat. Att köra den på en nyuppspelad instans här på Vultr i mindre än fem sekunder ger följande resultat:

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

Innan du går in på mer detaljer om hur du filtrerar indata, bör du ta en titt på några parametrar som kan skickas till tcpdump:

  • -i- Anger vilket gränssnitt du vill lyssna på, till exempel: tcpdump -i eth0.
  • -n- Försök inte göra omvända sökningar på IP-adresser, till exempel: tcpdump -n(om du lägger till en annan nkommer tcpdump att visa dig portnummer istället för namn).
  • -X- Visa innehållet i de insamlade paketen: tcpdump -X.
  • -c- Endast fånga xpaket, som xär ett godtyckligt nummer, tcpdump -c 10fångar till exempel exakt 10 paket.
  • -v- Öka mängden paketinformation du visas, fler vs lägg till mer utförlighet.

Var och en av de parametrar som nämns här kan kombineras. Om du ville fånga 100 paket, men bara på ditt VPN-gränssnitt tun0, skulle tcpdump-kommandot se ut så här:

tcpdump -i tun0 -c 100 -X

Det finns dussintals (om inte hundratals) alternativ utöver de få, men de är de vanligaste. Läs gärna tcpdumps manpage på ditt system.

Nu när du har en grundläggande förståelse för tcpdump är det dags att titta på en av tcpdumps mest fantastiska funktioner: uttryck. Uttryck kommer att göra ditt liv mycket enklare. De är också kända som BPF eller Berkeley Packet Filter. Genom att använda uttryck kan du selektivt visa (eller ignorera) paket baserat på vissa egenskaper - såsom ursprung, destination, storlek eller till och med TCP-sekvensnummer.

Hittills har du lyckats begränsa din sökning till en viss mängd paket på ett visst gränssnitt, men låt oss vara ärliga här: det lämnar fortfarande för mycket bakgrundsljud för att effektivt kunna arbeta med den insamlade datan. Det är där uttryck spelar in. Konceptet är ganska okomplicerat, så vi utelämnar den torra teorin här och stödjer förståelsen med några praktiska exempel.

De uttryck som du förmodligen kommer att använda mest är:

  • host - Leta efter trafik baserat på värdnamn eller IP-adresser.
  • srceller dst- Leta efter trafik från eller till en specifik värd.
  • proto- Leta efter trafik av ett visst protokoll. Fungerar för tcp, udp, icmp och andra. Att utelämna protonyckelordet är också möjligt.
  • net - Leta efter trafik till/från ett visst antal IP-adresser.
  • port - Leta efter trafik till/från en viss hamn.
  • greatereller less- Leta efter trafik som är större eller mindre än en viss mängd byte.

Även om mansidan för tcpdumpbara innehåller några få exempel, har mansidan för pcap-filtermycket detaljerade förklaringar om hur varje filter fungerar och kan tillämpas.

Om du vill se hur din kommunikation med en viss server går kan du till exempel använda hostnyckelordet (inklusive några av parametrarna ovan):

tcpdump -i eth0 host vultr.com

Ibland finns det datorer i nätverket som inte hedrar MTU:n eller spammar dig med stora paket; att filtrera bort dem kan ibland vara svårt. Med uttryck kan du filtrera bort paket som är större eller mindre än ett visst antal byte:

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

Kanske bara en viss hamn är av intresse för dig. Använd i det här fallet portuttrycket:

tcpdump -i eth0 -X port 21

Du kan också hålla utkik efter portintervall:

tcdump -i eth0 -X portrange 22-25

Eftersom NAT-gateways är ganska vanliga, kan du bara leta efter destinationsportar:

tcpdump dst port 80

Om du tittar på trafik till din webbserver kanske du bara vill titta på TCP-trafik till port 80:

tcpdump tcp and dst port 80

Du frågar dig förmodligen vad sökordet andgör där. Bra fråga. Det för oss till den sista delen av denna artikel.

tcpdump erbjuder grundläggande stöd för logiska uttryck, mer specifikt:

  • and/ &&- Logiskt "och".
  • or/ ||- Logiskt "eller".
  • not/ !- Logiskt "inte".

Tillsammans med möjligheten att gruppera uttryck gör detta att du kan skapa mycket kraftfulla sökningar efter inkommande och utgående trafik. Så låt oss filtrera bort trafik som kommer från vultr.com på port 22 eller 443:

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

Om du kör detta på kommandoraden får du följande fel:

bash: syntax error near unexpected token `('

Det beror på att det finns en varning: bashförsöker utvärdera varje karaktär den kan. Detta inkluderar (och )tecken. För att undvika det felet bör du använda enstaka citattecken runt det kombinerade uttrycket:

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

Ett annat användbart exempel: När du felsöker SSH-problem med en av dina användare, kanske du vill ignorera allt som är relaterat till din SSH-session:

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

Återigen, användningsfallen är oändliga, och du kan specificera i extrema djup vilken typ av trafik du vill se. Följande kommando skulle bara visa dig SYNACK-paket av en TCP-handskakning:

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

Detta fungerar genom att titta på den trettonde förskjutningen av TCP-huvudet och den artonde byten i den.

Om du har tagit dig hela vägen hit är du redo för de flesta användningsfall som kommer att dyka upp. Jag kan knappt röra ytan utan att gå in på för många detaljer. Jag rekommenderar starkt att du experimenterar med de olika alternativen och uttrycken lite längre; och som vanligt: ​​referera till manpagen när du går vilse.

Sist men inte minst – en snabb tillbakablick. Kommer du ihåg början av den här artikeln? Med de tusentals paket som fångats på några sekunder? Kraften i tcpdumpkan trimma ner det en hel del:

tcpdump -i eth0 tcp port 22

Resultatet är nu:

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

Detta är mycket sundare och lättare att felsöka. Glad nätverkande!


Installera Plesk på CentOS 7

Installera Plesk på CentOS 7

Använder du ett annat system? Plesk är en egen kontrollpanel för webbhotell som tillåter användare att administrera sina personliga och/eller klienters webbplatser, databaser

Installera Cacti på Debian Jessie

Installera Cacti på Debian Jessie

Introduktion Cacti är ett övervaknings- och grafverktyg med öppen källkod som är helt baserat på RRD-data. Genom Cacti kan du övervaka nästan vilken typ av enhet som helst

Installera Lets Encrypt SSL på One-Click WordPress-appen

Installera Lets Encrypt SSL på One-Click WordPress-appen

Introduktion Lets Encrypt är en certifikatmyndighetstjänst som erbjuder gratis TLS/SSL-certifikat. Installationsprocessen förenklas av Certbot,

Hur man ställer in en Tekkit Classic-server på Ubuntu 16.10

Hur man ställer in en Tekkit Classic-server på Ubuntu 16.10

Använder du ett annat system? Vad är Tekkit Classic? Tekkit Classic är ett modpack för spelet som alla känner och älskar; Minecraft. Den innehåller några av ver

Konfigurera iRedMail på Debian Wheezy

Konfigurera iRedMail på Debian Wheezy

Använder du ett annat system? Den här handledningen visar dig hur du installerar groupware iRedMail på en ny installation av Debian Wheezy. Du bör använda en serve

Hur man installerar och konfigurerar PHP 7.0 eller PHP 7.1 på Ubuntu 16.04

Hur man installerar och konfigurerar PHP 7.0 eller PHP 7.1 på Ubuntu 16.04

PHP och relaterade paket är de mest använda komponenterna när du distribuerar en webbserver. I den här artikeln kommer vi att lära oss hur du ställer in PHP 7.0 eller PHP 7.1 o

Hur man installerar Squid Proxy på CentOS

Hur man installerar Squid Proxy på CentOS

Squid är ett populärt, gratis Linux-program som låter dig skapa en webbproxy för vidarebefordran. I den här guiden ser du hur du installerar Squid på CentOS för att förvandla dig

Hur man installerar Lighttpd (LLMP Stack) på CentOS 6

Hur man installerar Lighttpd (LLMP Stack) på CentOS 6

Inledning Lighttpd är en apachegaffel som syftar till att vara mycket mindre resurskrävande. Den är lätt, därav namnet, och är ganska enkel att använda. Installera

Tre gratis serverkontrollpaneler (snabbinstallation)

Tre gratis serverkontrollpaneler (snabbinstallation)

1. Virtualmin/Webmin Virtualmin är en kraftfull och flexibel kontrollpanel för webbhotell för Linux- och UNIX-system baserad på den välkända Open Source-webbasen

Konfigurera en Yii-applikation på Ubuntu 14.04

Konfigurera en Yii-applikation på Ubuntu 14.04

Yii är ett PHP-ramverk som låter dig utveckla applikationer snabbare och enklare. Att installera Yii på Ubuntu är enkelt, eftersom du kommer att lära dig exakt

Använder skärmen på Ubuntu 14.04

Använder skärmen på Ubuntu 14.04

Screen är ett program som tillåter flera terminalsessioner inom ett fönster. Detta låter dig simulera flera terminalfönster där det ma

Konfigurera din egen DNS-server på Debian/Ubuntu

Konfigurera din egen DNS-server på Debian/Ubuntu

Denna handledning förklarar hur man ställer in en DNS-server med Bind9 på Debian eller Ubuntu. Genomgående i artikeln, byt ut ditt-domännamn.com i enlighet med detta. Vid th

Använda Logrotate för att hantera loggfiler

Använda Logrotate för att hantera loggfiler

Inledning Logrotate är ett Linux-verktyg som förenklar administrationen av loggfiler. Den körs vanligtvis en gång om dagen via ett cron-jobb och hanterar loggbasen

Konfigurera statiskt nätverk och IPv6 på CentOS 7

Konfigurera statiskt nätverk och IPv6 på CentOS 7

VULTR har nyligen gjort ändringar på deras sida, och allt borde nu fungera bra direkt när NetworkManager är aktiverat. Om du vill inaktivera

Ändra Icinga2 för att använda Master/Client Model på CentOS 6 eller CentOS 7

Ändra Icinga2 för att använda Master/Client Model på CentOS 6 eller CentOS 7

Icinga2 är ett kraftfullt övervakningssystem, och när det används i en master-klient-modell kan det ersätta behovet av NRPE-baserade övervakningskontroller. Master-klienten

Konfigurera Red5 Media Server på Ubuntu 16.04

Konfigurera Red5 Media Server på Ubuntu 16.04

Använder du ett annat system? Red5 är en mediaserver med öppen källkod implementerad i Java som låter dig köra Flash fleranvändarapplikationer som livestreamin

Kompilera och installera Nginx med PageSpeed-modulen på Debian 8

Kompilera och installera Nginx med PageSpeed-modulen på Debian 8

I den här artikeln kommer vi att se hur man kompilerar och installerar Nginx mainline från de officiella källorna för Nginx med PageSpeed-modulen, som låter dig t

Hur man installerar Apache Cassandra 3.11.x på Ubuntu 16.04 LTS

Hur man installerar Apache Cassandra 3.11.x på Ubuntu 16.04 LTS

Använder du ett annat system? Apache Cassandra är ett gratis NoSQL-databashanteringssystem med öppen källkod som är designat för att ge skalbarhet, hög

Hur man installerar Apache Cassandra 3.11.x på CentOS 7

Hur man installerar Apache Cassandra 3.11.x på CentOS 7

Använder du ett annat system? Apache Cassandra är ett gratis NoSQL-databashanteringssystem med öppen källkod som är designat för att ge skalbarhet, hög

Hur man installerar Vanilla Forum på Ubuntu 16.04

Hur man installerar Vanilla Forum på Ubuntu 16.04

Använder du ett annat system? Vanilla forum är en open source forumapplikation skriven i PHP. Det är en helt anpassningsbar, enkel att använda och stöder externa

The Rise of Machines: Real World Applications of AI

The Rise of Machines: Real World Applications of AI

Artificiell intelligens är inte i framtiden, det är här i nuet I den här bloggen Läs hur Artificiell intelligens-applikationer har påverkat olika sektorer.

DDOS-attacker: En kort översikt

DDOS-attacker: En kort översikt

Är du också ett offer för DDOS-attacker och förvirrad över de förebyggande metoderna? Läs den här artikeln för att lösa dina frågor.

Har du någonsin undrat hur hackare tjänar pengar?

Har du någonsin undrat hur hackare tjänar pengar?

Du kanske har hört att hackare tjänar mycket pengar, men har du någonsin undrat hur de tjänar den typen av pengar? låt oss diskutera.

Revolutionerande uppfinningar från Google som gör ditt liv lätt.

Revolutionerande uppfinningar från Google som gör ditt liv lätt.

Vill du se revolutionerande uppfinningar av Google och hur dessa uppfinningar förändrade livet för varje människa idag? Läs sedan till bloggen för att se uppfinningar av Google.

Fredag ​​Essential: Vad hände med AI-drivna bilar?

Fredag ​​Essential: Vad hände med AI-drivna bilar?

Konceptet med att självkörande bilar ska ut på vägarna med hjälp av artificiell intelligens är en dröm vi har ett tag nu. Men trots flera löften finns de ingenstans att se. Läs den här bloggen för att lära dig mer...

Technological Singularity: A Distant Future of Human Civilization?

Technological Singularity: A Distant Future of Human Civilization?

När vetenskapen utvecklas i snabb takt och tar över en hel del av våra ansträngningar, ökar också riskerna för att utsätta oss för en oförklarlig singularitet. Läs, vad singularitet kan betyda för oss.

Utveckling av datalagring – Infographic

Utveckling av datalagring – Infographic

Lagringsmetoderna för data har utvecklats kan vara sedan födelsen av data. Den här bloggen tar upp utvecklingen av datalagring på basis av en infografik.

Funktioner för Big Data Reference Architecture Layers

Funktioner för Big Data Reference Architecture Layers

Läs bloggen för att känna till olika lager i Big Data Architecture och deras funktionaliteter på enklaste sätt.

6 fantastiska fördelar med att ha smarta hemenheter i våra liv

6 fantastiska fördelar med att ha smarta hemenheter i våra liv

I denna digitala värld har smarta hemenheter blivit en avgörande del av livet. Här är några fantastiska fördelar med smarta hemenheter om hur de gör vårt liv värt att leva och enklare.

macOS Catalina 10.15.4 tilläggsuppdatering orsakar fler problem än att lösa

macOS Catalina 10.15.4 tilläggsuppdatering orsakar fler problem än att lösa

Nyligen släppte Apple macOS Catalina 10.15.4, en tilläggsuppdatering för att åtgärda problem, men det verkar som om uppdateringen orsakar fler problem som leder till att mac-datorer blir murade. Läs den här artikeln för att lära dig mer