آشنایی با Tcpdump

اگر سرور را راه اندازی کنید ، بدون شک به جایی خواهید رسید که باید مشکلات مربوط به شبکه را ناخوشایند کنید. مطمئناً فقط شلیک نامه به بخش پشتیبانی آسان است ، اما بعضی اوقات باید کثیف شوید. در این حالت tcpdumpابزاری برای آن کار است. Tcpdump یک آنالایزر پکیج شبکه است که در زیر خط فرمان اجرا می شود.

این مقاله به سه بخش تقسیم می شود:

  • ویژگی های اساسی.
  • فیلتر بر اساس ویژگی های خاص ترافیکی.
  • قطعه ای کوتاه از ویژگی های پیشرفته تر (مانند عبارات منطقی ، فیلتر توسط پرچم های TCP).

از آنجا که tcpdump در اکثر سیستم های پایه گنجانده نشده است ، شما نیاز به نصب آن دارید. با این حال ، تقریباً همه توزیعهای لینوکس در مخازن اصلی خود دارای tcpdump هستند. برای توزیع های مبتنی بر Debian ، دستور نصب tcpdump عبارت است از:

apt-get install tcpdump

برای CentOS / RedHat از دستور زیر استفاده کنید:

yum install tcpdump

FreeBSD بسته ای از پیش ساخته را ارائه می دهد که با صدور زیر قابل نصب است:

pkg install tcpdump

همچنین یک درگاه در دسترس است net/tcpdumpکه می تواند از طریق:

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

اگر tcpdumpبدون هیچگونه استدلالی اجرا شوید ، از نتیجه بدست می آیید. اجرای آن روی یک نمونه تازه چرخش شده در اینجا در Vultr برای کمتر از پنج ثانیه نتیجه زیر را می دهد:

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

قبل از جزییات بیشتر در مورد نحوه فیلتر کردن ورودی ، باید نگاهی به پارامترهای قابل انتقال به tcpdump بیندازید:

  • -i- رابط مورد نظر برای گوش دادن را مشخص می کند ، به عنوان مثال tcpdump -i eth0:.
  • -n- سعی نکنید به جستجوی معکوس در آدرس های IP tcpdump -nبپردازید ، به عنوان مثال: (اگر ntcpdump دیگری اضافه کنید ، شماره پورت را به جای نام نشان می دهد).
  • -X- محتوای بسته های جمع آوری شده را نشان دهید tcpdump -X:.
  • -c- فقط xبسته ها را ضبط کنید ، به xعنوان یک تعداد دلخواه ، به عنوان مثال tcpdump -c 10دقیقاً 10 بسته را ضبط می کند.
  • -v- مقدار بسته اطلاعاتی را که نشان داده می شود ، افزایش دهید ، بیشتر vباعث سیر و لعاب بیشتر می شوند.

هر یک از پارامترهای ذکر شده در اینجا می توانند با هم ترکیب شوند. اگر می خواستید 100 بسته را ضبط کنید ، اما فقط در رابط VPN شما tun0 ، پس دستور tcpdump به شکل زیر ظاهر می شود:

tcpdump -i tun0 -c 100 -X

علاوه بر این تعداد معدود ، ده ها (اگر نه صدها) گزینه وجود دارد ، اما رایج ترین آنها هستند. احساس رایگان کنید که manction tcpdump را در سیستم خود بخوانید.

اکنون که درک اساسی از tcpdump دارید ، وقت آن است که به یکی از جالب ترین ویژگی های tcpdump نگاه کنید: عبارت. عبارات باعث می شود زندگی شما بسیار ساده تر شود. آنها همچنین به عنوان فیلترهای بسته بندی BPF یا Berkeley Packet شناخته می شوند. استفاده از عبارات به شما امکان می دهد بسته های مختلف را بر اساس ویژگی های خاص - مانند مبدا ، مقصد ، اندازه یا حتی شماره دنباله TCP - به صورت انتخابی نمایش دهید (یا نادیده بگیرید).

