Uvod v Tcpdump

Uvod v Tcpdump

Če zaženete strežnik, boste nedvomno prišli do točke, ko boste morali odpraviti nekatere težave, povezane z omrežjem. Seveda bi bilo enostavno poslati pošto na podporni oddelek, a včasih si morate umazati roke. V tem primeru tcpdumpje orodje za to delo. Tcpdump je analizator omrežnih paketov, ki se izvaja pod ukazno vrstico.

Ta članek bo razdeljen na tri dele:

  • Osnovne lastnosti.
  • Filtriranje na podlagi določenih prometnih značilnosti.
  • Kratek izrezek naprednejših funkcij (kot so logični izrazi, filtriranje po zastavicah TCP).

Ker tcpdump ni vključen v večino osnovnih sistemov, ga boste morali namestiti. Vendar imajo skoraj vse distribucije Linuxa tcpdump v svojih osrednjih repozitorijih. Za distribucije, ki temeljijo na Debianu, je ukaz za namestitev tcpdump:

apt-get install tcpdump

Za CentOS/RedHat uporabite naslednji ukaz:

yum install tcpdump

FreeBSD ponuja vnaprej izdelan paket, ki ga je mogoče namestiti z izdajo:

pkg install tcpdump

Na voljo so tudi vrata, net/tcpdumpki jih je mogoče namestiti prek:

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

Če tečeš tcpdumpbrez argumentov, boš pretepen z rezultati. Če ga zaženete na sveže zavrtenem primerku tukaj na Vultru za manj kot pet sekund, dobite naslednje rezultate:

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

Preden se poglobite v podrobnosti o filtriranju vnosa, si oglejte nekaj parametrov, ki jih je mogoče posredovati tcpdump:

  • -i- Določa vmesnik, na katerem želite poslušati, na primer: tcpdump -i eth0.
  • -n- Ne poskušajte izvajati povratnih iskanj na naslovih IP, na primer: tcpdump -n(če dodate še en ntcpdump, vam bo namesto imen pokazal številke vrat).
  • -X- Pokaži vsebino zbranih paketov: tcpdump -X.
  • -c- Samo zajemanje xpaketov, xki je poljubno število, na primer tcpdump -c 10zajame točno 10 paketov.
  • -v- Povečajte količino prikazanih podatkov o paketih, več vs dodajte več besed.

Vsak od tukaj omenjenih parametrov je mogoče kombinirati skupaj. Če bi želeli zajeti 100 paketov, vendar samo na vašem vmesniku VPN tun0, bi bil ukaz tcpdump videti takole:

tcpdump -i tun0 -c 100 -X

Obstaja na desetine (če ne na stotine) možnosti poleg teh nekaj, vendar so najpogostejše. Vabljeni, da preberete man stran tcpdump v vašem sistemu.

Zdaj, ko imate osnovno razumevanje tcpdump, je čas, da si ogledate eno od najbolj osupljivih funkcij tcpdump: izraze. Izrazi vam bodo veliko olajšali življenje. Znani so tudi kot BPF ali Berkeley paketni filtri. Uporaba izrazov vam omogoča, da selektivno prikažete (ali prezrete) pakete na podlagi določenih značilnosti – kot so izvor, cilj, velikost ali celo zaporedna številka TCP.

Doslej vam je uspelo omejiti iskanje na določeno količino paketov na določenem vmesniku, a bodimo iskreni: to še vedno pušča preveč hrupa v ozadju za učinkovito delo z zbranimi podatki. Tu pridejo v poštev izrazi. Koncept je precej preprost, zato bomo tukaj izpustili suho teorijo in podprli razumevanje z nekaj praktičnimi primeri.

Izrazi, ki jih boste verjetno najbolj uporabljali, so:

  • host - Poiščite promet na podlagi imen gostiteljev ali naslovov IP.
  • srcali dst- Poiščite promet od ali do določenega gostitelja.
  • proto- Poiščite promet določenega protokola. Deluje za tcp, udp, icmp in druge. protoMožno je tudi izpuščanje ključne besede.
  • net - Poiščite promet na/iz določenega obsega naslovov IP.
  • port - Poiščite promet do/iz določenega pristanišča.
  • greaterali less- Poiščite promet, večji ali manjši od določene količine bajtov.

Medtem ko priročnik za tcpdumpvsebuje le nekaj primerov, ima stran priročnika za pcap-filterzelo podrobna pojasnila o tem, kako vsak filter deluje in ga je mogoče uporabiti.

