DCN - ट्रांसमिशन कंट्रोल प्रोटोकॉल

ट्रांसमिशन कंट्रोल प्रोटोकॉल (टीसीपी) इंटरनेट प्रोटोकॉल सूट के सबसे महत्वपूर्ण प्रोटोकॉल में से एक है। यह इंटरनेट जैसे संचार नेटवर्क में डेटा ट्रांसमिशन के लिए सबसे व्यापक रूप से इस्तेमाल किया जाने वाला प्रोटोकॉल है।

विशेषताएं

  • टीसीपी विश्वसनीय प्रोटोकॉल है। यही है, रिसीवर हमेशा प्रेषक को डेटा पैकेट के बारे में या तो सकारात्मक या नकारात्मक पावती भेजता है, ताकि प्रेषक को हमेशा इस बारे में उज्ज्वल सुराग मिले कि क्या डेटा पैकेट गंतव्य तक पहुंच गया है या उसे इसे फिर से भेजने की आवश्यकता है।

  • टीसीपी सुनिश्चित करता है कि डेटा उसी क्रम में इच्छित गंतव्य तक पहुँचे, जिस क्रम में इसे भेजा गया था।

  • टीसीपी कनेक्शन उन्मुख है। टीसीपी को वास्तविक डेटा भेजने से पहले दो दूरस्थ बिंदुओं के बीच संबंध स्थापित करना होगा।

  • टीसीपी त्रुटि-जाँच और पुनर्प्राप्ति तंत्र प्रदान करता है।

  • टीसीपी अंत-टू-एंड संचार प्रदान करता है।

  • टीसीपी प्रवाह नियंत्रण और सेवा की गुणवत्ता प्रदान करता है।

  • टीसीपी क्लाइंट / सर्वर पॉइंट-टू-पॉइंट मोड में चल रही है।

  • टीसीपी पूर्ण द्वैध सर्वर प्रदान करता है, अर्थात यह रिसीवर और प्रेषक दोनों की भूमिका निभा सकता है।

हैडर

