WebSockets - एपीआई

एपीआई - परिभाषा

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

कुछ महत्वपूर्ण विशेषताएं हैं -

  • एपीआई निर्दिष्ट करता है कि सॉफ्टवेयर घटकों को कैसे इंटरैक्ट करना चाहिए और ग्राफिकल यूजर इंटरफेस (जीयूआई) घटकों को प्रोग्रामिंग करते समय एपीआई का उपयोग किया जाना चाहिए।

  • एक अच्छा एपीआई सभी बिल्डिंग ब्लॉक्स प्रदान करके एक प्रोग्राम विकसित करना आसान बनाता है।

  • REST, जो आमतौर पर HTTP पर चलता है, अक्सर मोबाइल एप्लिकेशन, सोशल वेबसाइट, मैशअप टूल और स्वचालित व्यावसायिक प्रक्रियाओं में उपयोग किया जाता है।

  • REST शैली इस बात पर जोर देती है कि क्लाइंट और सेवाओं के बीच सीमित संख्या में संचालन (क्रिया) होने से परस्पर क्रियाओं में वृद्धि होती है।

  • संसाधनों को असाइन करके लचीलापन प्रदान किया जाता है; उनके अपने अद्वितीय यूनिवर्सल रिसोर्स आइडेंटिफ़ायर (URI)।

  • REST अस्पष्टता से बचता है क्योंकि प्रत्येक क्रिया का एक विशिष्ट अर्थ है (GET, POST, PUT और DELETE)

वेब सॉकेट के लाभ

वेब सॉकेट सामान्य रूप से REST या HTTP के साथ कुछ समस्याओं को हल करता है -

द्विदिश

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

फुल डुप्लेक्स

HTTP क्लाइंट से सर्वर पर जाने के लिए अनुरोध संदेश की अनुमति देता है और फिर सर्वर क्लाइंट को एक प्रतिक्रिया संदेश भेजता है। किसी दिए गए समय में, या तो क्लाइंट सर्वर से बात कर रहा है या सर्वर क्लाइंट से बात कर रहा है। वेब सॉकेट क्लाइंट और सर्वर को एक दूसरे से स्वतंत्र बात करने की अनुमति देता है।

सिंगल टीसीपी कनेक्शन

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

नीचे दिया गया ग्राफ एक स्थिर पेलोड आकार के लिए एन संदेशों को संसाधित करने के लिए लिया गया समय (मिलीसेकंड में) दिखाता है।

यहाँ कच्चा डेटा है जो इस ग्राफ को खिलाता है -

ऊपर दिया गया ग्राफ़ और तालिका दर्शाती है कि संदेशों की संख्या के साथ REST ओवरहेड बढ़ता है। यह सच है क्योंकि कई टीसीपी कनेक्शनों को शुरू करने और समाप्त करने की आवश्यकता है और कई HTTP हेडर को भेजने और प्राप्त करने की आवश्यकता है।

अंतिम कॉलम विशेष रूप से REST अनुरोध को पूरा करने के लिए समय की मात्रा के लिए गुणन कारक को दर्शाता है।

दूसरा ग्राफ पेलोड के आकार को अलग-अलग करके संदेशों की निश्चित संख्या को संसाधित करने में लगने वाले समय को दर्शाता है।

यहाँ कच्चा डेटा है जो इस ग्राफ को खिलाता है -

यह ग्राफ दर्शाता है कि REST समापन बिंदु के लिए अनुरोध / प्रतिक्रिया को संसाधित करने की वृद्धिशील लागत न्यूनतम है और अधिकांश समय कनेक्शन दीक्षा / समाप्ति और HTTP शब्दार्थ को सम्मानित करने में व्यतीत होता है।

निष्कर्ष

वेब सॉकेट एक निम्न-स्तरीय प्रोटोकॉल है। एक साधारण अनुरोध / प्रतिक्रिया डिजाइन पैटर्न, कैसे बनाने / अद्यतन / हटाने के लिए संसाधनों की जरूरत है, स्थिति कोड आदि सहित, सब कुछ इसके शीर्ष पर बनाता है। ये सभी HTTP के लिए अच्छी तरह से परिभाषित हैं।

वेब सॉकेट एक स्टेटफुल प्रोटोकॉल है जबकि HTTP एक स्टेटलेस प्रोटोकॉल है। वेब सॉकेट कनेक्शन एक सर्वर पर लंबवत रूप से स्केल कर सकता है जबकि HTTP क्षैतिज रूप से स्केल कर सकता है। वेब सॉकेट क्षैतिज स्केलिंग के लिए कुछ मालिकाना समाधान हैं, लेकिन वे मानकों पर आधारित नहीं हैं। HTTP कई अन्य अच्छाइयों जैसे कैशिंग, रूटिंग और मल्टीप्लेक्सिंग के साथ आता है। इन सभी को वेब सॉकेट के शीर्ष पर परिभाषित करने की आवश्यकता है।