Uvod u Tcpdump

Uvod u Tcpdump

Ako pokrenete poslužitelj, nesumnjivo ćete doći do točke u kojoj ćete morati riješiti neke probleme povezane s mrežom. Naravno, bilo bi jednostavno poslati mail odjelu za podršku, ali ponekad morate uprljati ruke. U ovom slučaju, to tcpdumpje alat za taj posao. Tcpdump je analizator mrežnih paketa koji radi ispod naredbenog retka.

Ovaj će članak biti podijeljen u tri dijela:

  • Osnovne značajke.
  • Filtriranje na temelju određenih karakteristika prometa.
  • Kratak isječak naprednijih značajki (kao što su logički izrazi, filtriranje prema TCP zastavicama).

Budući da tcpdump nije uključen u većinu osnovnih sustava, morat ćete ga instalirati. Međutim, gotovo sve distribucije Linuxa imaju tcpdump u svojim osnovnim repozitorijumima. Za distribucije temeljene na Debianu, naredba za instaliranje tcpdump je:

apt-get install tcpdump

Za CentOS/RedHat upotrijebite sljedeću naredbu:

yum install tcpdump

FreeBSD nudi unaprijed izgrađen paket koji se može instalirati izdavanjem:

pkg install tcpdump

Dostupan je i port net/tcpdumpkoji se može instalirati putem:

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

Ako trčite tcpdumpbez ikakvih argumenata, bit ćete pretučeni rezultatima. Pokretanje na svježe pokrenutoj instanci ovdje na Vultru na manje od pet sekundi daje sljedeće rezultate:

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

Prije nego što uđete u više pojedinosti o tome kako filtrirati unos, trebali biste pogledati neke parametre koji se mogu proslijediti tcpdumpu:

  • -i- Određuje sučelje na kojem želite slušati, na primjer: tcpdump -i eth0.
  • -n- Nemojte pokušavati izvršiti obrnute pretrage na IP adresama, na primjer: tcpdump -n(ako dodate još jedan ntcpdump će vam umjesto imena prikazati brojeve portova).
  • -X- Prikaži sadržaj prikupljenih paketa: tcpdump -X.
  • -c- Samo hvatanje xpaketa, xbudući da je proizvoljan broj, na primjer tcpdump -c 10hvata točno 10 paketa.
  • -v- Povećajte količinu informacija o paketima koje vam se prikazuju, više vs dodajte više opširnosti.

Svaki od ovdje navedenih parametara može se kombinirati zajedno. Ako želite uhvatiti 100 paketa, ali samo na vašem VPN sučelju tun0, tada bi naredba tcpdump izgledala ovako:

tcpdump -i tun0 -c 100 -X

Postoje deseci (ako ne i stotine) opcija uz tih nekoliko, ali one su najčešće. Slobodno pročitajte tcpdumpovu man stranicu na svom sustavu.

Sada kada imate osnovno razumijevanje tcpdump-a, vrijeme je da pogledate jednu od najstrašnijih značajki tcpdump-a: izraze. Izrazi će vam uvelike olakšati život. Također su poznati kao BPF ili Berkeley paketni filteri. Korištenje izraza omogućuje vam da selektivno prikažete (ili zanemarite) pakete na temelju određenih karakteristika - kao što su porijeklo, odredište, veličina ili čak TCP redni broj.

Do sada ste uspjeli ograničiti pretragu na određenu količinu paketa na određenom sučelju, ali budimo iskreni: to još uvijek ostavlja previše pozadinske buke za učinkovit rad s prikupljenim podacima. Tu na scenu stupaju izrazi. Koncept je prilično jednostavan, pa ćemo ovdje izostaviti suhu teoriju i potkrijepiti razumijevanje nekim praktičnim primjerima.

Izrazi koje ćete vjerojatno najčešće koristiti su:

  • host - Potražite promet na temelju imena hosta ili IP adresa.
  • srcili dst- Potražite promet od ili do određenog hosta.
  • proto- Potražite promet određenog protokola. Radi za tcp, udp, icmp i druge. protoMoguće je i izostavljanje ključne riječi.
  • net - Potražite promet do/iz određenog raspona IP adresa.
  • port - Potražite promet do/iz određene luke.
  • greaterili less- Potražite promet veći ili manji od određene količine bajtova.

Dok man stranica za tcpdumpsadrži samo nekoliko primjera, man stranica za pcap-filterima vrlo detaljna objašnjenja o tome kako svaki filtar radi i može se primijeniti.