टीसीपी हेडर की लंबाई न्यूनतम 20 बाइट्स लंबी और अधिकतम 60 बाइट्स होती है।

  • Source Port (16-bits)  - यह भेजने वाले डिवाइस पर एप्लिकेशन प्रक्रिया के स्रोत पोर्ट की पहचान करता है।

  • Destination Port (16-bits) - यह प्राप्त करने वाले डिवाइस पर एप्लिकेशन प्रक्रिया के गंतव्य पोर्ट की पहचान करता है।

  • Sequence Number (32-bits) - एक सत्र में एक खंड के डेटा बाइट्स की अनुक्रम संख्या।

  • Acknowledgement Number (32-bits)  - जब ACK ध्वज सेट होता है, तो इस संख्या में अपेक्षित डेटा बाइट की अगली अनुक्रम संख्या होती है और प्राप्त पिछले डेटा की पावती के रूप में काम करती है।

  • Data Offset (4-bits)  - यह फ़ील्ड दोनों टीसीपी हेडर के आकार (32-बिट शब्द) और पूरे टीसीपी सेगमेंट में वर्तमान पैकेट में डेटा की भरपाई का अर्थ है।

  • Reserved (3-bits)  - भविष्य के उपयोग के लिए आरक्षित और सभी डिफ़ॉल्ट रूप से शून्य सेट हैं।

  • Flags (1-bit each)

    • NS - नॉनस सम बिट का इस्तेमाल एक्सप्लोसिव कंजेशन नोटिफिकेशन सिग्नलिंग प्रक्रिया द्वारा किया जाता है।

    • CWR - जब कोई होस्ट ECE बिट सेट के साथ पैकेट प्राप्त करता है, तो यह स्वीकार करता है कि ECE को प्राप्त करने के लिए विंडोज कम हो गया है।

    • ECE -इसके दो अर्थ हैं:

      • यदि SYN बिट 0 पर स्पष्ट है, तो ECE का अर्थ है कि IP पैकेट में अपना CE (कंजेशन अनुभव) बिट सेट है।

      • यदि SYN बिट 1 पर सेट है, तो ECE का अर्थ है कि डिवाइस ECT सक्षम है।

    • URG - यह इंगित करता है कि अर्जेंट पॉइंटर क्षेत्र में महत्वपूर्ण डेटा है और इसे संसाधित किया जाना चाहिए।

    • ACK- यह इंगित करता है कि पावती क्षेत्र का महत्व है। यदि ACK को 0 पर साफ़ किया जाता है, तो यह इंगित करता है कि पैकेट में कोई पावती नहीं है।

    • PSH - जब सेट किया जाता है, तो यह PUSH डेटा को प्राप्त करने वाले स्टेशन के लिए एक अनुरोध है (जैसे ही यह आता है) इसे प्राप्त किए बिना आवेदन प्राप्त करने के लिए।

    • RST - रीसेट ध्वज में निम्नलिखित विशेषताएं हैं:

      • इसका उपयोग आने वाले कनेक्शन को मना करने के लिए किया जाता है।

      • इसका उपयोग किसी खंड को अस्वीकार करने के लिए किया जाता है।

      • इसका उपयोग किसी कनेक्शन को पुनरारंभ करने के लिए किया जाता है।

    • SYN - इस ध्वज का उपयोग मेजबानों के बीच संबंध स्थापित करने के लिए किया जाता है।

    • FIN- इस ध्वज का उपयोग कनेक्शन जारी करने के लिए किया जाता है और इसके बाद किसी भी डेटा का आदान-प्रदान नहीं किया जाता है। क्योंकि SYN और FIN झंडे वाले पैकेट में क्रम संख्या होती है, उन्हें सही क्रम में संसाधित किया जाता है।

  • Windows Size  - इस क्षेत्र का उपयोग दो स्टेशनों के बीच प्रवाह नियंत्रण के लिए किया जाता है और यह इंगित करता है कि बफर की मात्रा (बाइट्स में) रिसीवर को एक सेगमेंट के लिए आवंटित किया गया है, यानी रिसीवर कितना डेटा की उम्मीद कर रहा है।

  • Checksum - इस फील्ड में हैडर, डेटा और स्यूडो हेडर्स का चेकसम होता है।

  • Urgent Pointer  - यह तत्काल डेटा बाइट की ओर इशारा करता है यदि URG ध्वज 1 पर सेट है।

  • Options  - यह अतिरिक्त विकल्पों की सुविधा देता है जो नियमित हेडर द्वारा कवर नहीं किए जाते हैं। विकल्प फ़ील्ड को हमेशा 32-बिट शब्दों में वर्णित किया जाता है। यदि इस फ़ील्ड में 32-बिट से कम डेटा है, तो 32-बिट सीमा तक पहुंचने के लिए शेष बिट्स को कवर करने के लिए पैडिंग का उपयोग किया जाता है।

को संबोधित करते

दो दूरस्थ होस्ट के बीच टीसीपी संचार पोर्ट संख्या (TSAPs) के माध्यम से किया जाता है। पोर्ट नंबर 0 - 65535 से लेकर हो सकते हैं जो इस प्रकार विभाजित हैं:

  • सिस्टम पोर्ट (0 - 1023)
  • उपयोगकर्ता पोर्ट (1024 - 49151)
  • निजी / गतिशील बंदरगाह (49152 - 65535)

कनेक्शन प्रबंधन

टीसीपी संचार सर्वर / क्लाइंट मॉडल में काम करता है। क्लाइंट कनेक्शन शुरू करता है और सर्वर इसे स्वीकार या अस्वीकार करता है। कनेक्शन प्रबंधन के लिए तीन-तरफ़ा हैंडशेकिंग का उपयोग किया जाता है।

स्थापना

ग्राहक कनेक्शन शुरू करता है और एक अनुक्रम संख्या के साथ खंड भेजता है। सर्वर अपने स्वयं के अनुक्रम संख्या और ग्राहक के खंड के एसीके के साथ इसे स्वीकार करता है जो ग्राहक के अनुक्रम संख्या से एक अधिक है। अपने खंड का ACK प्राप्त करने के बाद क्लाइंट सर्वर की प्रतिक्रिया की स्वीकृति प्रदान करता है।

रिहाई

सर्वर और क्लाइंट या तो टीसीपी सेगमेंट को फ़ाइनल फ़्लैग सेट के साथ भेज सकते हैं। 1. जब रिसीविंग एंड इसे ACKnowledging फिन द्वारा वापस प्रतिक्रिया करता है, तो टीसीपी संचार की दिशा बंद हो जाती है और कनेक्शन जारी हो जाता है।

