0
mini-cart-logo

سبد خرید شما خالی است.

mini-cart-logo

سبد خرید شما خالی است.

عصر شبکه » شبکه و زیرساخت » NTP ( Network Time Protocol ) چیست؟

NTP ( Network Time Protocol ) چیست؟

آنچه در این مقاله می‌خوانید [پنهان‌سازی]

پروتکل زمان شبکه یا NTP (Network Time Protocol)، پروتکلی است که برای همگام‌سازی زمان در شبکه‌ای از ماشین‌ها طراحی شده است. این پروتکل، که یکی از قدیمی‌ترین پروتکل‌های اینترنتی مورد استفاده کنونی است (با قدمت پیش از سال 1985)، نقشی حیاتی در تضمین دقت زمانی در سراسر زیرساخت شبکه ایفا می‌کند.

NTP در لایه کاربرد مجموعه پروتکل اینترنت قرار دارد و بر روی پروتکل داده‌نگار کاربر (UDP) اجرا می‌شود، که به نوبه خود بر روی IP اجرا می‌گردد. نسخه فعلی پروتکل، NTP نسخه 4 (NTPv4)، در RFC 5905 مستند شده است. این پروتکل برای اطمینان از همگام‌سازی کامپیوترها تا حد چند میلی‌ثانیه نسبت به زمان جهانی هماهنگ (UTC) طراحی شده است.

NTP چیست؟

پروتکل زمان شبکه یک پروتکل کاربردی است که وظیفه همگام‌سازی ساعت میزبان‌ها را در شبکه TCP/IP بر عهده دارد و توسط دیوید میلز در سال 1981 توسعه داده شد. NTP از طریق تبادل پیام‌های درخواست و پاسخ کار می‌کند و در حالت معمول بر روی پورت 123 UDP اجرا می‌شود.

به جای تبادل زمان به صورت متنی (مانند “امروز دوشنبه است”)، NTP پیام‌هایی را مبادله می‌کند که حاوی مهر زمانی (Timestamps) هستند؛ یک مقدار 64 بیتی که شامل 32 بیت برای ثانیه‌ها (از اول ژانویه 1900) و 32 بیت برای کسرهای ثانیه است. این فرمت دقت بسیار بالایی تا کسر ثانیه را فراهم می‌کند تا اطمینان حاصل شود که همگام‌سازی بسیار دقیق انجام می‌شود.

اگر مفاهیمی مثل NTP، DNS، VLAN و مدل OSI برایتان جذاب‌اند و می‌خواهید از پایه تا سطح تسلط شبکه را یاد بگیرید، آموزش +Network بهترین شروع مسیر شماست. توی این دوره، همین پروتکل‌ها و ده‌ها مفهوم کاربردی دیگر را عملی، پروژه‌محور و منظم یاد می‌گیرید.

چرا همگام‌سازی زمان در شبکه حیاتی است؟

همگام بودن ساعت در دستگاه‌های شبکه یک منبع حیاتی محسوب می‌شود و برای عملکرد صحیح شبکه ضروری است. بدون ساعت‌های همگام، بسیاری از فرآیندهای حیاتی شبکه مختل یا غیرقابل مدیریت می‌شوند.

کاربردهای حیاتی همگام‌سازی زمان

NTP چیست؟

ثبت وقایع و عیب‌یابی (Logging and Troubleshooting)

دستگاه‌های شبکه برای رویدادهایی مانند تغییرات پیکربندی، خطاها و حوادث شبکه، پیام‌های گزارش (syslogs) تولید می‌کنند. مهرهای زمانی دقیق برای درک ترتیب و زمان‌بندی این رویدادها ضروری هستند تا بتوان رویدادها را در چندین دستگاه با یکدیگر مرتبط کرد.

امنیت (Authentication and Encryption)