Ako želite vidjeti kako se odvija vaša komunikacija s određenim poslužiteljem, možete koristiti hostključnu riječ, na primjer (uključujući neke od parametara odozgo):

tcpdump -i eth0 host vultr.com

Ponekad na mreži postoje računala koja ne poštuju MTU ili vam šalju velike pakete; njihovo filtriranje ponekad može biti teško. Izrazi vam omogućuju filtriranje paketa koji su veći ili manji od određenog broja bajtova:

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

Možda vas zanima samo određena luka. U ovom slučaju koristite portizraz:

tcpdump -i eth0 -X port 21

Također možete paziti na raspon portova:

tcdump -i eth0 -X portrange 22-25

Budući da su NAT pristupnici prilično česti, možete tražiti samo odredišne ​​portove:

tcpdump dst port 80

Ako gledate promet na svom web poslužitelju, možda ćete htjeti pogledati samo TCP promet na port 80:

tcpdump tcp and dst port 80

Vjerojatno se pitate što ključna riječ andtamo radi. Dobro pitanje. To nas dovodi do posljednjeg dijela ovog članka.

tcpdump nudi osnovnu podršku za logičke izraze, točnije:

  • and/ &&- Logično "i".
  • or/ ||- Logično "ili".
  • not/ !- Logično "ne".

Zajedno s mogućnošću grupiranja izraza, to vam omogućuje stvaranje vrlo moćnih pretraživanja za dolazni i odlazni promet. Zato filtrirajmo promet koji dolazi s vultr.com na portu 22 ili 443:

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

Pokretanjem ovoga na naredbenoj liniji dobit ćete sljedeću pogrešku:

bash: syntax error near unexpected token `('

To je zato što postoji upozorenje: bashpokušava procijeniti svaki lik koji može. To uključuje (i )znakove. Kako biste izbjegli tu pogrešku, trebali biste koristiti jednostruke navodnike oko kombiniranog izraza:

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

Još jedan koristan primjer: kada otklanjate greške sa SSH-om s jednim od vaših korisnika, možda ćete htjeti zanemariti sve što je povezano s vašom SSH sesijom:

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

Opet, slučajevi korištenja su beskonačni, a možete odrediti u ekstremne dubine kakvu vrstu prometa želite vidjeti. Sljedeća naredba bi vam pokazala samo SYNACK pakete TCP rukovanja:

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

Ovo funkcionira gledanjem na trinaesti pomak TCP zaglavlja i osamnaesti bajt unutar njega.

Ako ste uspjeli do kraja ovdje, onda ste spremni za većinu slučajeva upotrebe koji će se pojaviti. Jedva mogu dodirnuti površinu, a da ne ulazim u previše detalja. Toplo preporučam da malo dalje eksperimentirate s različitim opcijama i izrazima; i kao i obično: uputite se na man stranicu kada se izgubite.

Na kraju, ali ne i najmanje važno – brzi pogled unatrag. Sjećate li se početka ovog članka? S tisućama paketa uhvaćenih u nekoliko sekundi? Snaga tcpdumpmože to uvelike smanjiti:

tcpdump -i eth0 tcp port 22

Rezultat je sada:

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

Ovo je puno razumnije i lakše za otklanjanje pogrešaka. Sretno umrežavanje!


Instalirajte Plesk na CentOS 7

Instalirajte Plesk na CentOS 7

Korištenje drugog sustava? Plesk je vlasnička upravljačka ploča web hosta koja omogućuje korisnicima da administriraju svoje osobne i/ili klijentske web stranice, baze podataka

Postavite Cacti na Debian Jessie

Postavite Cacti na Debian Jessie

Uvod Cacti je alat otvorenog koda za praćenje i crtanje koji se u potpunosti temelji na RRD podacima. Putem Cactusa možete pratiti gotovo sve vrste uređaja

Instalirajte Lets Encrypt SSL na WordPress aplikaciju jednim klikom

Instalirajte Lets Encrypt SSL na WordPress aplikaciju jednim klikom

Uvod Lets Encrypt je usluga za izdavanje certifikata koja nudi besplatne TLS/SSL certifikate. Certbot pojednostavljuje proces instalacije,

Kako postaviti Tekkit Classic Server na Ubuntu 16.10

Kako postaviti Tekkit Classic Server na Ubuntu 16.10

Korištenje drugog sustava? Što je Tekkit Classic? Tekkit Classic je modpack za igru ​​koju svi znaju i vole; Minecraft. Sadrži neke od ver

Postavite iRedMail na Debian Wheezy

Postavite iRedMail na Debian Wheezy

Korištenje drugog sustava? Ovaj vodič će vam pokazati kako instalirati grupni softver iRedMail na novu instalaciju Debian Wheezyja. Trebali biste koristiti servis

Izrada Jekyll bloga na Ubuntu 16.04

Izrada Jekyll bloga na Ubuntu 16.04

Korištenje drugog sustava? Jekyll je izvrsna alternativa WordPressu za bloganje ili dijeljenje sadržaja. Ne zahtijeva nikakve baze podataka i vrlo je jednostavan i

Kako postaviti nenadzirane nadogradnje na Debianu 9 (protežu)

Kako postaviti nenadzirane nadogradnje na Debianu 9 (protežu)

Korištenje drugog sustava? Ako kupite Debian poslužitelj, uvijek biste trebali imati najnovije sigurnosne zakrpe i ažuriranja, bez obzira spavate li ili ne

Kako instalirati i konfigurirati PHP 7.0 ili PHP 7.1 na Ubuntu 16.04

Kako instalirati i konfigurirati PHP 7.0 ili PHP 7.1 na Ubuntu 16.04

PHP i povezani paketi najčešće su korištene komponente prilikom postavljanja web poslužitelja. U ovom članku ćemo naučiti kako postaviti PHP 7.0 ili PHP 7.1 o

Kako instalirati Squid proxy na CentOS

Kako instalirati Squid proxy na CentOS

Squid je popularan besplatni program za Linux koji vam omogućuje stvaranje web proxyja za prosljeđivanje. U ovom vodiču vidjet ćete kako instalirati Squid na CentOS da vas preokrene

Kako instalirati Lighttpd (LLMP Stack) na CentOS 6

Kako instalirati Lighttpd (LLMP Stack) na CentOS 6

Uvod Lighttpd je fork Apachea koji ima za cilj da bude puno manje intenzivan prema resursima. Lagan je, otuda mu i naziv, i prilično je jednostavan za korištenje. Instaliraj

Korištenje zaslona na Ubuntu 14.04

Korištenje zaslona na Ubuntu 14.04

Screen je aplikacija koja omogućuje višestruko korištenje terminalskih sesija unutar jednog prozora. To vam omogućuje da simulirate više prozora terminala gdje je ma

Postavite svoj vlastiti DNS poslužitelj na Debian/Ubuntu

Postavite svoj vlastiti DNS poslužitelj na Debian/Ubuntu

Ovaj vodič objašnjava kako postaviti DNS poslužitelj pomoću Bind9 na Debianu ili Ubuntu. U cijelom članku u skladu s tim zamijenite your-domain-name.com. Na th

Konfiguriranje statičkog umrežavanja i IPv6 na CentOS 7

Konfiguriranje statičkog umrežavanja i IPv6 na CentOS 7

VULTR je nedavno napravio promjene na svojoj strani i sada bi sve trebalo raditi dobro iz kutije s omogućenim NetworkManagerom. Želite li onemogućiti

Promjena Icinga2 za korištenje modela Master/Client na CentOS 6 ili CentOS 7

Promjena Icinga2 za korištenje modela Master/Client na CentOS 6 ili CentOS 7

Icinga2 je moćan sustav nadzora, a kada se koristi u modelu master-client, može zamijeniti potrebu za provjerama praćenja na temelju NRPE. Glavni klijent

Postavite Red5 Media Server na Ubuntu 16.04

Postavite Red5 Media Server na Ubuntu 16.04

Korištenje drugog sustava? Red5 je medijski poslužitelj otvorenog koda implementiran u Javi koji vam omogućuje pokretanje Flash višekorisničkih aplikacija kao što je live streamin

Prevedite i instalirajte Nginx s modulom PageSpeed ​​na Debian 8

Prevedite i instalirajte Nginx s modulom PageSpeed ​​na Debian 8

U ovom članku ćemo vidjeti kako sastaviti i instalirati Nginx mainline iz službenih izvora Nginxa s modulom PageSpeed, koji vam omogućuje da

Kako instalirati Vanilla Forum na Ubuntu 16.04

Kako instalirati Vanilla Forum na Ubuntu 16.04

Korištenje drugog sustava? Vanilla forum je aplikacija otvorenog koda napisana u PHP-u. Potpuno je prilagodljiv, jednostavan za korištenje i podržava eksterne

Kako instalirati Kanboard na Ubuntu 18.04 LTS

Kako instalirati Kanboard na Ubuntu 18.04 LTS

Korištenje drugog sustava? Uvod Kanboard je besplatni softver za upravljanje projektima otvorenog koda koji je dizajniran za olakšavanje i vizualizaciju

Kako instalirati Kanboard na Debian 9

Kako instalirati Kanboard na Debian 9

Korištenje drugog sustava? Uvod Kanboard je besplatni softver za upravljanje projektima otvorenog koda koji je dizajniran za olakšavanje i vizualizaciju

Kako instalirati Giteu na Debian 9

Kako instalirati Giteu na Debian 9

Korištenje drugog sustava? Gitea je alternativni sustav za kontrolu verzija otvorenog koda s vlastitim hostom koji pokreće Git. Gitea je napisana na Golangu i jest

Uspon strojeva: primjene AI u stvarnom svijetu

Uspon strojeva: primjene AI u stvarnom svijetu

Umjetna inteligencija nije u budućnosti, ovdje je upravo u sadašnjosti. U ovom blogu Pročitajte kako su aplikacije umjetne inteligencije utjecale na različite sektore.

DDOS napadi: kratak pregled

DDOS napadi: kratak pregled

Jeste li i vi žrtva DDOS napada i zbunjeni ste metodama prevencije? Pročitajte ovaj članak kako biste riješili svoje upite.

Jeste li se ikada zapitali kako hakeri zarađuju novac?

Jeste li se ikada zapitali kako hakeri zarađuju novac?

Možda ste čuli da hakeri zarađuju mnogo novca, ali jeste li se ikada zapitali kako zarađuju toliki novac? raspravimo.

Revolucionarni Googleovi izumi koji će vam olakšati život.

Revolucionarni Googleovi izumi koji će vam olakšati život.

Želite li vidjeti revolucionarne izume Googlea i kako su ti izumi promijenili život svakog čovjeka danas? Zatim čitajte na blogu kako biste vidjeli Googleove izume.

Friday Essential: Što se dogodilo s automobilima s umjetnom inteligencijom?

Friday Essential: Što se dogodilo s automobilima s umjetnom inteligencijom?

Koncept samovozećih automobila koji će krenuti na ceste uz pomoć umjetne inteligencije san je koji već neko vrijeme imamo. No, unatoč nekoliko obećanja, nigdje ih nema. Pročitajte ovaj blog kako biste saznali više…

Tehnološka singularnost: daleka budućnost ljudske civilizacije?

Tehnološka singularnost: daleka budućnost ljudske civilizacije?

Kako se znanost razvija velikom brzinom, preuzimajući mnoge naše napore, raste i rizik da se podvrgnemo neobjašnjivoj Singularnosti. Pročitajte što bi za nas mogla značiti singularnost.

Evolucija pohrane podataka – Infografika

Evolucija pohrane podataka – Infografika

Metode pohrane podataka su se razvijale možda od rođenja podataka. Ovaj blog pokriva evoluciju pohrane podataka na temelju infografike.

Funkcionalnosti slojeva referentne arhitekture velikih podataka

Funkcionalnosti slojeva referentne arhitekture velikih podataka

Pročitajte blog kako biste na najjednostavniji način upoznali različite slojeve u arhitekturi velikih podataka i njihove funkcionalnosti.

6 nevjerojatnih prednosti posjedovanja pametnih kućnih uređaja u našim životima

6 nevjerojatnih prednosti posjedovanja pametnih kućnih uređaja u našim životima

U ovom digitalnom svijetu, pametni kućni uređaji postali su ključni dio života. Evo nekoliko nevjerojatnih prednosti pametnih kućnih uređaja o tome kako naš život čine vrijednim življenja i jednostavnijim.

Ažuriranje dodataka macOS Catalina 10.15.4 uzrokuje više problema nego što ih rješava

Ažuriranje dodataka macOS Catalina 10.15.4 uzrokuje više problema nego što ih rješava

Nedavno je Apple izdao macOS Catalina 10.15.4 dodatak ažuriranju kako bi riješio probleme, ali čini se da ažuriranje uzrokuje više problema koji dovode do zalijevanja mac strojeva. Pročitajte ovaj članak da biste saznali više