बैंडविड्थ प्रबंधन

बंधन प्रबंधन की आवश्यकता को समायोजित करने के लिए टीसीपी खिड़की के आकार की अवधारणा का उपयोग करता है। विंडो का आकार दूरस्थ छोर पर प्रेषक को बताता है, डेटा बाइट की संख्या इस छोर पर रिसीवर को प्राप्त कर सकती है। टीसीपी खिड़की के आकार 1 का उपयोग करके धीमी शुरुआत चरण का उपयोग करता है और प्रत्येक सफल संचार के बाद खिड़की के आकार को तेजी से बढ़ाता है।

उदाहरण के लिए, क्लाइंट विंडोज़ साइज़ 2 का उपयोग करता है और 2 बाइट्स डेटा भेजता है। जब इस सेगमेंट की पावती प्राप्त हुई तो विंडो का आकार 4 से दोगुना हो जाएगा और अगले भेजे गए सेगमेंट में 4 डेटा बाइट्स लंबे होंगे। जब 4-बाइट डेटा सेगमेंट की पावती प्राप्त होती है, तो क्लाइंट विंडोज का आकार 8 और इतने पर सेट करता है।

यदि एक पावती याद आती है, यानी पारगमन नेटवर्क में डेटा खो जाता है या इसे NACK प्राप्त होता है, तो विंडो का आकार आधा हो जाता है और धीमी शुरुआत चरण फिर से शुरू होता है।

त्रुटि नियंत्रण और प्रवाह नियंत्रण

टीसीपी यह जानने के लिए पोर्ट नंबर का उपयोग करती है कि डेटा सेक्शन को हैंडओवर करने के लिए किस एप्लिकेशन प्रक्रिया की आवश्यकता है। इसके साथ ही, यह दूरस्थ होस्ट के साथ खुद को सिंक्रनाइज़ करने के लिए अनुक्रम संख्या का उपयोग करता है। सभी डेटा खंडों को अनुक्रम संख्याओं के साथ भेजा और प्राप्त किया जाता है। प्रेषक जानता है कि कौन सा अंतिम डेटा खंड रिसीवर द्वारा प्राप्त किया गया था जब वह एसीके प्राप्त करता है। प्राप्तकर्ता हाल ही में प्राप्त पैकेट के अनुक्रम संख्या का संदर्भ देकर प्रेषक द्वारा भेजे गए अंतिम खंड के बारे में जानता है।

यदि हाल ही में प्राप्त एक खंड का अनुक्रम संख्या रिसीवर द्वारा अनुक्रम संख्या के साथ मेल नहीं खाता है, तो उसे छोड़ दिया जाता है और एनएके को वापस भेज दिया जाता है। यदि दो खंड समान अनुक्रम संख्या के साथ आते हैं, तो टीसीपी टाइमस्टैम्प मान की तुलना एक निर्णय लेने के लिए की जाती है।

बहुसंकेतन

एक सत्र में दो या अधिक डेटा धाराओं को संयोजित करने की तकनीक को मल्टीप्लेक्सिंग कहा जाता है। जब एक टीसीपी क्लाइंट सर्वर के साथ एक कनेक्शन को इनिशियलाइज़ करता है, तो यह हमेशा एक अच्छी तरह से परिभाषित पोर्ट नंबर को संदर्भित करता है जो एप्लिकेशन प्रक्रिया को इंगित करता है। क्लाइंट स्वयं निजी पोर्ट नंबर पूल से एक बेतरतीब ढंग से उत्पन्न पोर्ट नंबर का उपयोग करता है।

टीसीपी मल्टीप्लेक्सिंग का उपयोग करते हुए, एक ग्राहक एक ही सत्र में विभिन्न आवेदन प्रक्रिया के साथ संवाद कर सकता है। उदाहरण के लिए, एक क्लाइंट एक वेब पेज का अनुरोध करता है, जिसमें बदले में विभिन्न प्रकार के डेटा (HTTP, SMTP, FTP आदि) शामिल होते हैं, टीसीपी सत्र का समय बढ़ा दिया जाता है और सत्र को अधिक समय तक खुला रखा जाता है, ताकि तीन-तरफ़ा हैंडशेक ओवरहेड कर सकें दूर रहे।

