دستور traceroute چگونه کار می‌کند؟

1404/08/29
8 بازدید
دستور traceroute

دستور traceroute چگونه کار می‌کند؟ دستور traceroute ابزاری است که مانند یک GPS برای داده‌های شما عمل می‌کند و هر «هاپ» (hop) یا توقف در طول مسیر، از کامپیوتر شما تا سرور مقصد را نقشه‌برداری می‌کند. در حالی که ابزاری مانند ping می‌تواند به شما بگوید که آیا به مقصد خود رسیده‌اید یا نه، traceroute کل نقشه سفر را به شما نشان می‌دهد. هدف این مقاله این است که به شما نشان دهد این ابزار قدرتمند چگونه با استفاده از یک مفهوم ساده به نام «Time-to-Live» یا TTL، این کار را انجام می‌دهد.

برای درک نبوغ traceroute، ابتدا باید مشکلی اساسی را که این مفهوم برای حل آن طراحی شده است، بشناسیم.

1. مشکل بسته‌های سرگردان: چرا اینترنت به یک قانون نیاز داشت؟

یکی از دوستان قدیمی‌ام زمانی به شوخی تصور می‌کرد که اینترنت پر از بسته‌های داده «جاودانه» است؛ بسته‌هایی که چون هرگز مقصد خود را پیدا نکرده‌اند، تا ابد در حال سرگردانی هستند. این فکر بامزه، در واقع یک نگرانی جدی برای معماران اولیه اینترنت بود. تصور کنید بسته‌ای به دلیل یک خطای پیکربندی در شبکه، در یک چرخه بی‌پایان گیر کند. آیا این بسته برای همیشه از یک روتر به روتر دیگر منتقل می‌شود و منابع شبکه را هدر می‌دهد؟

این وضعیت را می‌توان به نامه‌ای در سیستم پستی تشبیه کرد که آدرس گیرنده آن اشتباه است و آدرس فرستنده‌ای هم ندارد. چنین نامه‌ای می‌تواند برای همیشه در چرخه مرتب‌سازی اداره پست گیر کند.

برای جلوگیری از این هرج و مرج دیجیتال، طراحان اینترنت یک راه‌حل هوشمندانه ارائه کردند: Time-to-Live (TTL). این مفهوم به عنوان یک تاریخ انقضای داخلی برای هر بسته داده عمل می‌کند و تضمین می‌کند که هیچ بسته‌ای برای همیشه در شبکه سرگردان نخواهد ماند.

2. معرفی Time-to-Live (TTL): قانون «تعداد قدم‌های محدود»

به زبان ساده، Time-to-Live (TTL) عددی است که به هر بسته داده اختصاص داده می‌شود و مشخص می‌کند که آن بسته قبل از دور انداخته شدن، حداکثر از چند «هاپ» یا روتر می‌تواند عبور کند.

برای درک بهتر، این تشبیه را که برگرفته از منبع است، در نظر بگیرید. فرض کنید به یک پیام‌رسان وظیفه‌ای می‌دهید و یک قانون مشخص برای او تعیین می‌کنید:

“برو تا سر بقالی، ولی بیشتر از ۲۰۰۰ قدم راه نرو.”

در این سناریو، TTL همان عدد «۲۰۰۰» است که یک محدودیت سخاوتمندانه برای یک سفر مشخص است. با این قانون، مکانیسم زیر اتفاق می‌افتد:

• شمارش معکوس: با هر قدمی که پیام‌رسان برمی‌دارد (یا هر روتری که بسته از آن عبور می‌کند)، یک واحد از این عدد کم می‌شود.

• رسیدن به صفر: اگر پیام‌رسان پس از برداشتن ۲۰۰۰ قدم هنوز به بقالی نرسیده باشد، باید متوقف شود، وظیفه را لغو کند و به شما بازگردد تا اطلاع دهد که نتوانسته است با محدودیت تعیین‌شده به مقصد برسد.

در شبکه نیز دقیقاً همین اتفاق می‌افتد. وقتی TTL یک بسته به صفر می‌رسد، روتری که بسته را در اختیار دارد، آن را دور می‌اندازد و—این بخش بسیار مهم است—یک پیام خطا با عنوان «Time to Live exceeded» به فرستنده اصلی ارسال می‌کند.

این ویژگی ایمنی که برای جلوگیری از بسته‌های گمشده طراحی شده، به طرز هوشمندانه‌ای به پایه و اساس ابزار قدرتمند traceroute تبدیل شد.

3. ترفند هوشمندانه traceroute: تبدیل یک قانون ایمنی به ابزار نقشه‌برداری

نبوغ traceroute در این نیست که از ابتدا برای این کار طراحی شده بود—بلکه در یک کشف هوشمندانه نهفته است. مهندسان شبکه هنگام عیب‌یابی متوجه شدند که بسته‌ها پیام‌های خطای «Time to Live exceeded» را برمی‌گردانند و ناگهان یک ایده به ذهنشان رسید: «چه می‌شود اگر ما عمداً این خطا را ایجاد کنیم تا مسیر شبکه را نقشه‌برداری کنیم؟»