پروتکل‌های امنیتی مانند IPsec و SSL/TLS برای عملکرد صحیح، به ساعت‌های همگام وابسته هستند. به عنوان مثال، اگر ساعت‌ها بیش از حد ناهماهنگ باشند، احراز هویت ممکن است شکست بخورد، و دستگاه ممکن است نتواند گواهینامه‌هایی را که دارای دوره‌های اعتبار هستند، به درستی تأیید کند.

پایبندی به مقررات (Compliance)

بسیاری از صنایع دارای الزامات نظارتی هستند (مانند PCI DSS، HIPAA یا GDPR) که برای ثبت وقایع و حسابرسی، زمان‌سنجی دقیق را الزامی می‌کنند. یک ساعت همگام، یک مسیر حسابرسی ثابت و دقیق را برای رعایت این مقررات تضمین می‌کند.

سیستم لایه‌ای Stratum و مرجع زمانی

NTP از مفهوم لایه (Stratum) استفاده می‌کند تا توصیف کند که یک ماشین چند “هاپ” (Hop) با یک منبع معتبر زمانی فاصله دارد. این ساختار سلسله‌مراتبی، درختی خودسازمان‌دهنده از سرورهای NTP را ایجاد می‌کند و به دستگاه‌ها کمک می‌کند تا نزدیکی خود به منبع اصلی زمان را درک کنند.

Reference Clock (ساعت مرجع) در رأس این سلسله مراتب قرار دارد. یک شبکه NTP معمولاً زمان خود را از یک منبع زمانی معتبر مانند ساعت رادیویی یا ساعت اتمی که به یک سرور زمانی متصل است، دریافت می‌کند.

سطوح Stratum

  • Stratum 0: این‌ها دستگاه‌های زمان‌سنجی با دقت بالا مانند ساعت‌های اتمی، GPS یا ساعت‌های رادیویی هستند که مستقیماً سیگنال زمان را تولید می‌کنند (سرورهای NTP خود را Stratum 0 معرفی نمی‌کنند).
  • Stratum 1: سرورهایی هستند که مستقیماً با یک دستگاه Stratum 0 همگام‌سازی می‌شوند (مانند یک ساعت اتمی یا GPS متصل شده).
  • Stratum 2: این دستگاه‌ها زمان خود را از یک سرور Stratum 1 از طریق شبکه دریافت می‌کنند.
  • حداکثر لایه: حداکثر سطح Stratum، 15 است. Stratum 16 نشان دهنده این است که یک دستگاه همگام نشده یا غیرقابل دسترسی است. هرچه عدد Stratum کمتر باشد، منبع زمانی دقیق‌تر است.

حالت‌های ارتباطی NTP (Association Modes)

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

  • نظرسنجی از سرورهای میزبان (Polling)
  • گوش دادن به پیام‌های پخش (Broadcast)

1. انجمن‌های مبتنی بر نظرسنجی (Poll-Based Associations)

این حالت‌ها (مانند Client mode و Symmetric Active mode) باید زمانی استفاده شوند که NTP به ارائه سطح بالایی از دقت و قابلیت اطمینان زمانی نیاز دارد.

حالت Client (Client Mode)

دستگاه شبکه سرورهای میزبان زمانی تعیین شده خود را برای زمان جاری نظرسنجی می‌کند. در این حالت، سرور از هیچ اطلاعات زمانی ارسال شده توسط کلاینت محلی استفاده نمی‌کند، زیرا یک رابطه یک‌طرفه (Client-Host) برقرار است. برای تنظیم دستگاه در این حالت از دستور ntp server استفاده می‌شود.

حالت متقارن فعال (Symmetric Active Mode)

دستگاه هم سرورهای خود را نظرسنجی می‌کند و هم به نظرسنجی‌های میزبان‌هایش پاسخ می‌دهد (Peer-to-Peer). این حالت زمانی استفاده می‌شود که چندین سرور اضافی (redundant) از طریق مسیرهای شبکه متنوع به هم متصل شده باشند و برای سرورهای Stratum 1 و 2 اینترنت رایج است. برای تنظیم دستگاه در این حالت از دستور ntp peer استفاده می‌شود.

