لایه پیوند داده‌ای

از ویکی‌پدیا، دانشنامهٔ آزاد
(تغییرمسیر از لایه پیوندداده)
پرش به: ناوبری، جستجو
مدل مرجع اتصال داخلی سیستم‌های باز
۷ لایه کاربرد
۶ لایه نمایش
۵ لایه نشست
۴ لایه انتقال
۳ لایه شبکه
۲ لایه پیوندداده
۱ لایه فیزیکی

لایهٔ پیوند داده‌ای[۱] دومین سطح از مدل اتصال متقابل سامانه‌های باز می‌باشد. در این لایه بر روی الگوریتم‌های دستیابی به ارتباطات قابل اعتماد بین دو کامپیوتر همسایه بحث می‌شود. این لایه دارای وظایفی به قرار زیر است:

  • ارائه سرویس‌های مشخص به لایهٔ شبکه
  • مدیریت خطاهای انتقال
  • تنظیم جریان داده‌ها

برای تحقق این اهداف این لایه اقدام به فریم بندی اطلاعات می‌نمایید.

ارائه سرویس‌های مشخص به لایه شبکه[ویرایش]

از مهم‌ترین وظایف لایه پیوند داده انتقال داده‌ها از لایه شبکهٔ ماشین مبدا به لایه شبکه ماشین مقصد می‌باشد. این ارتباط (بخش الف) در شکل مقابل نشان داده شده است. البته این اتصال ارتباطی همچون بخش (ب) که ارتباطی واقعی است، را دنبال می نماید. سرویس هایی که لایه پیوند داده ارائه می‌کند، از سیستمی تا سیستم دیگر متفاوت است. اما از مهم‌ترین سرویس‌ها عبارت‌اند از:

  • سرویس غیر متصل بدون تصدیق دریافت: این سرویس در اکثر LANها مورد استفاده قرار می‌گیرد.
  • سرویس غیر متصل با تصدیق دریافت: این سرویس برای کانالهای غیر اعتمادی مثل سیستم‌های شبکه بی‌سیم مناسب است.

سرویس اتصال گرا با تصدیق دریافت:این سرویس که مناسب‌ترین سرویس این لایه است در سه مرحله انجام می‌گیرد.

  1. مقدار دهی متغییرهای لازم برای شمارش فریم‌ها و غیره.
  2. انتقال فریم ها.
  3. قطع اتصال و آزاد سازی متغییرها و بافر ها.

فریم بندی[ویرایش]

جهت فریم بندی روشهای زیر وجود دارد:

  1. شمارش کاراکتر ها: در این روش تعداد کاراکترهای فریم در یکی از فیلدهای سرآیند آن نوشته می‌شود. وقتی این فریم به مقصد برسد، لایه پیوند داده مقابل به کمک آنها فریم داده‌ای را مشخص می‌کند. شکل زیر مثالی از فریم بندی به کمک شمارش کاراکترها می‌باشد.

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

  1. بایتهای پرچم، با لاگذاری بایت: در این روش فلگ هایی (نشانه) برای مشخص کردن ابتدا و انتهای فریم داده‌ای استفاده می‌شود.این روش هم مشکلات خاص خود را دارد چونکه ممکن است بخشی از داده‌ها شامل بایت‌های پرچم قراردادی باشد.
  2. پرچم‌های شروع و پایان، با لاگذاری بیت: در این شیوه هر فریم با طرح بیتی ۰۱۱۱۱۱۱۰ شروع می‌گردد و در سمت فرسنده به محض مشاهده ۵ بیت ۱ پشت سرهم یک ۰ قرار می‌دهد. عکس این رویداد در قسمت گیرنده رخ می‌دهد.
  3. حالت‌های غیر مجاز کُدگذاری لایه‌ٔ فیزیکی: در این روش در اصل نوعی افزونگی داریم. مثلاً در برخی LANها هر بیت داده با دو بیت فیزیکی نشان داده می‌شود: بیت ۱ با زوج بالا-پایین و بیت ۰ با زوج پایین-بالا.

در بسیاری از پروتکل‌های لینک داده برای اطمینان بیشتر از ترکیب روشهای گفته شده استفاده می‌شود.

کنترل خطا[ویرایش]

جهت کنترل خطای دریافت اطلاعات معمولاً از دو مکانیزم استفاده می‌شود.

  • تصدیق دریافت: گیرنده دریافت بسته را تصدیق می‌کند.
  • استفاده از زمانسنج: هر بسته اگر در مدت زمان معینی به مقصد نرسید، دوباره ارسال می‌شود.

کنترل جریان[ویرایش]

برای یکی کردن سرعت ارسال و دریافت بسته‌های اطلاعاتی معمولاً از راهکارهای کنترل جریان استفاده می‌شود. در زیر چند راهکار را بیان می کنیم.

  • کنترل جریان بر اساس بازخور: گیرنده آمادگی خود را برای دریافت بسته‌ها اعلام می‌کند.
  • کنترل جریان بر اساس نرخ

پروتکل‌های لینک داده[ویرایش]

در این بخش پروتکل یکطرفه نا مقید که ساده‌ترین این پروتکل ها(و البته ناقص‌ترین آنها) را ارائه می کنیم:

/* Protocol 1 (utopia) provides for data transmission in one direction only, from
   sender to receiver.  The communication channel is assumed to be error free
   and the receiver is assumed to be able to process all the input infinitely quickly.
   Consequently, the sender just sits in a loop pumping data out onto the line as
   fast as it can. */

typedef enum {frame_arrival} event_type;
#include "protocol.h"

void sender1(void)
{
  frame s;                      /* buffer for an outbound frame */
  packet buffer;                /* buffer for an outbound packet */

  while (true) {
        from_network_layer(&buffer);        /* go get something to send */
        s.info = buffer;        /* copy it into s for transmission */
        to_physical_layer(&s);      /* send it on its way */
  }     /* Tomorrow, and tomorrow, and tomorrow,
           Creeps in this petty pace from day to day
           To the last syllable of recorded time.
                - Macbeth, V, v */
}

void receiver1(void)
{
  frame r;
  event_type event;             /* filled in by wait, but not used here */

  while (true) {
        wait_for_event(&event);      /* only possibility is frame_arrival */
        from_physical_layer(&r); /* go get the inbound frame */
        to_network_layer(&r.info); /* pass the data to the network layer */
  }
}

ارزیابی پروتکل‌ها[ویرایش]

تکنیک هایی جهت ارزیابی پروتکل‌های شبکه وجود دارد. این تکنیک‌ها بایستی دقیق و مبتنی بر اصول ریاضی باشد. دو روش زیر از مهم‌ترین این روشها هستند.

پیوند به بیرون[ویرایش]

مدل مرجع OSI
مقایسه مدلهای OSI و TCP/IP
مدل مرجع TCP/IP

منابع[ویرایش]

  1. لایهٔ پیوند داده‌ای [مهندسی مخابرات] هم‌ارزِ data link layer (انگلیسی)؛ منبع: گروه واژه‌گزینی، فرهنگ واژه‌های مصوب فرهنگستان، تهران: انتشارات فرهنگستان زبان و ادب فارسی، http://www.persianacademy.ir/fa/wordspdf.aspx 

شبکه‌های کامپیوتری - آندرواس. تَنن بام - ویراست چهارم۲۰۰۳