Če želite videti, kako poteka vaša komunikacija z določenim strežnikom, lahko uporabite na hostprimer ključno besedo (vključno z nekaterimi od zgornjih parametrov):

tcpdump -i eth0 host vultr.com

Včasih so v omrežju računalniki, ki ne spoštujejo MTU ali vam pošiljajo velike pakete; njihovo filtriranje je včasih težko. Izrazi vam omogočajo filtriranje paketov, ki so večji ali manjši od določenega števila bajtov:

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

Morda vas zanima le določeno pristanišče. V tem primeru uporabite portizraz:

tcpdump -i eth0 -X port 21

Prav tako lahko pazite na obsege vrat:

tcdump -i eth0 -X portrange 22-25

Ker so prehodi NAT precej pogosti, lahko iščete samo ciljna vrata:

tcpdump dst port 80

Če gledate promet na svojem spletnem strežniku, boste morda želeli pogledati samo promet TCP do vrat 80:

tcpdump tcp and dst port 80

Verjetno se sprašujete, kaj ključna beseda andtam počne. Dobro vprašanje. To nas pripelje do zadnjega dela tega članka.

tcpdump ponuja osnovno podporo za logične izraze, natančneje:

  • and/ &&- Logično "in".
  • or/ ||- Logično "ali".
  • not/ !- Logično "ne".

Skupaj z zmožnostjo združevanja izrazov skupaj vam omogoča, da ustvarite zelo zmogljiva iskanja za dohodni in odhodni promet. Zato filtrirajmo promet, ki prihaja z vultr.com na vratih 22 ali 443:

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

Če to zaženete v ukazni vrstici, boste dobili naslednjo napako:

bash: syntax error near unexpected token `('

To je zato, ker obstaja opozorilo: bashposkuša oceniti vsak znak, ki ga lahko. To vključuje znake (in ). Da bi se izognili tej napaki, uporabite enojne narekovaje okoli kombiniranega izraza:

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

Še en uporaben primer: pri odpravljanju napak pri SSH pri enem od vaših uporabnikov boste morda želeli prezreti vse, kar je povezano z vašo sejo SSH:

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

Spet so primeri uporabe neskončni in lahko natančno določite, kakšen promet želite videti. Naslednji ukaz bi vam pokazal samo pakete SYNACK pri rokovanju TCP:

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

To deluje tako, da pogledate trinajsti odmik glave TCP in osemnajsti bajt v njej.

Če ste naredili vse do tukaj, potem ste pripravljeni na večino primerov uporabe, ki se bodo pojavili. Komaj se dotaknem površine, ne da bi se spuščal v preveč podrobnosti. Zelo priporočam, da še malo eksperimentirate z različnimi možnostmi in izrazi; in kot običajno: sklicujte se na stran priročnika, ko se izgubite.

Nenazadnje – hiter pogled nazaj. Se spomnite začetka tega članka? Z na tisoče paketov, zajetih v nekaj sekundah? Moč tcpdumplahko to precej zmanjša:

tcpdump -i eth0 tcp port 22

Rezultat je zdaj:

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

To je veliko bolj razumno in lažje odpravljati napake. Srečno mreženje!


Namestite Plesk na CentOS 7

Namestite Plesk na CentOS 7

Uporaba drugega sistema? Plesk je lastniška nadzorna plošča spletnega gostitelja, ki uporabnikom omogoča upravljanje svojih osebnih in/ali strank spletnih mest, baz podatkov

Namestite Lets Encrypt SSL v aplikacijo WordPress z enim klikom

Namestite Lets Encrypt SSL v aplikacijo WordPress z enim klikom

Uvod Lets Encrypt je storitev overitelja potrdil, ki ponuja brezplačna potrdila TLS/SSL. Certbot poenostavlja postopek namestitve,

Ustvarjanje bloga Jekyll v Ubuntu 16.04

Ustvarjanje bloga Jekyll v Ubuntu 16.04

Uporaba drugega sistema? Jekyll je odlična alternativa WordPressu za bloganje ali deljenje vsebine. Ne zahteva nobenih baz podatkov in je zelo enostaven i

Kako nastaviti nenadzorovane nadgradnje na Debian 9 (raztegni)

Kako nastaviti nenadzorovane nadgradnje na Debian 9 (raztegni)

Uporaba drugega sistema? Če kupite strežnik Debian, morate vedno imeti najnovejše varnostne popravke in posodobitve, ne glede na to, ali spite ali ne

Kako namestiti in konfigurirati PHP 7.0 ali PHP 7.1 na Ubuntu 16.04

Kako namestiti in konfigurirati PHP 7.0 ali PHP 7.1 na Ubuntu 16.04

PHP in sorodni paketi so najpogosteje uporabljene komponente pri uvajanju spletnega strežnika. V tem članku se bomo naučili, kako nastaviti PHP 7.0 ali PHP 7.1 o

Kako namestiti Squid Proxy na CentOS

Kako namestiti Squid Proxy na CentOS

Squid je priljubljen brezplačen program za Linux, ki vam omogoča ustvarjanje spletnega proxyja za posredovanje. V tem priročniku boste videli, kako namestiti Squid na CentOS, da vas obrne

Kako namestiti Lighttpd (LLMP Stack) na CentOS 6

Kako namestiti Lighttpd (LLMP Stack) na CentOS 6

Uvod Lighttpd je razdelek Apache, katerega namen je biti veliko manj intenziven vir. Je lahek, od tod tudi njegovo ime, in je precej preprost za uporabo. Namestite

Tri brezplačne nadzorne plošče strežnika (hitra namestitev)

Tri brezplačne nadzorne plošče strežnika (hitra namestitev)

1. Virtualmin/Webmin Virtualmin je zmogljiva in prilagodljiva nadzorna plošča za spletno gostovanje za sisteme Linux in UNIX, ki temelji na dobro znani odprtokodni spletni bazi

Nastavitev aplikacije Yii na Ubuntu 14.04

Nastavitev aplikacije Yii na Ubuntu 14.04

Yii je okvir PHP, ki vam omogoča hitrejši in preprostejši razvoj aplikacij. Namestitev Yii na Ubuntu je enostavna, saj se boste naučili natančno

Uporaba zaslona v Ubuntu 14.04

Uporaba zaslona v Ubuntu 14.04

Screen je aplikacija, ki omogoča večkratno uporabo terminalskih sej v enem oknu. To vam omogoča simulacijo več terminalskih oken, kjer je ma

Nastavite svoj DNS strežnik na Debian/Ubuntu

Nastavite svoj DNS strežnik na Debian/Ubuntu

Ta vadnica pojasnjuje, kako nastaviti strežnik DNS z uporabo Bind9 v Debianu ali Ubuntuju. V celotnem članku ustrezno nadomestite your-domain-name.com. Ob th

Uporaba Logrotate za upravljanje dnevniških datotek

Uporaba Logrotate za upravljanje dnevniških datotek

Uvod Logrotate je pripomoček za Linux, ki poenostavlja upravljanje dnevniških datotek. Običajno se izvaja enkrat na dan prek opravila cron in upravlja bazo dnevnikov

Konfiguriranje statičnega omrežja in IPv6 na CentOS 7

Konfiguriranje statičnega omrežja in IPv6 na CentOS 7

VULTR je pred kratkim naredil spremembe na svoji strani in zdaj bi moralo vse delovati v redu iz škatle z omogočenim NetworkManagerjem. Če želite onemogočiti

Spreminjanje Icinga2 za uporabo modela Master/Client na CentOS 6 ali CentOS 7

Spreminjanje Icinga2 za uporabo modela Master/Client na CentOS 6 ali CentOS 7

Icinga2 je zmogljiv sistem za spremljanje in če se uporablja v modelu glavni-odjemalec, lahko nadomesti potrebo po nadzornih pregledih, ki temeljijo na NRPE. Glavni naročnik

Nastavite Red5 Media Server na Ubuntu 16.04

Nastavite Red5 Media Server na Ubuntu 16.04

Uporaba drugega sistema? Red5 je odprtokodni medijski strežnik, implementiran v Javi, ki vam omogoča zagon večuporabniških aplikacij Flash, kot je prenos v živo

Prevedite in namestite Nginx z modulom PageSpeed ​​na Debian 8

Prevedite in namestite Nginx z modulom PageSpeed ​​na Debian 8

V tem članku bomo videli, kako prevesti in namestiti Nginx mainline iz uradnih virov Nginxa z modulom PageSpeed, ki vam omogoča

Kako namestiti Apache Cassandra 3.11.x na Ubuntu 16.04 LTS

Kako namestiti Apache Cassandra 3.11.x na Ubuntu 16.04 LTS

Uporaba drugega sistema? Apache Cassandra je brezplačen in odprtokodni sistem za upravljanje baz podatkov NoSQL, ki je zasnovan tako, da zagotavlja razširljivost, visoko

Kako namestiti Apache Cassandra 3.11.x na CentOS 7

Kako namestiti Apache Cassandra 3.11.x na CentOS 7

Uporaba drugega sistema? Apache Cassandra je brezplačen in odprtokodni sistem za upravljanje baz podatkov NoSQL, ki je zasnovan tako, da zagotavlja razširljivost, visoko

Kako namestiti Vanilla Forum na Ubuntu 16.04

Kako namestiti Vanilla Forum na Ubuntu 16.04

Uporaba drugega sistema? Vanilla forum je odprtokodna forumska aplikacija, napisana v PHP. Je popolnoma prilagodljiv, enostaven za uporabo in podpira zunanjost

Kako namestiti Kanboard na Ubuntu 18.04 LTS

Kako namestiti Kanboard na Ubuntu 18.04 LTS

Uporaba drugega sistema? Uvod Kanboard je brezplačen in odprtokodni program za vodenje projektov, ki je zasnovan za olajšanje in vizualizacijo

Vzpon strojev: aplikacije AI v resničnem svetu

Vzpon strojev: aplikacije AI v resničnem svetu

Umetna inteligenca ni v prihodnosti, tukaj je prav v sedanjosti. V tem blogu preberite, kako so aplikacije umetne inteligence vplivale na različne sektorje.

DDOS napadi: kratek pregled

DDOS napadi: kratek pregled

Ste tudi vi žrtev DDOS napadov in ste zmedeni glede načinov preprečevanja? Preberite ta članek, če želite rešiti svoja vprašanja.

Ste se kdaj vprašali, kako hekerji zaslužijo denar?

Ste se kdaj vprašali, kako hekerji zaslužijo denar?

Morda ste že slišali, da hekerji zaslužijo veliko denarja, a ste se kdaj vprašali, kako zaslužijo takšen denar? razpravljajmo.

Revolucionarni Googlovi izumi, ki vam bodo olajšali življenje.

Revolucionarni Googlovi izumi, ki vam bodo olajšali življenje.

Ali želite videti revolucionarne izume Googla in kako so ti izumi danes spremenili življenje vsakega človeka? Nato preberite v blogu in si oglejte Googlove izume.

Friday Essential: Kaj se je zgodilo z avtomobili, ki jih poganja umetna inteligenca?

Friday Essential: Kaj se je zgodilo z avtomobili, ki jih poganja umetna inteligenca?

Koncept samovozečih avtomobilov, ki zapeljejo na ceste s pomočjo umetne inteligence, so sanje, ki jih imamo že nekaj časa. A kljub številnim obljubam jih ni nikjer. Preberite ta blog, če želite izvedeti več…

Tehnološka singularnost: oddaljena prihodnost človeške civilizacije?

Tehnološka singularnost: oddaljena prihodnost človeške civilizacije?

Ker se znanost hitro razvija in prevzame veliko naših prizadevanj, se povečuje tudi tveganje, da se podvržemo nerazložljivi singularnosti. Preberite, kaj bi za nas lahko pomenila singularnost.

Razvoj shranjevanja podatkov – Infografika

Razvoj shranjevanja podatkov – Infografika

Metode shranjevanja podatkov so se lahko razvijale od rojstva podatkov. Ta blog pokriva razvoj shranjevanja podatkov na podlagi infografike.

Funkcionalnosti slojev referenčne arhitekture velikih podatkov

Funkcionalnosti slojev referenčne arhitekture velikih podatkov

Preberite blog, če želite na najpreprostejši način spoznati različne plasti v arhitekturi velikih podatkov in njihove funkcionalnosti.

6 neverjetnih prednosti pametnih naprav za dom v našem življenju

6 neverjetnih prednosti pametnih naprav za dom v našem življenju

V tem digitalno vodenem svetu so pametne naprave za dom postale ključni del življenja. Tukaj je nekaj neverjetnih prednosti pametnih naprav za dom o tem, kako naredijo naše življenje vredno življenja in poenostavijo.

Posodobitev dodatka macOS Catalina 10.15.4 povzroča več težav kot jih rešuje

Posodobitev dodatka macOS Catalina 10.15.4 povzroča več težav kot jih rešuje

Pred kratkim je Apple izdal macOS Catalina 10.15.4 dopolnilno posodobitev za odpravo težav, vendar se zdi, da posodobitev povzroča več težav, ki vodijo do opečenja računalnikov Mac. Preberite ta članek, če želite izvedeti več