2. انجمن‌های مبتنی بر پخش (Broadcast-Based Associations)

این حالت‌ها باید زمانی استفاده شوند که الزامات دقت و قابلیت اطمینان زمانی متوسط است و شبکه محلی و دارای بیش از 20 کلاینت باشد. همچنین برای شبکه‌هایی با پهنای باند، حافظه سیستمی یا منابع CPU محدود توصیه می‌شود.

در حالت پخش، دستگاه درگیر نظرسنجی نمی‌شود، بلکه به بسته‌های پخش NTP که توسط سرورهای زمان پخش ارسال می‌شوند گوش می‌دهد. به دلیل جریان اطلاعات یک‌طرفه، دقت زمان ممکن است کمی کاهش یابد. برای فعال کردن سرور برای ارسال بسته‌های پخش، از دستور ntp broadcast و برای فعال کردن کلاینت از دستور ntp broadcast client استفاده می‌شود.

امنیت و ملاحظات آسیب‌پذیری

از آنجایی که زمان حفظ شده در یک ماشین یک منبع حیاتی است، سیسکو قویاً توصیه می‌کند از ویژگی‌های امنیتی NTP برای جلوگیری از تنظیم تصادفی یا مخرب زمان نادرست استفاده شود.

مکانیسم‌های امنیتی

طرح محدودیت مبتنی بر لیست دسترسی (Access List-based Restriction)

این طرح به شما اجازه می‌دهد امتیازات دسترسی خاصی را به یک شبکه، زیرشبکه، یا یک میزبان خاص بدهید یا از آن سلب کنید. از دستور ntp access-group برای تعریف گروه دسترسی NTP استفاده می‌شود که می‌تواند شامل گزینه‌هایی مانند peer، serve، serve-only و query-only باشد.

احراز هویت رمزنگاری‌شده (Encrypted Authentication)

این طرح در جایی که نیاز به شکل قابل اعتمادی از کنترل دسترسی است، استفاده می‌شود. این روش از کلیدهای احراز هویت و یک فرآیند احراز هویت برای تعیین اعتماد به بسته‌های همگام‌سازی NTP استفاده می‌کند. کلیدهای جمع کنترلی رمزنگاری‌شده با استفاده از الگوریتم MD5 تولید می‌شوند و در بسته جاسازی می‌گردند؛ در صورت تطابق کلید احراز هویت، اطلاعات مهر زمانی پذیرفته می‌شود. (توجه: NTPv4 دارای یک سیستم کلید عمومی به نام “Autokey” بود که مشکلات طراحی داشت و نباید دیگر استفاده شود.)

ملاحظات امنیتی مهم:

  • آسیب‌پذیری DoS: بسته NTP دارای آسیب‌پذیری است که می‌تواند به یک مهاجم از راه دور و بدون احراز هویت اجازه دهد یک وضعیت انکار سرویس (DoS) ایجاد کند. این آسیب‌پذیری به دلیل خطای در مدیریت پیام‌های خاص بدشکل‌شده در نسخه‌های NTPv4 4.2.4p7 و قبل‌تر است.
  • تأثیر بر CPU: فرآیندهای رمزنگاری و رمزگشایی مورد استفاده در احراز هویت NTP می‌توانند بسیار پرمصرف باشند و دقت زمانی که در شبکه منتشر می‌شود را به طور جدی کاهش دهند.

تنظیم و پیکربندی عملی

پیکربندی NTP در دستگاه‌های شبکه شامل چندین مرحله است. توجه به این نکته مهم است که خدمات NTP به طور پیش‌فرض در تمام رابط‌ها غیرفعال هستند و به صورت سراسری با ورود هر دستور NTP فعال می‌شوند.