تاکنون موفق شده اید که جستجوی خود را به مقدار مشخصی از بسته ها در یک رابط خاص محدود کنید ، اما بیایید صادقانه بگویم: این هنوز صدای پس زمینه زیادی را برای کارآمد با داده های جمع آوری شده باقی می گذارد. در اینجاست که عبارات بازی می شوند. این مفهوم بسیار ساده است ، بنابراین ما تئوری خشک را در اینجا کنار می گذاریم و با برخی مثال های عملی از درک پشتیبانی خواهیم کرد.

عباراتی که احتمالاً بیشترین استفاده را خواهید کرد عبارتند از:

  • host - به دنبال ترافیک بر اساس نام های میزبان یا آدرس های IP باشید.
  • srcیا dst- به دنبال ترافیک از یا به هاست خاص باشید.
  • proto- به دنبال ترافیک یک پروتکل خاص باشید. برای tcp ، udp ، icmp و دیگران کار می کند. ترک کردن protoکلمه کلیدی نیز ممکن است.
  • net - به دنبال مراجعه به / از طیف خاصی از آدرسهای IP باشید.
  • port - به دنبال ترافیک به / از یک درگاه مشخص باشید.
  • greaterیا less- به دنبال ترافیکی بزرگتر یا کوچکتر از مقدار مشخصی از بایت باشید.

در حالی که manpage tcpdumpفقط شامل چند نمونه است ، manpage pcap-filterتوضیحات بسیار مفصلی درباره نحوه کار و استفاده از هر فیلتر دارد.

اگر می خواهید ببینید ارتباط شما با یک سرور خاص چگونه انجام می شود ، می توانید hostبه عنوان مثال از کلمه کلیدی استفاده کنید (شامل برخی از پارامترهای از بالا):

tcpdump -i eth0 host vultr.com

بعضی اوقات رایانه هایی در شبکه وجود دارند که MTU را رعایت نمی کنند یا با بسته های بزرگ شما را اسپم می کنند. فیلتر کردن بعضی اوقات ممکن است دشوار باشد. عبارات به شما امکان می دهد بسته های بزرگتر یا کوچکتر از تعداد مشخصی از بایت ها را فیلتر کنید:

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

شاید فقط یک بندر خاص مورد توجه شما باشد. در این حالت از portعبارت استفاده کنید :

tcpdump -i eth0 -X port 21

همچنین می توانید از محدوده بندر استفاده کنید:

tcdump -i eth0 -X portrange 22-25

از آنجا که دروازه های NAT بسیار معمول هستند ، شما فقط می توانید به دنبال پورت های مقصد باشید:

tcpdump dst port 80

اگر ترافیک وب سرور خود را مشاهده می کنید ، فقط ممکن است بخواهید به ترافیک TCP به پورت 80 نگاه کنید:

tcpdump tcp and dst port 80

احتمالاً از خود می پرسید که این کلمه کلیدی andدر آنجا انجام می شود. سؤال خوبی بود. این ما را به قسمت آخر این مقاله می رساند.

tcpdump به طور خاص پشتیبانی بیشتری برای عبارات منطقی ارائه می دهد:

  • and/ &&- منطقی "و".
  • or/ ||- منطقی "یا".
  • not/ !- منطقی "نه".

بهمراه امکان گروه بندی اصطلاحات در کنار هم ، این امر به شما امکان می دهد جستجوهای بسیار قدرتمندی برای ترافیک ورودی و خروجی ایجاد کنید. بنابراین اجازه دهید ترافیکی که از vultr.com در پورت 22 یا 443 دریافت می شود را فیلتر کنیم:

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

اجرای این کار در خط فرمان خطای زیر را به شما می دهد:

bash: syntax error near unexpected token `('

دلیلش این است که یک احتیاط وجود دارد: bashسعی می کند هر شخصیتی را که می تواند ارزیابی کند. این شامل شخصیت ها (و )شخصیت ها می شود. برای جلوگیری از این خطا ، باید از نقل قولهای واحدی پیرامون عبارت ترکیبی استفاده کنید:

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

مثال مفید دیگر: هنگام اشکال زدایی در مورد مشکلات SSH با یکی از کاربران خود ، ممکن است بخواهید همه موارد مرتبط با جلسه SSH خود را نادیده بگیرید:

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

مجدداً موارد استفاده بی پایان است و می توانید نوع ترافیکی را که می خواهید ببینید در اعماق شدید مشخص کنید. دستور زیر فقط بسته های SYNACK دستی TCP را نشان می دهد:

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

این کار با نگاه کردن به سیزدهمین افست هدر TCP و هجدهمین بایت درون آن کار می کند.

اگر آن را تا اینجا ساخته اید ، برای اکثر موارد استفاده که آماده می شوند ، آماده هستید. من به سختی می توانم سطح را لمس کنم بدون اینکه به جزئیات خیلی زیادی برسم. من بسیار توصیه می کنم کمی بیشتر با گزینه ها و اصطلاحات مختلف آزمایش کنید. و طبق معمول: هنگام گم شدن به صفحه اصلی مراجعه کنید.

تاریخ و زمان آخرین اما نه چندان مهم - نگاهی گذرا به عقب. شروع این مقاله را به خاطر دارید؟ با هزاران بسته دستگیر شده در عرض چند ثانیه؟ قدرت tcpdumpمی تواند آن را کم کند:

tcpdump -i eth0 tcp port 22

نتیجه اکنون است:

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

اشکال زدایی بسیار راحت تر و آسان تر است. شبکه سازی مبارک!



Leave a Comment

نحوه نصب بستر سبد خرید LiteCart در اوبونتو 16.04

نحوه نصب بستر سبد خرید LiteCart در اوبونتو 16.04

LiteCart یک بستر سبد خرید آزاد و منبع باز است که به زبان های PHP ، jQuery و HTML 5 نوشته شده است. این نرم افزار ساده ، سبک و با کاربرد آسان است.

نحوه نصب Anchor CMS بر روی یک VPS Fedora 26 LAMP

نحوه نصب Anchor CMS بر روی یک VPS Fedora 26 LAMP

با استفاده از یک سیستم متفاوت؟ Anchor CMS یک سیستم مدیریت محتوا (CMS) بسیار ساده و بسیار سبک ، بسیار آزاد و آزاد است.

اشتراک NFS را در Debian تنظیم کنید

اشتراک NFS را در Debian تنظیم کنید

NFS یک سیستم فایل مبتنی بر شبکه است که به رایانه ها اجازه می دهد تا از طریق شبکه رایانه ای به فایلها دسترسی پیدا کنند. این راهنما توضیح می دهد که چگونه می توانید پوشه ها را روی NF قرار دهید

نحوه نصب Matomo Analytics در Fedora 28

نحوه نصب Matomo Analytics در Fedora 28

با استفاده از یک سیستم متفاوت؟ Matomo (سابقا پیویک) یک بستر تحلیلی منبع باز است ، یک جایگزین باز برای Google Analytics. منبع Matomo میزبان o

یک سرور TeamTalk را در لینوکس تنظیم کنید

یک سرور TeamTalk را در لینوکس تنظیم کنید

TeamTalk یک سیستم کنفرانس است که به کاربران امکان می دهد مکالمات صوتی / تصویری با کیفیت بالا ، چت متنی ، انتقال فایل ها و صفحه های به اشتراک بگذارند. من

با استفاده از کلید SSH خود برای ورود به کاربران غیر ریشه استفاده کنید

با استفاده از کلید SSH خود برای ورود به کاربران غیر ریشه استفاده کنید

Vultr یک ویژگی را فراهم می کند که به شما امکان می دهد با ایجاد یک نمونه جدید ، کلیدهای SSH را از قبل نصب کنید. این اجازه می دهد تا به کاربر root دسترسی داشته باشید ، با این حال ، th

نحوه نصب Ranger Terminal File Manager در لینوکس

نحوه نصب Ranger Terminal File Manager در لینوکس

رنجر یک مدیر فایل مبتنی بر خط فرمان است که دارای کلیدهای اتصال VI است. این برنامه یک رابط لعنتی مینیمالیستی و زیبا با نمای سلسله مراتب فهرست ارائه می دهد

تنظیم RethinkDB Cluster On CentOS 7

تنظیم RethinkDB Cluster On CentOS 7

مقدمه RethinkDB یک پایگاه داده NoSQL است که داده ها را به عنوان اسناد JSON ذخیره می کند. این یک زبان پرس و جو بسیار بصری است و از ویژگی های آن معمولا در دسترس است

نحوه ساخت Brotli از Source on Ubuntu 18.04 LTS

نحوه ساخت Brotli از Source on Ubuntu 18.04 LTS

با استفاده از یک سیستم متفاوت؟ Brotli یک روش فشرده سازی جدید با نسبت فشرده سازی بهتر از GZIP است. کد منبع آن در این Githu به صورت عمومی میزبانی می شود

با استفاده از نمایش های MySQL در Debian 7

با استفاده از نمایش های MySQL در Debian 7

مقدمه MySQL دارای یک ویژگی عالی است که به عنوان بازدید شناخته می شود. نمایش نمایش داده شد. برای یک سؤال طولانی مدت از آنها فکر کنید. در این راهنما ،

غیرفعال یا محدود کردن ورود ریشه از طریق SSH در لینوکس

غیرفعال یا محدود کردن ورود ریشه از طریق SSH در لینوکس

اجازه ورود به سیستم ریشه در SSH معمولاً یک روش امنیتی ضعیف در کل صنعت فناوری تلقی می شود. درعوض ، می توانید اداری حساس را انجام دهید

نحوه نصب نسخه باز Vtiger CRM در CentOS 7

نحوه نصب نسخه باز Vtiger CRM در CentOS 7

Vtiger CRM یک نرم افزار محبوب مدیریت ارتباط با مشتری است که می تواند به بنگاهها در رشد فروش ، ارائه خدمات به مشتری و افزایش سود کمک کند. من

نحوه نصب DokuWiki در اوبونتو 16.04 LTS

نحوه نصب DokuWiki در اوبونتو 16.04 LTS

با استفاده از یک سیستم متفاوت؟ DokuWiki یک برنامه ویکی منبع باز است که به زبان پی اچ پی نوشته شده است و به پایگاه داده نیاز ندارد. این داده ها را در پرونده های متنی ذخیره می کند. DokuWik

راه اندازی یک Chroot در دبیان

راه اندازی یک Chroot در دبیان

در این مقاله به شما می آموزد که چگونه زندان دزدگیر را در دبیان تنظیم کنید. تصور می کنم از Debian 7.x استفاده می کنید. اگر دبیان 6 یا 8 را اجرا کردید ، ممکن است این کار کند

نحوه نصب PiVPN در Debian

نحوه نصب PiVPN در Debian

مقدمه یک راه آسان برای راه اندازی سرور VPN در دبیان با PiVPN است. PiVPN نصب و بسته بندی OpenVPN است. این دستورات ساده را برای شما ایجاد می کند

Nginx ، Wordpress را نصب کنید و رمزگذاری را در چند دقیقه با EasyEngine روی Debian 8 یا Ubuntu 16.04 نصب کنید

Nginx ، Wordpress را نصب کنید و رمزگذاری را در چند دقیقه با EasyEngine روی Debian 8 یا Ubuntu 16.04 نصب کنید

EasyEngine (ee) ابزاری پایتون است که به شما امکان می دهد سایت های وردپرس خود را به راحتی و به صورت خودکار مدیریت کنید. با استفاده از EasyEngine ، شما مجبور به dea نیستید

نحوه نصب و پیکربندی CyberPanel در Ubuntu 18.04 LTS

نحوه نصب و پیکربندی CyberPanel در Ubuntu 18.04 LTS

با استفاده از یک سیستم متفاوت؟ مقدمه CyberPanel یکی از اولین صفحه کنترل در بازار است که هم منبع باز است و هم از OpenLiteSpeed ​​استفاده می کند. چی

نحوه ساخت Brotli از Source on Debian 9

نحوه ساخت Brotli از Source on Debian 9

با استفاده از یک سیستم متفاوت؟ Brotli یک روش فشرده سازی جدید با نسبت فشرده سازی بهتر از Gzip است. کد منبع آن در Github به صورت عمومی میزبانی می شود. تی

نحوه نصب کاناپه CMS 2.0 بر روی یک VPS CentOS 7 LAMP

نحوه نصب کاناپه CMS 2.0 بر روی یک VPS CentOS 7 LAMP

با استفاده از یک سیستم متفاوت؟ Couch CMS یک سیستم مدیریت محتوای منبع ساده و انعطاف پذیر ، آزاد و منبع باز (CMS) است که به طراحان وب اجازه می دهد تا طراحی کنند.

ایجاد یک سرور Teamspeak 3 در اوبونتو 14 64 بیتی

ایجاد یک سرور Teamspeak 3 در اوبونتو 14 64 بیتی

بررسی اجمالی که آیا شما در حال همکاری در یک پروژه همکاری بزرگ با تیم توسعه خود هستید و یا در جدیدترین بازی نقش آفرینی رئیس را می کشید ، می خواهید

نحوه نصب بستر سبد خرید LiteCart در اوبونتو 16.04

نحوه نصب بستر سبد خرید LiteCart در اوبونتو 16.04

LiteCart یک بستر سبد خرید آزاد و منبع باز است که به زبان های PHP ، jQuery و HTML 5 نوشته شده است. این نرم افزار ساده ، سبک و با کاربرد آسان است.

نحوه نصب Anchor CMS بر روی یک VPS Fedora 26 LAMP

نحوه نصب Anchor CMS بر روی یک VPS Fedora 26 LAMP

با استفاده از یک سیستم متفاوت؟ Anchor CMS یک سیستم مدیریت محتوا (CMS) بسیار ساده و بسیار سبک ، بسیار آزاد و آزاد است.

اشتراک NFS را در Debian تنظیم کنید

اشتراک NFS را در Debian تنظیم کنید

NFS یک سیستم فایل مبتنی بر شبکه است که به رایانه ها اجازه می دهد تا از طریق شبکه رایانه ای به فایلها دسترسی پیدا کنند. این راهنما توضیح می دهد که چگونه می توانید پوشه ها را روی NF قرار دهید

نحوه بروزرسانی CentOS 7 ، Ubuntu 16.04 و Debian 8

نحوه بروزرسانی CentOS 7 ، Ubuntu 16.04 و Debian 8

هنگام راه اندازی سرور جدید لینوکس ، به روزرسانی سیستم های هسته و سایر بسته ها تا آخرین نسخه پایدار یک روش توصیه شده است. در این مقاله

نحوه نصب Matomo Analytics در Fedora 28

نحوه نصب Matomo Analytics در Fedora 28

با استفاده از یک سیستم متفاوت؟ Matomo (سابقا پیویک) یک بستر تحلیلی منبع باز است ، یک جایگزین باز برای Google Analytics. منبع Matomo میزبان o

یک سرور TeamTalk را در لینوکس تنظیم کنید

یک سرور TeamTalk را در لینوکس تنظیم کنید

TeamTalk یک سیستم کنفرانس است که به کاربران امکان می دهد مکالمات صوتی / تصویری با کیفیت بالا ، چت متنی ، انتقال فایل ها و صفحه های به اشتراک بگذارند. من

با استفاده از کلید SSH خود برای ورود به کاربران غیر ریشه استفاده کنید

با استفاده از کلید SSH خود برای ورود به کاربران غیر ریشه استفاده کنید

Vultr یک ویژگی را فراهم می کند که به شما امکان می دهد با ایجاد یک نمونه جدید ، کلیدهای SSH را از قبل نصب کنید. این اجازه می دهد تا به کاربر root دسترسی داشته باشید ، با این حال ، th

نحوه نصب انجمن NodeBB در FreeBSD 12

نحوه نصب انجمن NodeBB در FreeBSD 12

با استفاده از یک سیستم متفاوت؟ NodeBB یک نرم افزار انجمن مبتنی بر Node.js است. از سوکت های وب برای تعامل فوری و اعلامیه های زمان واقعی استفاده می کند. NodeB

نصب و راه اندازی ZNC در اوبونتو

نصب و راه اندازی ZNC در اوبونتو

ZNC یک پیشرانه پیشرفته شبکه IRC است که تمام وقت بهم متصل می شود تا مشتری IRC بتواند بدون از دست دادن جلسه گپ قطع یا وصل شود.

نحوه نصب Ranger Terminal File Manager در لینوکس

نحوه نصب Ranger Terminal File Manager در لینوکس

رنجر یک مدیر فایل مبتنی بر خط فرمان است که دارای کلیدهای اتصال VI است. این برنامه یک رابط لعنتی مینیمالیستی و زیبا با نمای سلسله مراتب فهرست ارائه می دهد