Inleiding tot Tcpdump

Als u een server draait, komt u ongetwijfeld op een punt waar u enkele netwerkgerelateerde problemen moet oplossen. Het is natuurlijk makkelijk om gewoon een mailtje te sturen naar de supportafdeling, maar soms moet je je handen vuil maken. In dit geval tcpdumpis het de tool voor die taak. Tcpdump is een netwerkpakketanalysator die wordt uitgevoerd onder de opdrachtregel.

Dit artikel bestaat uit drie delen:

  • Basis kenmerken.
  • Filteren op basis van bepaalde verkeerskenmerken.
  • Een kort fragment van de meer geavanceerde functies (zoals logische uitdrukkingen, filteren op TCP-vlaggen).

Aangezien tcpdump niet wordt meegeleverd met de meeste basissystemen, moet u het installeren. Bijna alle Linux-distributies hebben echter tcpdump in hun kernrepository's. Voor op Debian gebaseerde distributies is de opdracht om tcpdump te installeren:

apt-get install tcpdump

Gebruik voor CentOS / RedHat de volgende opdracht:

yum install tcpdump

FreeBSD biedt een voorgebouwd pakket dat kan worden geïnstalleerd door het uitgeven van:

pkg install tcpdump

Er is ook een poort beschikbaar, net/tcpdumpdie kan worden geïnstalleerd via:

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

Als u tcpdumpzonder argumenten loopt, wordt u gehavend met resultaten. Als u het hier op Vultr gedurende minder dan vijf seconden op een pas opgestarte instantie uitvoert, krijgt u de volgende resultaten:

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

Voordat u dieper ingaat op het filteren van invoer, moet u enkele parameters bekijken die aan tcpdump kunnen worden doorgegeven:

  • -i- Geeft de interface die u wilt op te luisteren, bijvoorbeeld: tcpdump -i eth0.
  • -n- Probeer niet om reverse lookups uit te voeren op IP-adressen, bijvoorbeeld: tcpdump -n(als u nog een ntcpdump toevoegt , worden poortnummers weergegeven in plaats van namen).
  • -X- Laat de inhoud van de verzamelde pakketten: tcpdump -X.
  • -c- Alleen xpakketten vastleggen , xzijnde een willekeurig getal, tcpdump -c 10vangt bijvoorbeeld precies 10 pakketten op.
  • -v- Vergroot de hoeveelheid pakketinformatie die u te zien krijgt, meer vs voeg meer uitgebreidheid toe.

Elk van de hier genoemde parameters kan met elkaar worden gecombineerd. Als je 100 pakketten wilde vastleggen, maar alleen op je VPN-interface tun0, dan zou de opdracht tcpdump er als volgt uitzien:

tcpdump -i tun0 -c 100 -X

Er zijn tientallen (zo niet honderden) opties naast die paar, maar ze zijn de meest voorkomende. Voel je vrij om de manpage van tcpdump op je systeem te lezen.

Nu je een basiskennis hebt van tcpdump, is het tijd om naar een van de meest geweldige functies van tcpdump te kijken: uitdrukkingen. Uitdrukkingen maken je leven een stuk makkelijker. Ze staan ​​ook bekend als BPF- of Berkeley-pakketfilters. Door uitdrukkingen te gebruiken, kunt u selectief pakketten weergeven (of negeren) op basis van bepaalde kenmerken - zoals oorsprong, bestemming, grootte of zelfs TCP-volgnummer.

Tot nu toe is het je gelukt om je zoekopdracht te beperken tot een bepaald aantal pakketten op een bepaalde interface, maar laten we eerlijk zijn: dat laat nog steeds te veel achtergrondgeluiden achter om effectief met de verzamelde gegevens te werken. Dat is waar uitdrukkingen in het spel komen. Het concept is vrij eenvoudig, dus we laten de droge theorie hier weg en ondersteunen het begrip met enkele praktische voorbeelden.

De uitdrukkingen die u waarschijnlijk het meest zult gebruiken, zijn:

  • host - Zoek verkeer op basis van hostnamen of IP-adressen.
  • srcof dst- Zoek naar verkeer van of naar een specifieke host.
  • proto- Zoek naar verkeer van een bepaald protocol. Werkt voor tcp, udp, icmp en anderen. Het weglaten van het protozoekwoord is ook mogelijk.
  • net - Zoek naar verkeer van / naar een bepaald bereik van IP-adressen.
  • port - Zoek naar verkeer van / naar een bepaalde haven.
  • greaterof less- Zoek naar verkeer dat groter of kleiner is dan een bepaald aantal bytes.