پیکربندی NTP مبتنی بر نظرسنجی (Poll-Based)

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

  • تشکیل ارتباط همتا (Peer): ntp peer ip-address (دستگاه هم زمان دریافت می‌کند و هم به همتای خود زمان می‌دهد).
  • تشکیل ارتباط سرور (Client): ntp server ip-address (دستگاه به عنوان کلاینت زمان را از سرور دریافت می‌کند).

تنظیم دستگاه به عنوان سرور زمان معتبر (Authoritative NTP Server)

اگر می‌خواهید سیستم به عنوان یک سرور NTP معتبر عمل کند، حتی اگر با یک منبع زمانی خارجی همگام نشده باشد، می‌توانید از دستور ntp master در حالت پیکربندی سراسری استفاده کنید. این قابلیت اجازه می‌دهد تا اگر شبکه از اینترنت جدا باشد، دستگاه بتواند زمان را با استفاده از روش‌های دیگر تعیین کرده و آن را از طریق NTP به سایر دستگاه‌ها منتقل کند.

  • دستور: ntp master.
  • توجه: استفاده از این دستور باید با احتیاط باشد، زیرا به راحتی می‌تواند منابع زمانی معتبر دیگر را نادیده بگیرد، به خصوص اگر یک شماره Stratum پایین پیکربندی شود.

تأیید و عیب‌یابی (Verification)

برای بررسی وضعیت همگام‌سازی و اطلاعات زمانی دستگاه، می‌توان از دستورات زیر در حالت EXEC استفاده کرد:

مشاهده وضعیت همگام‌سازی NTP

show ntp status. این دستور نشان می‌دهد که آیا ساعت همگام شده است یا خیر (Clock is synchronized) و Stratum فعلی و مرجع زمانی را نمایش می‌دهد.

مشاهده انجمن‌های NTP

show ntp associations detail این دستور وضعیت ارتباطات NTP را نمایش می‌دهد. اگر دستگاه با سرور همگام شده باشد، یک علامت ستاره (*) در خروجی کنار آدرس سرور ظاهر می‌شود.

مشاهده زمان ساعت

show clock detail.

نتیجه‌گیری

پروتکل زمان شبکه (NTP) یک ستون فقرات اساسی برای عملکرد دقیق و ایمن شبکه‌های مدرن است، زیرا زمان‌بندی را تا حد میلی‌ثانیه یا بهتر، در سراسر سیستم‌های متصل تضمین می‌کند. NTP نه تنها برای عیب‌یابی و ثبت وقایع ضروری است، بلکه نقش حیاتی در امنیت شبکه (مانند احراز هویت و گواهینامه‌ها) و اجرای سیاست‌های زمانی ایفا می‌کند.

با استفاده از ساختار سلسله‌مراتبی Stratum و حالت‌های ارتباطی متنوع (Poll-Based برای دقت بالا و Broadcast-Based برای شبکه‌های محلی)، NTP انعطاف‌پذیری لازم را برای همگام‌سازی طیف وسیعی از دستگاه‌ها فراهم می‌آورد. پیاده‌سازی صحیح NTP، همراه با استفاده از مکانیسم‌های امنیتی مانند احراز هویت رمزنگاری‌شده یا لیست‌های دسترسی، برای حفظ یکپارچگی و قابلیت اطمینان سیستم‌های اطلاعاتی حیاتی است.

سوالات متداول

Stratum در NTP دقیقاً به چه معناست؟

Stratum یک مفهوم سلسله‌مراتبی است که تعداد “هاپ‌های NTP” (NTP hops) بین یک دستگاه و یک منبع زمانی معتبر (مانند یک ساعت اتمی یا GPS) را توصیف می‌کند. Stratum 1 نزدیک‌ترین منبع است و Stratum 16 نشان‌دهنده یک دستگاه غیر همگام یا غیرقابل دسترس است. این عدد به کاربر نشان می‌دهد که چقدر می‌تواند به دقت زمانی دریافت‌شده توسط دستگاه اعتماد کند.

چرا همگام‌سازی NTP در ابتدا کند است؟