این ابزار به جای ارسال یک بسته با TTL بالا، یک مأموریت اکتشافی گام‌به‌گام را آغاز می‌کند:

1. قدم اول: کشف اولین همسایه (TTL=1) traceroute اولین بسته خود را با TTL=1 ارسال می‌کند. اولین روتر در مسیر (مثلاً مودم خانگی شما) بسته را دریافت کرده، TTL را یک واحد کم می‌کند و به ۰ می‌رساند. طبق قانون، روتر بسته را دور می‌اندازد و یک پیام خطا به کامپیوتر شما بازمی‌گرداند. این پیام خطا حاوی آدرس خود روتر است. نتیجه؟ ما آدرس اولین هاپ در مسیر را کشف کردیم!

2. قدم دوم: ساختن نقشه، هاپ به هاپ (TTL=2) اکنون traceroute یک بسته جدید با TTL=2 ارسال می‌کند. این بسته با موفقیت از اولین روتر عبور می‌کند (که در آنجا TTL آن به ۱ کاهش می‌یابد)، اما توسط روتر دوم متوقف می‌شود. روتر دوم TTL را به ۰ کاهش می‌دهد، بسته را دور می‌اندازد و یک پیام خطا به همراه آدرس خود بازمی‌گرداند. نتیجه؟ حالا ما هاپ دوم را هم می‌شناسیم!

3. تکرار فرآیند این فرآیند به طور خودکار تکرار می‌شود. traceroute هر بار TTL را یک واحد افزایش می‌دهد (TTL=3، TTL=4 و الی آخر) و به این ترتیب آدرس هر روتر در مسیر را یکی پس از دیگری کشف می‌کند.

4. قدم نهایی: تأیید رسیدن به مقصد اما traceroute چگونه می‌فهمد که به مقصد رسیده است؟ ترفند آخر این است که بسته‌های نهایی را به یک شماره پورت بسیار بالا و غیرمعمول در سرور مقصد ارسال می‌کند. از آنجایی که به احتمال زیاد سرویسی روی آن پورت در حال اجرا نیست، سرور مقصد با یک پیام خطای متفاوت پاسخ می‌دهد: «Port Unreachable». دریافت این پیام، تأیید قطعی است که بسته ما تمام مسیر را با موفقیت طی کرده است.

4. جمع‌بندی: مشاهده یک سفر در عمل

وقتی دستور traceroute را اجرا می‌کنید، نتیجه این فرآیند اکتشافی به شما نمایش داده می‌شود. برای اطمینان از دقت، traceroute معمولاً برای هر هاپ، سه بسته آزمایشی جداگانه ارسال می‌کند. خروجی آن شبیه به این است:

traceroute to 8.8.8.8 (8.8.8.8), 30 hops max
1  192.168.1.254 (مودم خانگی)                   1.2 ms  1.4 ms  1.5 ms
2  10.20.30.1 (سرور شرکت ارائه‌دهنده اینترنت)  7.5 ms  7.2 ms  7.9 ms
3  * * *
4  212.55.100.5 (یک روتر دیگر در شبکه)        29.1 ms 28.8 ms 29.5 ms
...
7  8.8.8.8 (سرور مقصد گوگل)                   55.0 ms 54.5 ms 56.1 ms

نکته: سه ستاره (* * *) در خط سوم به این معنی است که روتر مربوطه به بسته‌های آزمایشی پاسخ نداده است که این اتفاق معمولاً به دلیل تنظیمات فایروال رخ می‌دهد.

هر خط از این خروجی، اطلاعات مربوط به یک هاپ در مسیر را نشان می‌دهد:

بخش توضیحات
شماره هاپ ترتیب روتر در مسیر (مثلاً 123).
آدرس IP آدرس منحصر به فرد آن روتر.
زمان پاسخ مدت زمان رفت و برگشت برای هر یک از سه پیام خطا از آن هاپ. این زمان‌ها به میلی‌ثانیه (ms) اندازه‌گیری می‌شوند.

با کنار هم قرار دادن این اطلاعات، traceroute یک تصویر واضح از کل سفر داده‌های شما، از نقطه شروع تا مقصد، ارائه می‌دهد.

نتیجه‌گیری: هوش پنهان در ابزارهای شبکه

traceroute گواهی بر نبوغ زیبا و اغلب ساده‌ای است که در ابزارهای شبکه ما پنهان شده است. این ابزار به طرز هوشمندانه‌ای یک ویژگی ایمنی شبکه (TTL) را برای ارائه یک نقشه دقیق از سفر اینترنتی، به کار می‌گیرد.

درست مانند پیام‌رسانی که با قانون «تعداد قدم‌های محدود» فرستاده شد، traceroute نیز با محدود کردن سفر هر بسته، به صورت گام به گام مسیر را کشف می‌کند. درک این مفاهیم بنیادی، کلید اصلی برای کسب دانش بیشتر در مورد نحوه عملکرد اینترنت و ابزارهای قدرتمند آن است.

دیدگاهتان را بنویسید

نشانی ایمیل شما منتشر نخواهد شد. بخش‌های موردنیاز علامت‌گذاری شده‌اند *

آخرین مقالات