Wprowadzenie do Tcpdump

Jeśli prowadzisz serwer, niewątpliwie dojdziesz do punktu, w którym musisz rozwiązać niektóre problemy związane z siecią. Oczywiście łatwo byłoby po prostu wysłać wiadomość do działu wsparcia, ale czasami trzeba ubrudzić sobie ręce. W tym przypadku tcpdumpjest narzędziem do tego zadania. Tcpdump to analizator pakietów sieciowych działający w wierszu poleceń.

Ten artykuł zostanie podzielony na trzy części:

  • Podstawowe funkcje.
  • Filtrowanie na podstawie określonych cech ruchu.
  • Krótki fragment bardziej zaawansowanych funkcji (takich jak wyrażenia logiczne, filtrowanie według flag TCP).

Ponieważ tcpdump nie jest dołączony do większości systemów podstawowych, musisz go zainstalować. Jednak prawie wszystkie dystrybucje Linuksa mają tcpdump w swoich podstawowych repozytoriach. W przypadku dystrybucji opartych na Debianie, polecenie instalacji tcpdump to:

apt-get install tcpdump

W przypadku CentOS / RedHat użyj następującego polecenia:

yum install tcpdump

FreeBSD oferuje wstępnie zbudowany pakiet, który można zainstalować, wydając:

pkg install tcpdump

Dostępny jest również port, net/tcpdumpktóry można zainstalować za pomocą:

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

Jeśli biegniesz tcpdumpbez żadnych argumentów, będziesz obijany wynikami. Uruchomienie go na świeżo rozwiniętej instancji na Vultr przez mniej niż pięć sekund daje następujące wyniki:

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

Zanim przejdziesz do dalszych szczegółów na temat filtrowania danych wejściowych, powinieneś rzucić okiem na niektóre parametry, które można przekazać do tcpdump:

  • -i- Określa interfejs chcesz słuchać tego, na przykład: tcpdump -i eth0.
  • -n- Nie próbuj wyszukiwać wstecz na adresach IP, na przykład: tcpdump -n(jeśli dodasz inny program ntcpdump wyświetli numery portów zamiast nazw).
  • -X- Pokaż zawartość zebranych pakietów: tcpdump -X.
  • -c- Przechwytuj tylko xpakiety, które xsą dowolnymi liczbami, na przykład tcpdump -c 10przechwytuje dokładnie 10 pakietów.
  • -v- Zwiększ ilość wyświetlanych informacji o pakietach, więcej vs dodaj więcej gadatliwości.

Każdy z wymienionych tutaj parametrów można łączyć ze sobą. Jeśli chcesz przechwycić 100 pakietów, ale tylko na interfejsie VPN tun0, wówczas polecenie tcpdump wyglądałoby tak:

tcpdump -i tun0 -c 100 -X

Oprócz tych kilku są dziesiątki (jeśli nie setki) opcji, ale są one najczęściej spotykane. Zapraszam do przeczytania strony podręcznika tcpdump w twoim systemie.

Teraz, gdy znasz podstawy tcpdump, czas spojrzeć na jedną z najbardziej niesamowitych funkcji tcpdump: wyrażenia. Wyrażenia znacznie ułatwią ci życie. Są one również znane jako BPF lub Berkeley Packet Filters. Używanie wyrażeń umożliwia selektywne wyświetlanie (lub ignorowanie) pakietów w oparciu o pewne cechy charakterystyczne - takie jak pochodzenie, miejsce docelowe, rozmiar, a nawet numer kolejny TCP.

Do tej pory udało ci się ograniczyć wyszukiwanie do określonej liczby pakietów na określonym interfejsie, ale bądźmy szczerzy: wciąż pozostawia zbyt dużo hałasu w tle, aby skutecznie pracować z zebranymi danymi. To tutaj pojawiają się wyrażenia. Pomysł jest dość prosty, więc pomińmy suchą teorię tutaj i popieramy zrozumienie kilkoma praktycznymi przykładami.

Wyrażenia, których prawdopodobnie będziesz używać najczęściej, to:

  • host - Poszukaj ruchu na podstawie nazw hostów lub adresów IP.
  • srclub dst- Poszukaj ruchu z lub do określonego hosta.
  • proto- Poszukaj ruchu określonego protokołu. Działa z tcp, udp, icmp i innymi. protoMożliwe jest także pominięcie słowa kluczowego.
  • net - Poszukaj ruchu do / z określonego zakresu adresów IP.
  • port - Poszukaj ruchu do / z określonego portu.
  • greaterlub less- Poszukaj ruchu większego lub mniejszego niż pewna ilość bajtów.