NTP یک پروتکل ذاتی کُند است و فواصل نظرسنجی پیش‌فرض معمولاً بین ۱ تا ۱۵ دقیقه است (دقیقه، نه ثانیه). این پروتکل طراحی شده است تا زمان را به تدریج در مراحل کوچک تنظیم کند تا تغییرات ناگهانی که می‌توانند فرآیندهای وابسته به زمان دقیق را مختل کنند، به حداقل برسد. به همین دلیل، قبل از پیکربندی NTP، توصیه می‌شود ساعت داخلی دستگاه را به صورت دستی به زمانی نسبتاً نزدیک به زمان دقیق تنظیم کنید تا زمان همگام‌سازی کامل کاهش یابد.

تفاوت بین حالت Client و Symmetric Active چیست؟

حالت Client یک رابطه یک‌طرفه است: دستگاه زمان را از سرور می‌گیرد، اما سرور زمان کلاینت را ردیابی نمی‌کند. این حالت برای کلاینت‌های معمولی مناسب است. حالت Symmetric Active یک رابطه دو طرفه (Peer-to-Peer) است: هر دو دستگاه زمان یکدیگر را نظرسنجی کرده و به نظرسنجی‌ها پاسخ می‌دهند و اطلاعات زمانی یکدیگر را حفظ می‌کنند. این حالت برای سرورهایی که باید افزونگی (redundancy) داشته باشند (مانند سرورهای Stratum 1 و 2)، مناسب‌تر است.

آیا NTP در برابر حملات امن است؟

NTP می‌تواند در برابر حملات آسیب‌پذیر باشد، به ویژه حملات DoS (انکار سرویس) در نسخه‌های قدیمی‌تر. همچنین، NTPv3 از حالت کلید متقارن برای احراز هویت پشتیبانی می‌کرد که در برابر حملات مرد میانی (MITM) مفید نبود. سیسکو به شدت استفاده از ویژگی‌های امنیتی NTP مانند لیست‌های دسترسی و احراز هویت رمزنگاری شده (MD5) را برای محافظت در برابر تنظیم تصادفی یا مخرب زمان توصیه می‌کند. راهکارهای مدرن‌تر مانند Network Time Security (NTS) نیز در حال توسعه هستند تا امنیت NTPv4 را با استفاده از TLS افزایش دهند.

NTP چگونه خطاها و ناهماهنگی‌های زمانی را مدیریت می‌کند؟

NTP از الگوریتم‌هایی برای مقایسه زمان گزارش شده توسط چندین ماشین استفاده می‌کند و هرگز با ماشینی که زمان آن به طور قابل توجهی با دیگران متفاوت است، همگام نمی‌شود، حتی اگر Stratum پایین‌تری داشته باشد. همچنین، NTP از الگوریتم‌های پیچیده‌ای برای محاسبه تأخیر رفت و برگشت ($\delta$) و اختلاف زمانی ($\theta$) استفاده می‌کند و از طریق فیلترها و تحلیل‌های آماری، داده‌های پرت (outliers) را حذف می‌کند.

Picture of وحید گلی
وحید گلی
وحید گلی، فارغ‌التحصیل کارشناسی فناوری اطلاعات با گرایش امنیت اطلاعات، بیش از ده سال سابقه طراحی، پیاده‌سازی و مشاوره شبکه و زیرساخت در شرکت‌های بزرگی همچون پگاه آذربایجان، الکانت و بانک ملت دارد. ایشان در راه‌اندازی سرویس‌های مایکروسافتی (Exchange، Skype for Business، System Center)، مجازی‌سازی با Hyper-V و VMware، و شبکه‌های امن تخصص دارند و علاوه بر آن، به‌عنوان مدرس دوره‌های Network+, MCSA/MCSE و مهندسی شبکه در مؤسسات معتبری مانند عصر شبکه و البرز فعالیت کرده‌اند.

Comments are closed.