यह क्लाइंट सिस्टम को सिंगल वर्चुअल कनेक्शन पर कई कनेक्शन प्राप्त करने में सक्षम बनाता है। यदि टाइमआउट बहुत लंबा है, तो ये वर्चुअल कनेक्शन सर्वर के लिए अच्छे नहीं हैं।

भीड़ नियंत्रण

जब बड़ी मात्रा में डेटा सिस्टम को खिलाया जाता है जो इसे संभालने में सक्षम नहीं होता है, तो भीड़ होती है। टीसीपी विंडो तंत्र के माध्यम से भीड़ को नियंत्रित करता है। टीसीपी एक खिड़की के आकार को बताता है जो दूसरे छोर को बताता है कि कितना डेटा खंड भेजना है। टीसीपी भीड़ नियंत्रण के लिए तीन एल्गोरिदम का उपयोग कर सकता है:

  • योजक वृद्धि, गुणक में कमी

  • धीमी शुरुआत

  • टाइमआउट प्रतिक्रिया

समय प्रबंधन

टीसीपी विभिन्न कार्यों को नियंत्रित करने और प्रबंधन करने के लिए विभिन्न प्रकार के टाइमर का उपयोग करता है:

ज़िंदा रखें टाइमर:

  • इस टाइमर का उपयोग किसी कनेक्शन की अखंडता और वैधता की जांच करने के लिए किया जाता है।

  • जब जीवित-समय समाप्त हो जाता है, तो होस्ट यह जांचने के लिए जांच भेजता है कि क्या कनेक्शन अभी भी मौजूद है।

रिट्रांसमिशन टाइमर:

  • यह टाइमर भेजे गए डेटा के स्टेटफुल सेशन को बनाए रखता है।

  • यदि भेजे गए डेटा की पावती रिट्रांसमिशन समय के भीतर प्राप्त नहीं होती है, तो डेटा खंड फिर से भेजा जाता है।

लगातार टाइमर:

  • विंडो साइज़ 0 भेजकर टीसीपी सत्र को मेजबान द्वारा रोका जा सकता है।

  • सत्र को फिर से शुरू करने के लिए एक मेजबान को कुछ बड़े मूल्य के साथ विंडो आकार भेजने की आवश्यकता होती है।

  • यदि यह खंड कभी दूसरे छोर तक नहीं पहुंचता है, तो दोनों छोर अनंत समय तक एक-दूसरे का इंतजार कर सकते हैं।

  • जब पर्सिस्ट टाइमर समाप्त हो जाता है, तो मेजबान दूसरे छोर को पता करने के लिए अपने विंडो का आकार फिर से भेजता है।

  • पर्सिस्ट टिमर संचार में गतिरोध से बचने में मदद करता है।

समयबद्ध-प्रतीक्षा:

  • एक कनेक्शन जारी करने के बाद, या तो मेजबान पूरी तरह से कनेक्शन को समाप्त करने के लिए एक समयबद्ध प्रतीक्षा की प्रतीक्षा करता है।

  • यह सुनिश्चित करने के लिए है कि दूसरे छोर को अपने कनेक्शन समाप्ति अनुरोध की पावती प्राप्त हुई है।

  • टाइम-आउट अधिकतम 240 सेकंड (4 मिनट) हो सकता है।

क्रैश रिकवरी

टीसीपी बहुत विश्वसनीय प्रोटोकॉल है। यह खंड में भेजे गए प्रत्येक बाइट को अनुक्रम संख्या प्रदान करता है। यह फीडबैक मैकेनिज्म प्रदान करता है यानी जब कोई होस्ट पैकेट प्राप्त करता है, तो वह एसीके से जुड़ा होता है, जिसके पैकेट में अगले अनुक्रम की उम्मीद होती है (यदि यह अंतिम खंड नहीं है)।

जब एक टीसीपी सर्वर मध्य-मार्ग संचार को क्रैश कर देता है और अपनी प्रक्रिया को फिर से शुरू करता है तो यह अपने सभी मेजबानों को TPDU प्रसारण भेजता है। मेजबान फिर अंतिम डेटा खंड भेज सकते हैं जो कभी भी अनजाने में नहीं था और बाद में ले जाता है।