From Wikipedia, the free encyclopedia
قرارداد بسته دادهٔ کاربر یا پروتکل بسته دادهٔ کاربر (به انگلیسی: UDP یا User Datagram Protocol) یکی از اجزاء اصلی مجموعه پروتکل اینترنت، مجموعهای از پروتکلهای شبکه که در اینترنت مورد استفاده قرار میگیرند، میباشد. رایانهها با استفاده از UDP قادر به ارسال پیغام، که در این مورد آن را بسته داده یا Datagram مینامیم، به دیگر میزبانهای موجود در پروتکل اینترنت (IP) میباشند. این پروتکل توانایی این را دارد که این کار را بدون برقراری ارتباط قبلی یا ایجاد کانالها یا مسیرهای انتقال داده ویژه انجام دهد. پروتکل مزبور در سال ۱۹۸۰ توسط دیوید پی. رید ابداع گردیده و بهطور رسمی در استاندارد RFC 768 تعریف شد.
UDP از مدل انتقال ساده بدون استفاده از تکنیک دست تکانی صریح که برای ایجاد قابلیت اطمینان (Reliability)، مرتبسازی و یکپارچهسازی دادهها بکار میرود، بهره میجوید؛ بنابراین، UDP سرویس غیرمطمئنی را ارائه میدهد و ممکن است بسته دادهها نامرتب، تکراری بوده یا بدون اطلاع قبلی از دست بروند. UDP تشخیص میدهد که بررسی خطا و تصحیح آن با توجه به نوع کاربردی که دارد لازم نبوده یا نباید اجرا شود، بنابراین چنین بار اضافی پردازشی را بر شبکه تحمیل نمیکند. برنامههایی که نسبت به زمان حساس هستند از UDP استفاده میکنند، زیرا از دست دادن بستهها بهتر از منتظر ماندن برای بسته هاست؛ بنابراین پروتکل UDP بهترین گزینه برای سیستمهای بیدرنگ به حساب میآید. اگر برنامهای نیاز به امکانات تصحیح خطا در سطح واسط شبکه داشته باشد، میتواند از قرارداد کنترل انتقال (به انگلیسی: TCP یا Transmission Control Protocol) یا پروتکل انتقال کنترل جریان (به انگلیسی: SCTP یا Stream Control Transmission Protocol) استفاده کند که بهطور خاص برای این منظور طراحی شدهاند.
طبیعت بدون حالت UDP میتواند برای سرورهایی که به پرس و جوهای کوچک حجم زیادی از کلاینتها پاسخ میدهند نیز مفید واقع شود. UDP بر خلاف TCP، با شبکههای پخشی (انتشار بسته در کل شبکه محلی) و شبکههای چندپخشی (ارسال بسته به بخشی از شبکه) سازگاری کامل دارد.
برنامههای معمول شبکه که از UDP استفاده میکنند عبارتند از: سامانه نام دامنه (به انگلیسی: DNS یا Domain Name System)، برنامههایی که از پخش زنده یا رسانه جاری (Streaming Media) استفاده میکنند نظیر تلویزیون پروتکل اینترنت یا IPTV، صدا روی پروتکل اینترنت یا VoIP، پروتکل ساده انتقال فایل (به انگلیسی: TFTP یا Trivial File Transfer Protocol) و بسیاری از بازیهای برخط.
برنامههای UDP از سوکت بسته داده برای برقراری ارتباطات میزبان-به-میزبان استفاده میکنند. برنامه یک سوکت را در انتهای بسته انتقال داده اش میچسباند، که ترکیبی از آدرس آیپی و شماره پورت سرویس است. پورت یک ساختار نرمافزاری است که با یک عدد ۱۶ بیتی به نام شماره پورت شناسایی میشود. شماره پورت عددی بین ۰ تا ۶۵٬۵۳۵ است. پورت ۰ رزرو شدهاست، اما اگر پردازش ارسالکننده انتظار دریافت پیام را نداشته باشید مجاز است که از این پورت استفاده کند.
آیانا یا انجمن شمارههای تخصیص یافته اینترنتی شماره پورتها را به سه دسته تقسیم کردهاست. پورتهای بین ۰ تا ۱۰۲۳ برای سرویسهای شناخته شده و عمومی آزادند. پورتهای بین ۱۰۲۴ و ۴۹٬۱۵۱ پورتهای ثبت شده هستند و برای سرویسهای مخصوص IANA در نظر گرفته شدهاند. پورتهای بین ۴۹٬۱۵۲ تا ۶۵٬۵۳۵ پورتهای دینامیکی هستند که بهطور رسمی برای سرویس خاصی در نظر گرفته نشدهاند و میتوان برای هر منظوری استفاده کرد.
UDP کمینهترین پروتکل مبتنی بر پیغام لایه انتقال است که جزئیات آن در RFC 768 آورده شدهاست.
UDP هیچگونه تضمینی برای تحویل پیام به پروتکل لایه بالاتر را نمیدهد و پروتکلهایی هم که از UDP استفاده میکنند هیچ حالتی از پیغامی را میفرستند نگه نمیدارند. به همین دلیل، UDP را پروتکل بسته-داده غیر مطمئن مینامند.
UDP تسهیمسازی برنامه (از طریق شماره پورت) و بررسی یکپارچگی (با استفاده از چکسام) سرایند و بخش دادهای را فراهم میآورد. اگر مطمئن بودن انتقال موردنظر باشد، بایستی این امکان در برنامه کاربر تعبیه شود.
افست (بیت) | ۰ – ۱۵ | ۱۶ – ۳۱ | ||||||||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
۰ | شماره پورت مبدأ | شماره پورت مقصد | ||||||||||||||||||||||||||||||
۳۲ | طول | چکسام | ||||||||||||||||||||||||||||||
۶۴ | داده |
UDP دادهها را در قالب قطعاتی (Segment) ارسال میکند، که در ابتدای آنها ۸ بایت سرآیند و سپس دادههای لایه کاربرد قرار میگیرد. این سرآیند در جدول بالا نشان داده شدهاست. دو فیلد شماره پورت به منظور شناسایی نقاط پایانی (پروسههای نهایی) در ماشینهای مبدأ و مقصد به کار میآیند. وقتی یک بسته UDP از راه میرسد، محتوای آن به پروسه متصل به شماره پورت مقصد، تحویل داده میشود. عمل اتصال پروسه به یک پورت از طریق تابع اولیه BIND انجام میشود. (فرایند مقیدسازی پروسه به یک پورت در TCP و UDP تفاوتی ندارد) در حقیقت، آنچه که UDP در مقایسه با IP معمولی اضافهتر دارد پورتهای مبدأ و مقصد هستند. بدون فیلدهای مربوط به پورت، لایه انتقال نمیداند که با یک بسته چه کار کند. با این فیلدها، داده به درستی تحویل پروسه مربوط خواهد شد.
برای آنکه بتوان برای پروسه مبدأ پاسخی برگرداند، به شماره پورت مبدأ نیاز است. بدین منظور محتوای فیلد پورت مبدأ از بسته ورودی، در فیلد پورت مقصد از بسته خروجی، کپی و ارسال میشود. بدین ترتیب فرستنده پاسخ، پروسه تحویل گیرنده بسته را مشخص مینماید.[1]
سرایند UDP دارای ۴ ستون، طول هر کدام ۲ بایت (۱۶ بیت) و استفاده از دو تای آنها در IPv4 اختیاری است. (فیلدهایی که با رنگ صورتی مشخص شدهاند). در IPv6 تنها استفاده از شماره پورت مبداً اختیاری میباشد. (جدول پایین)
روشی که برای محاسبه چکسام مورد استفاده قرار میگیرد در RFC 768 تعریف شدهاست:
این کد حاصل جمع سرآیند، دادهها و یک «شبه فرایند فرضی» (Pseudoheader) است. قالب شبه سرآیند فرضی در جدول پایین آمدهاست. برای محاسبه این کد ابتدا فید چکسام صفر فرض میشود و در صورت فرد بودن تعداد بایتها، تعدادی صفر زائد به انتهای دادهها اضافه میگردد تا تعداد بایتها زوج شود. الگوریتم محاسبه چکسام بسیار ساده است: مجموعه بایتها به صورت کلمات ۱۶ بیتی (یعنی دو بایت دو بایت) با هم جمع شده و حاصل جمع به صورت «متمم ۱» (One's Complement) منفی میشود و درون فید چکسام قرار میگیرد. نتیجتاً وقتی در گیرنده این محاسبه بر روی کل قطعه (شامل فیلد چکسام) انجام میشود نتیجه آن باید صفر باشد. در غیر اینصورت دادهها قابل اطمینان و سالم نیستند.[2]
تفاوت IPv4 و IPv6 در محاسبه چکسام در میزان دادههای محاسباتی آنها میباشد.
چک سام در قالب UDP IPv4 با استفاده از یک شبه سرآیند فرضی محاسبه میشود و شباهت زیادی به سرآیند واقعی یک IP دارد. این سرآیند فرضی یک سرآیند واقعی IP نمیباشد که در ارسال بسته IP دخالت دارد. جدول زیر ساختار کامل شبه سرآیند فرضی که تنها برای محاسبه چکسام مورد استفاده قرار میگیرد را مشخص مینماید.
bits | ۰ – ۷ | ۸ – ۱۵ | ۱۶ – ۲۳ | ۲۴ – ۳۱ | ||||||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
۰ | آدرس مبدأ | |||||||||||||||||||||||||||||||
۳۲ | آدرس مقصد | |||||||||||||||||||||||||||||||
۶۴ | تعدادی صفر | پروتکل | طول UDP | |||||||||||||||||||||||||||||
۹۶ | شماره پورت مبدأ | شماره پورت مقصد | ||||||||||||||||||||||||||||||
۱۲۸ | طول | چکسام | ||||||||||||||||||||||||||||||
۱۶۰ | داده |
محاسبه چکسام در IPv4 اختیاری است. اگر این کار انجام نشود، مقدار آن فیلد با صفر پر میشود.
زمانیکه پروتکل UDP در سیستم IPv6 مورد استفاده قرار میگیرد، محاسبه آن اجباری است. روشی که برای محاسبه چکسام در IPv6 انجام میشود در RFC 2460 تعریف شدهاست. همانند IPv4 شبه سرآیند فرضی در محاسبه چک سام استفاده میشود.
bits | ۰ – ۷ | ۸ – ۱۵ | ۱۶ – ۲۳ | ۲۴ – ۳۱ | ||||||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
۰ | آدرس مبدأ | |||||||||||||||||||||||||||||||
۳۲ | ||||||||||||||||||||||||||||||||
۶۴ | ||||||||||||||||||||||||||||||||
۹۶ | ||||||||||||||||||||||||||||||||
۱۲۸ | آدرس مقصد | |||||||||||||||||||||||||||||||
۱۶۰ | ||||||||||||||||||||||||||||||||
۱۹۲ | ||||||||||||||||||||||||||||||||
۲۲۴ | ||||||||||||||||||||||||||||||||
۲۵۶ | طول UDP | |||||||||||||||||||||||||||||||
۲۸۸ | تعدادی صفر | سرآیند بعدی | ||||||||||||||||||||||||||||||
۳۲۰ | شماره پورت مبدأ | شماره پورت مقصد | ||||||||||||||||||||||||||||||
۳۵۲ | طول | چکسام | ||||||||||||||||||||||||||||||
۳۸۴ | داده |
فقدان قابلیت اطمینان بدین معناست که برنامههایی که از UDP استفاده میکنند کلاً میتوانند مقداری خطا یا افزونگی را بپذیرند. برخی پروتکلها نظیر TFTP میتوانند مکانیزمهای ابتدایی برای برقراری قابلیت اطمینان را در لایه کاربرد به کار گیرند. در اغلب اوقات برنامههایی که از UDP استفاده میکنند از مکانیزمهای برقراری قابلیت اطمینان استفاده نمیکنند و حتی مانع از اجرای آنها میشوند. رسانههای جاری، بازیهای چندبازیکنه بیدرنگ و VoIP مثالهایی از برنامههایی هستند که از UDP بهره میبرند. در این برنامههای خاص از دست دادن بستهها معمولاً مشکل حادی نیست. اگر برنامهای احتیاج به برقراری قابلیت اطمینان بالا داشته باشد، باید از پروتکلی نظیر TCP استفاده کند.
در مورد UDP بر خلاف TCP مورد مهم و قابل توجهی وجود دارد که برنامههای مبتنی بر این پروتکل قابلیت جلوگیری از ازدحام و مکانیزم کنترلی خوبی نیستند. برنامههای UDP ای که به مسئله ازدحام توجهی نمیکنند و میزان قابل توجهی از پهنای باند را نیز اشغال میکنند، میتوانند ثبات اینترنت را به مخاطره بیندازند. مکانیزمهای مبتنی بر شبکهای وجود دارد که برای به حداقل رساندن تأثیرات مخرب، ترافیکهای کنترل نشده UDP ارائه شدهاند. اجزاء مبتنی بر شبکه نظیر روترها که از تکنیکهای صف بندی و حذف بستهها استفاده میکنند، تنها ابزار موجود برای کاهش دادن ترافیک حجیم برنامههای مبتنی بر UDP میباشند. پروتکل کنترل ازدحام بسته داده (به انگلیسی: DCCP یا Datagram Congestion Control Protocol) راه حلی نسبی برای حل این مشکل بالقوهاست. این پروتکل با افزودن رفتار کنترلی مشابه TCP در سیستم میزبان، جریانهای شدید UDP را کنترل میکند.
برنامههای اینترنتی متعددی از UDP بهره میبرند:
انتقال صدا و تصویر معمولاً از طریق UDP صورت میگیرد. پروتکلهای پخش زنده صدا و تصویر برای مدیریت از دست رفتن بستهها طراحی شدهاند تا تنها افت کیفیت ناچیزی رخ دهد، تا اینکه زمان زیادی برای ارسال دوباره بستههای از دست رفته صرف شود. به این دلیل که TCP و UDP هر دو در یک شبکه کار میکنند، بسیاری از کسب و کارها به این نتیجه رسیدهاند که افزایش اخیر در ترافیک UDP از این برنامههای بیدرنگ بر کارایی برنامههایی نظیر پایانههای فروش (POS)، سیستمهای حسابداری و پایگاه داده که از TCP استفاده میکنند، آسیب میرسانند. زمانیکه TCP متوجه از دست رفتن بستهای میشود، نرخ انتقال دادههایش را کاهش میدهد. از آنجاییکه، برنامههای تجاری و بیدرنگ برای کسب و کارها مهم میباشند، بر اهمیت توسعه راه حلهای کیفیت خدمات (QoS) روز به روز افزوده میشود.
پروتکل کنترل انتقال یک پروتکل اتصال گرا (Connection-Oriented) میباشد، بدین معنا که برای برقراری ارتباط بین دو میزبان احتیاج به تکنیک «دست دهی» یا Handshaking دارد. به محض اینکه ارتباط برقرار شد دادههای کاربر میتواند به صورت دوطرفه ارسال و دریافت شود. از جمله خصوصیات این پروتکل میتوان به موارد زیر اشاره کرد:
UDP یک پروتکل بی اتصال (Connectionless) مبتنی بر پیغام سادهاست. پروتکلهای بی اتصال نیازی به برقراری ارتباط اختصاصی ندارند. ارتباط به صورت یکطرفه و در یک مسیر ار مبدأ به مقصد و بدون در نظر گرفتن حالت یا وضعیت گیرنده برقرار میشود. از جمله خصوصیات این پروتکل میتوان به موارد زیر اشاره کرد:
مشارکتکنندگان ویکیپدیا. «User Datagram Protocol». در دانشنامهٔ ویکیپدیای انگلیسی، بازبینیشده در ۲۹ ژوئیه ۲۰۱۱.
Seamless Wikipedia browsing. On steroids.
Every time you click a link to Wikipedia, Wiktionary or Wikiquote in your browser's search results, it will show the modern Wikiwand interface.
Wikiwand extension is a five stars, simple, with minimum permission required to keep your browsing private, safe and transparent.