Podczas gdy strona man tcpdumpzawiera tylko kilka przykładów, strona man pcap-filterzawiera bardzo szczegółowe wyjaśnienia dotyczące działania każdego filtra i można je zastosować.

Jeśli chcesz zobaczyć, jak przebiega komunikacja z określonym serwerem, możesz hostna przykład użyć słowa kluczowego (w tym niektórych parametrów z powyższego):

tcpdump -i eth0 host vultr.com

Czasami w sieci są komputery, które nie honorują MTU ani nie wysyłają spamu dużymi pakietami; ich odfiltrowanie może czasem być trudne. Wyrażenia pozwalają na odfiltrowanie pakietów większych lub mniejszych niż pewna liczba bajtów:

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

Może interesuje Cię tylko określony port. W takim przypadku użyj portwyrażenia:

tcpdump -i eth0 -X port 21

Możesz także poszukać zakresów portów:

tcdump -i eth0 -X portrange 22-25

Ponieważ bramy NAT są dość powszechne, możesz szukać tylko portów docelowych:

tcpdump dst port 80

Jeśli oglądasz ruch do swojego serwera internetowego, możesz chcieć przyjrzeć się tylko ruchowi TCP do portu 80:

tcpdump tcp and dst port 80

Prawdopodobnie zastanawiasz się, co andtam robi słowo kluczowe . Dobre pytanie. To prowadzi nas do ostatniej części tego artykułu.

tcpdump oferuje podstawową obsługę wyrażeń logicznych, a dokładniej:

  • and/ &&- Logiczne ”i„.
  • or/ ||- Logiczne ”lub„.
  • not/ !- Logiczne „nie”.

Wraz z możliwością grupowania wyrażeń razem pozwala to na tworzenie bardzo skutecznych wyszukiwań ruchu przychodzącego i wychodzącego. Odfiltrujmy więc ruch przychodzący z vultr.com na porcie 22 lub 443:

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

Uruchomienie tego w wierszu polecenia spowoduje następujący błąd:

bash: syntax error near unexpected token `('

Jest tak, ponieważ istnieje zastrzeżenie: bashpróbuje ocenić każdą postać, jaką potrafi. Obejmuje to znaki (i ). Aby uniknąć tego błędu, należy używać pojedynczych cudzysłowów wokół połączonego wyrażenia:

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

Kolejny przydatny przykład: debugując problemy SSH z jednym z użytkowników, możesz zignorować wszystko, co jest związane z twoją sesją SSH:

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

Ponownie, przypadki użycia są nieograniczone i możesz określić w ekstremalnych głębokościach, jaki rodzaj ruchu chcesz zobaczyć. Następujące polecenie pokaże tylko pakiety SYNACK uzgadniania TCP:

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

Działa to poprzez sprawdzenie trzynastego przesunięcia nagłówka TCP i osiemnastego bajtu w nim zawartego.

Jeśli udało Ci się to zrobić tutaj, jesteś gotowy na większość przypadków użycia, które się pojawią. Ledwo mogę dotknąć powierzchni bez wchodzenia w zbyt wiele szczegółów. Gorąco polecam eksperymentowanie z różnymi opcjami i wyrażeniami nieco dalej; i jak zwykle: zajrzyj do strony podręcznika, gdy się zgubisz.

Last but not least - szybkie spojrzenie wstecz. Pamiętasz początek tego artykułu? Z tysiącami pakietów przechwyconych w ciągu kilku sekund? Moc tcpdumpmoże to znacznie obniżyć:

tcpdump -i eth0 tcp port 22

Wynik jest teraz:

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

Jest to znacznie zdrowsze i łatwiejsze do debugowania. Udanego nawiązywania kontaktów!



Leave a Comment

Jak zainstalować platformę koszyków LiteCart na Ubuntu 16.04

Jak zainstalować platformę koszyków LiteCart na Ubuntu 16.04

LiteCart to darmowa i otwarta platforma koszyka na zakupy napisana w PHP, jQuery i HTML 5. Jest to prosty, lekki i łatwy w użyciu program do handlu elektronicznego

Jak zainstalować Anchor CMS na CentOS 7 LAMP VPS

Jak zainstalować Anchor CMS na CentOS 7 LAMP VPS

Używasz innego systemu? Anchor CMS to bardzo prosty i niezwykle lekki, darmowy i otwarty system zarządzania treścią (CMS) Blog Engine, który

Skonfiguruj udział NFS na Debianie

Skonfiguruj udział NFS na Debianie

NFS to oparty na sieci system plików, który umożliwia komputerom dostęp do plików w sieci komputerowej. Ten przewodnik wyjaśnia, w jaki sposób możesz udostępniać foldery w NF

Jak zainstalować Matomo Analytics na Fedorze 28

Jak zainstalować Matomo Analytics na Fedorze 28

Używasz innego systemu? Matomo (wcześniej Piwik) to platforma analityczna typu open source, otwarta alternatywa dla Google Analytics. Źródło Matomo jest hostowane o

Skonfiguruj serwer TeamTalk w systemie Linux

Skonfiguruj serwer TeamTalk w systemie Linux

TeamTalk to system konferencyjny, który pozwala użytkownikom na wysokiej jakości rozmowy audio / wideo, czat tekstowy, przesyłanie plików i udostępnianie ekranów. To ja

Jak uzyskać dostęp do Vultr VPS

Jak uzyskać dostęp do Vultr VPS

Vultr oferuje kilka różnych sposobów uzyskiwania dostępu do VPS w celu konfiguracji, instalacji i użytkowania. Poświadczenia dostępu Domyślne poświadczenia dostępu dla twojego VPS ar

Jak zainstalować Ranger Terminal File Manager w systemie Linux

Jak zainstalować Ranger Terminal File Manager w systemie Linux

Ranger to oparty na linii poleceń menedżer plików z powiązaniami klawiszy VI. Zapewnia minimalistyczny i ładny interfejs curses z widokiem na hierarchię katalogów

Skonfiguruj klaster RethinkDB w CentOS 7

Skonfiguruj klaster RethinkDB w CentOS 7

Wprowadzenie RethinkDB to baza danych NoSQL, która przechowuje dane jako dokumenty JSON. Ma bardzo intuicyjny język zapytań i funkcje powszechnie dostępne

Skonfiguruj Magento na CentOS 6

Skonfiguruj Magento na CentOS 6

Niezależnie od tego, czy chcesz umieścić zapasy sklepów online, czy po prostu prosty sklep z akcesoriami technicznymi, Magento jest doskonałym rozwiązaniem dla eCommerce online. Ten artykuł

Jak zbudować Brotli ze źródła na Ubuntu 18.04 LTS

Jak zbudować Brotli ze źródła na Ubuntu 18.04 LTS

Używasz innego systemu? Brotli to nowa metoda kompresji z lepszym współczynnikiem kompresji niż GZIP. Jego kod źródłowy jest publicznie hostowany na tym Githu

Korzystanie z widoków MySQL w Debianie 7

Korzystanie z widoków MySQL w Debianie 7

Wprowadzenie MySQL ma świetną funkcję znaną jako widoki. Widoki są przechowywane zapytania. Pomyśl o nich jako o aliasie dla długiego zapytania. W tym przewodniku

Wyłącz lub ogranicz logowanie roota przez SSH w systemie Linux

Wyłącz lub ogranicz logowanie roota przez SSH w systemie Linux

Zezwolenie na logowanie roota przez SSH jest powszechnie uważane za słabą praktykę bezpieczeństwa w branży technologicznej. Zamiast tego możesz wykonać delikatną administrację

Jak zainstalować Neos CMS na CentOS 7

Jak zainstalować Neos CMS na CentOS 7

Neos to innowacyjny system zarządzania treścią typu open source, który doskonale nadaje się do tworzenia i edytowania treści online. Z myślą o autorach i redaktorach, Neo

Jak zainstalować Vtiger CRM Open Source Edition na CentOS 7

Jak zainstalować Vtiger CRM Open Source Edition na CentOS 7

Vtiger CRM to popularna aplikacja do zarządzania relacjami z klientami, która może pomóc przedsiębiorstwom zwiększyć sprzedaż, zapewnić obsługę klienta i zwiększyć zyski. ja

Jak zainstalować DokuWiki na Ubuntu 16.04 LTS

Jak zainstalować DokuWiki na Ubuntu 16.04 LTS

Używasz innego systemu? DokuWiki to program wiki typu open source napisany w PHP, który nie wymaga bazy danych. Przechowuje dane w plikach tekstowych. DokuWik

Konfigurowanie chroota w Debianie

Konfigurowanie chroota w Debianie

W tym artykule dowiesz się, jak skonfigurować więzienie chroot w Debianie. Zakładam, że używasz Debiana 7.x. Jeśli używasz Debiana 6 lub 8, może to działać, bu

Jak zainstalować PiVPN na Debianie

Jak zainstalować PiVPN na Debianie

Wprowadzenie Prostym sposobem na skonfigurowanie serwera VPN na Debianie jest PiVPN. PiVPN to instalator i opakowanie dla OpenVPN. Tworzy proste polecenia dla ciebie

Jak zainstalować MaraDNS na CentOS 6

Jak zainstalować MaraDNS na CentOS 6

MaraDNS to lekki, ale solidny program serwera DNS typu open source. W porównaniu z innymi aplikacjami tego samego rodzaju, takimi jak ISC BIND, PowerDNS i djbdns

Jak zainstalować i skonfigurować CyberPanel na Ubuntu 18.04 LTS

Jak zainstalować i skonfigurować CyberPanel na Ubuntu 18.04 LTS

Używasz innego systemu? Wprowadzenie CyberPanel jest jednym z pierwszych paneli sterowania na rynku, który jest zarówno open source, jak i wykorzystuje OpenLiteSpeed. Co ty?

Jak zainstalować forum NodeBB na Fedorze 28

Jak zainstalować forum NodeBB na Fedorze 28

Używasz innego systemu? NodeBB jest forum opartym na Node.js. Wykorzystuje gniazda sieciowe do natychmiastowych interakcji i powiadomień w czasie rzeczywistym. Kod źródłowy NodeBB i

Funkcjonalności warstw architektury referencyjnej Big Data

Funkcjonalności warstw architektury referencyjnej Big Data

Przeczytaj blog, aby w najprostszy sposób poznać różne warstwy w architekturze Big Data i ich funkcjonalności.

Rewolucyjne wynalazki Google, które ułatwią Twoje życie.

Rewolucyjne wynalazki Google, które ułatwią Twoje życie.

Chcesz zobaczyć rewolucyjne wynalazki Google i jak te wynalazki zmieniły życie każdego człowieka dzisiaj? Następnie czytaj na blogu, aby zobaczyć wynalazki Google.

13 komercyjnych narzędzi do ekstrakcji danych z Big Data

13 komercyjnych narzędzi do ekstrakcji danych z Big Data

13 komercyjnych narzędzi do ekstrakcji danych z Big Data

Pozostań w kontakcie dzięki aplikacji WhatsApp na komputer 24*7

Pozostań w kontakcie dzięki aplikacji WhatsApp na komputer 24*7

Whatsapp w końcu uruchomił aplikację Desktop dla użytkowników komputerów Mac i Windows. Teraz możesz łatwo uzyskać dostęp do Whatsapp z systemu Windows lub Mac. Dostępne dla Windows 8+ i Mac OS 10.9+

5 przykładów, które dowodzą, że energetyka jądrowa nie zawsze jest zła

5 przykładów, które dowodzą, że energetyka jądrowa nie zawsze jest zła

Energia jądrowa jest zawsze pogardzana, nigdy jej nie szanujemy z powodu przeszłych wydarzeń, ale nie zawsze jest zła. Przeczytaj post, aby dowiedzieć się więcej na ten temat.

Friday Essential: Co się stało z samochodami sterowanymi przez sztuczną inteligencję?

Friday Essential: Co się stało z samochodami sterowanymi przez sztuczną inteligencję?

Koncepcja autonomicznych samochodów, które wyjadą na drogi za pomocą sztucznej inteligencji, to marzenie, które mamy już od jakiegoś czasu. Ale pomimo kilku obietnic nigdzie ich nie widać. Przeczytaj ten blog, aby dowiedzieć się więcej…

Czy AI może walczyć z rosnącą liczbą ataków ransomware?

Czy AI może walczyć z rosnącą liczbą ataków ransomware?

Wzrasta liczba ataków ransomware, ale czy sztuczna inteligencja może pomóc w radzeniu sobie z najnowszym wirusem komputerowym? Czy AI jest odpowiedzią? Przeczytaj tutaj, wiedz, że sztuczna inteligencja jest zmorą lub zgubą

5 przydatnych narzędzi sztucznej inteligencji, które uproszczą Twoje życie

5 przydatnych narzędzi sztucznej inteligencji, które uproszczą Twoje życie

Sztuczna inteligencja nie jest dla ludzi nową nazwą. Ponieważ sztuczna inteligencja jest włączona do każdego strumienia, jednym z nich jest opracowywanie narzędzi zwiększających ludzką wydajność i dokładność. Skorzystaj z tych niesamowitych narzędzi uczenia maszynowego i uprość swoje codzienne zadania.

Wgląd w 26 technik analizy Big Data: część 2

Wgląd w 26 technik analizy Big Data: część 2

Zawsze potrzebujemy Big Data Analytics do efektywnego zarządzania danymi. W tym artykule omówiliśmy kilka technik analizy Big Data. Sprawdź ten artykuł.

Ataki DDOS: krótki przegląd

Ataki DDOS: krótki przegląd

Czy jesteś również ofiarą ataków DDOS i nie masz pewności co do metod zapobiegania? Przeczytaj ten artykuł, aby rozwiązać swoje pytania.