Hoewel de manpage voor tcpdumpslechts een paar voorbeelden bevat, heeft de manpage voor pcap-filterzeer gedetailleerde uitleg over hoe elk filter werkt en kan worden toegepast.

Als u wilt zien hoe uw communicatie met een bepaalde server verloopt, dan kunt u bijvoorbeeld het hosttrefwoord gebruiken (inclusief enkele van de parameters van hierboven):

tcpdump -i eth0 host vultr.com

Soms zijn er computers op het netwerk die de MTU niet eren of u spammen met grote pakketten; ze eruit filteren kan soms moeilijk zijn. Met expressies kunt u pakketten filteren die groter of kleiner zijn dan een bepaald aantal bytes:

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

Misschien is alleen een bepaalde haven voor u interessant. Gebruik in dit geval de portuitdrukking:

tcpdump -i eth0 -X port 21

U kunt ook uitkijken naar poortbereiken:

tcdump -i eth0 -X portrange 22-25

Aangezien NAT-gateways vrij algemeen zijn, mag u alleen zoeken naar bestemmingspoorten:

tcpdump dst port 80

Als u verkeer naar uw webserver bekijkt, wilt u misschien alleen TCP-verkeer naar poort 80 bekijken:

tcpdump tcp and dst port 80

U vraagt ​​zich waarschijnlijk af wat het zoekwoord anddaar doet. Goede vraag. Dat brengt ons bij het laatste deel van dit artikel.

tcpdump biedt basisondersteuning voor logische uitdrukkingen, meer specifiek:

  • and/ &&- Logisch "en".
  • or/ ||- Logisch "of".
  • not/ !- Logisch "niet".

Samen met de mogelijkheid om uitdrukkingen te groeperen, kunt u hiermee zeer krachtige zoekopdrachten voor inkomend en uitgaand verkeer maken. Laten we dus verkeer filteren dat afkomstig is van vultr.com op poort 22 of 443:

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

Als u dit op de opdrachtregel uitvoert, krijgt u de volgende foutmelding:

bash: syntax error near unexpected token `('

Dat komt omdat er een waarschuwing is: bashprobeert elk personage te evalueren dat het kan. Dit omvat de (en )karakters. Om die fout te voorkomen, moet u enkele aanhalingstekens rond de gecombineerde uitdrukking gebruiken:

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

Nog een nuttig voorbeeld: wanneer u SSH-problemen met een van uw gebruikers debugt, wilt u misschien alles negeren dat betrekking heeft op uw SSH-sessie:

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

Nogmaals, de use-cases zijn eindeloos en u kunt in extreme diepten specificeren wat voor soort verkeer u wilt zien. Met de volgende opdracht ziet u alleen SYNACK-pakketten van een TCP-handshake:

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

Dit werkt door te kijken naar de dertiende offset van de TCP-header en de achttiende byte daarin.

Als je het helemaal hier hebt gehaald, ben je klaar voor de meeste use-cases die zich zullen voordoen. Ik kan het oppervlak amper aanraken zonder in teveel details te treden. Ik raad je ten zeerste aan om wat verder te experimenteren met de verschillende opties en uitdrukkingen; en zoals gewoonlijk: verwijs naar de manpage als je verdwaalt.

Last but not least - een snelle terugblik. Weet je nog het begin van dit artikel? Met de duizenden pakketten die binnen enkele seconden zijn vastgelegd? De kracht van tcpdumpkan dat een stuk inkorten:

tcpdump -i eth0 tcp port 22

Het resultaat is nu:

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

Dit is veel gezonder en gemakkelijker te debuggen. Gelukkig netwerken!



Leave a Comment

Hoe LiteCart Shopping Cart Platform op Ubuntu 16.04 te installeren

Hoe LiteCart Shopping Cart Platform op Ubuntu 16.04 te installeren

LiteCart is een gratis en open source winkelwagenplatform geschreven in PHP, jQuery en HTML 5. Het is een eenvoudige, lichtgewicht en gebruiksvriendelijke e-commerce software

Stel NFS Share op Debian in

Stel NFS Share op Debian in

NFS is een netwerkgebaseerd bestandssysteem waarmee computers toegang hebben tot bestanden via een computernetwerk. Deze gids legt uit hoe u mappen via NF kunt weergeven

Hoe Matomo Analytics op Fedora te installeren 28

Hoe Matomo Analytics op Fedora te installeren 28

Gebruikt u een ander systeem? Matomo (voorheen Piwik) is een open source analyseplatform, een open alternatief voor Google Analytics. Matomo source wordt gehost o

Initiële veilige serverconfiguratie van Ubuntu 18.04

Initiële veilige serverconfiguratie van Ubuntu 18.04

Inleiding In deze tutorial leert u hoe u een basisbeveiligingsniveau configureert op een gloednieuwe Vultr VC2 virtuele machine met Ubunt

McMyAdmin installeren op Ubuntu 14.10

McMyAdmin installeren op Ubuntu 14.10

McMyAdmin is een Minecraft-serverbedieningspaneel dat wordt gebruikt om uw server te beheren. Hoewel McMyAdmin gratis is, zijn er meerdere edities, waarvan sommige pai zijn

Stel een TeamTalk-server in op Linux

Stel een TeamTalk-server in op Linux

TeamTalk is een conferentiesysteem waarmee gebruikers hoogwaardige audio- / videogesprekken kunnen voeren, tekstchatten, bestanden kunnen overdragen en schermen kunnen delen. Het ik

CyberPanel installeren en configureren op uw CentOS 7-server

CyberPanel installeren en configureren op uw CentOS 7-server

Gebruikt u een ander systeem? Introductie CyberPanel is een van de eerste bedieningspanelen op de markt die zowel open source is als OpenLiteSpeed ​​gebruikt. Wat thi

Ruby installeren en configureren met Rbenv, Rails, MariaDB, Nginx, SSL en Passenger op Ubuntu 17.04

Ruby installeren en configureren met Rbenv, Rails, MariaDB, Nginx, SSL en Passenger op Ubuntu 17.04

Ruby on Rails is een populair webraamwerk voor Ruby dat is ontwikkeld om de productiviteit van programmeurs te verhogen. Het verkrijgen van verschillende edelstenen en afhankelijkheden t

Sensu Monitoring installeren en configureren op CentOS 7

Sensu Monitoring installeren en configureren op CentOS 7

Introductie Sensu is een gratis en open source monitoringoplossing die kan worden gebruikt om server, applicatie en verschillende systeemservices te monitoren. Sensu i

Installeer phpBB With Apache op Ubuntu 16.04

Installeer phpBB With Apache op Ubuntu 16.04

PhpBB is een open source prikbordprogramma. Dit artikel laat zien hoe je phpBB bovenop een Apache-webserver op Ubuntu 16.04 installeert. Het was geschreven

Stel een niet-rootgebruiker in met Sudo Access op Ubuntu

Stel een niet-rootgebruiker in met Sudo Access op Ubuntu

Slechts één gebruiker, root, kan gevaarlijk zijn. Dus laten we dat oplossen. Vultr geeft ons de vrijheid om te doen wat we willen met onze gebruikers en onze servers

Toegang krijgen tot uw Vultr VPS

Toegang krijgen tot uw Vultr VPS

Vultr biedt verschillende manieren om toegang te krijgen tot je VPS om te configureren, installeren en gebruiken. Toegangsgegevens De standaard toegangsgegevens voor uw VPS-ar

Fuel CMS installeren op Ubuntu 16.04 LTS

Fuel CMS installeren op Ubuntu 16.04 LTS

Gebruikt u een ander systeem? Fuel CMS is een op CodeIgniter gebaseerd contentmanagementsysteem. De broncode wordt gehost op GitHub. Deze gids laat zien hoe t

Remote Servers bewaken met Zabbix op Ubuntu 16.04

Remote Servers bewaken met Zabbix op Ubuntu 16.04

Gebruikt u een ander systeem? Zabbix is ​​een gratis en open source enterprise-ready software die wordt gebruikt om de beschikbaarheid van systemen en netwerkcomponenten te bewaken

Couch CMS 2.0 installeren op een Debian 9 LAMP VPS

Couch CMS 2.0 installeren op een Debian 9 LAMP VPS

Gebruikt u een ander systeem? Couch CMS is een eenvoudig en flexibel, gratis en open source Content Management Systeem (CMS) waarmee webdesigners kunnen ontwerpen

Golang 1.8.3 installeren op CentOS 7, Ubuntu 16.04 en Debian 9

Golang 1.8.3 installeren op CentOS 7, Ubuntu 16.04 en Debian 9

Golang is een door Google ontwikkelde programmeertaal. Dankzij zijn veelzijdigheid, eenvoud en betrouwbaarheid is Golang uitgegroeid tot een van de meest bevolkte

Quassel instellen op Debian 9

Quassel instellen op Debian 9

IRC is populair bij ontwikkelaars en gebruikers van open source software. Een van de nadelen van IRC is dat wanneer u niet online bent, u importan kunt missen

Sudo gebruiken op Debian, CentOS en FreeBSD

Sudo gebruiken op Debian, CentOS en FreeBSD

Het gebruik van een sudo-gebruiker om toegang te krijgen tot een server en opdrachten uit te voeren op rootniveau is een veel voorkomende praktijk onder Linux en Unix-systeembeheerder. Het gebruik van een sud

Hoe DokuWiki op Ubuntu 16.04 LTS te installeren

Hoe DokuWiki op Ubuntu 16.04 LTS te installeren

Gebruikt u een ander systeem? DokuWiki is een open source wiki-programma geschreven in PHP waarvoor geen database nodig is. Het slaat gegevens op in tekstbestanden. DokuWik

Een Chroot opzetten op Debian

Een Chroot opzetten op Debian

Dit artikel leert u hoe u een chroot-gevangenis op Debian instelt. Ik neem aan dat u Debian 7.x gebruikt. Als u Debian 6 of 8 gebruikt, kan dit werken, bu

Kan AI vechten met toenemend aantal ransomware-aanvallen?

Kan AI vechten met toenemend aantal ransomware-aanvallen?

Ransomware-aanvallen nemen toe, maar kan AI helpen het nieuwste computervirus het hoofd te bieden? Is AI het antwoord? Lees hier weten is AI boezem of vloek

ReactOS: is dit de toekomst van Windows?

ReactOS: is dit de toekomst van Windows?

ReactOS, een open source en gratis besturingssysteem is hier met de nieuwste versie. Kan het voldoen aan de behoeften van moderne Windows-gebruikers en Microsoft uitschakelen? Laten we meer te weten komen over deze oude stijl, maar een nieuwere OS-ervaring.

Blijf verbonden via WhatsApp Desktop-app 24 * 7

Blijf verbonden via WhatsApp Desktop-app 24 * 7

WhatsApp heeft eindelijk de Desktop-app voor Mac- en Windows-gebruikers gelanceerd. Nu heb je eenvoudig toegang tot WhatsApp vanuit Windows of Mac. Beschikbaar voor Windows 8+ en Mac OS 10.9+

Hoe AI procesautomatisering naar een hoger niveau kan tillen?

Hoe AI procesautomatisering naar een hoger niveau kan tillen?

Lees dit om te weten hoe kunstmatige intelligentie populair wordt onder de kleinschalige bedrijven en hoe het de kansen vergroot om ze te laten groeien en hun concurrenten voorsprong te geven.

macOS Catalina 10.15.4 Supplement Update veroorzaakt meer problemen dan het oplost

macOS Catalina 10.15.4 Supplement Update veroorzaakt meer problemen dan het oplost

Onlangs heeft Apple macOS Catalina 10.15.4 uitgebracht, een aanvullende update om problemen op te lossen, maar het lijkt erop dat de update meer problemen veroorzaakt die ertoe leiden dat mac-machines worden gemetseld. Lees dit artikel voor meer informatie

13 Commerciële data-extractietools voor big data

13 Commerciële data-extractietools voor big data

13 Commerciële data-extractietools voor big data

Wat is een logboekbestandssysteem en hoe werkt het?

Wat is een logboekbestandssysteem en hoe werkt het?

Onze computer slaat alle gegevens op een georganiseerde manier op, het zogenaamde Journaling-bestandssysteem. Het is een efficiënte methode waarmee de computer bestanden kan zoeken en weergeven zodra u op zoeken drukt.https://wethegeek.com/?p=94116&preview=true

Technologische singulariteit: een verre toekomst van de menselijke beschaving?

Technologische singulariteit: een verre toekomst van de menselijke beschaving?

Naarmate de wetenschap zich snel ontwikkelt en veel van onze inspanningen overneemt, nemen ook de risico's toe om onszelf te onderwerpen aan een onverklaarbare singulariteit. Lees, wat singulariteit voor ons kan betekenen.

Een inzicht in 26 Big Data-analysetechnieken: deel 1

Een inzicht in 26 Big Data-analysetechnieken: deel 1

Een inzicht in 26 Big Data-analysetechnieken: deel 1

De impact van kunstmatige intelligentie in de gezondheidszorg 2021

De impact van kunstmatige intelligentie in de gezondheidszorg 2021

AI in de zorg heeft de afgelopen decennia grote sprongen gemaakt. De toekomst van AI in de gezondheidszorg groeit dus nog steeds met de dag.