विहित प्रोटोकॉल पैटर्न

कैनोनिकल प्रोटोकॉल एक प्रारूप प्रतिमान है, जिसे सेवा-उन्मुख प्रारूप प्रतिमान के अंदर लागू किया जाता है, जिसका प्रयास होता है कि सेवा इन्वेंट्री में आपसी सम्बन्ध स्थापित हों। यह सेवाओं के बीच संचार प्रोटोकॉल को मानकीकृत करके उन्हें एक-दूसरे के साथ संगत बनाने का प्रयास  करता है। जब सेवाएँ विभिन्न संचार प्रोटोकॉल का उपयोग करती हैं तो यह संचार प्रोटोकॉल को  सेतु  की आवश्यकता को समाप्त कर देता है। जब सेवाएं विभिन्न संचार प्रोटोकॉल का उपयोग करती हैं, तो कैनोनिकल प्रोटोकॉल के द्वारा ब्रिजिंग संचार प्रोटोकॉल की आवश्यकता को समाप्त किया जाता है।

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

एक सेवा इन्वेंटरी प्रारूप करने के लिए, जहां सभी सेवाएं एक-दूसरे के साथ संगत हों जिससे वे विभिन्न समाधानों में संयोजित की जा सकें, कैननिकल प्रोटोकॉल पैटर्न के लागू होने से सेवाओं द्वारा उपयोग किए जाने वाले संचार प्रोटोकॉल को मानकीकृत किया जाना आवश्यक होता है। जब सभी सेवाएं एक ही संचार प्रोटोकॉल का उपयोग कर रही होती हैं, तो मध्यवर्ती प्रौद्योगिकी की आवश्यकता समाप्त हो जाती है और सेवाओं के मध्य संचार अधिक संगठित होता है।

उपयोग
इस प्रारूप प्रतिरूप के अनुप्रयोग के लिए एक प्रौद्योगिकी वास्तुकला को चुनने की आवश्यकता होती है जो एक सामान्य संचार ढांचा प्रदान करती है ताकि एक इन्वेंट्री में सभी सेवाएँ समान संचार प्रोटोकॉल का उपयोग करके एक दूसरे के साथ संचार कर सकें। यह इस बात पर निर्भर करता है कि सेवा सूची के अंदर सेवाओं का उपयोग कैसे किया जाएगा। यदि सेवाएँ केवल उन सेवा संरचनाओं का हिस्सा बनने जा रही हैं जो हमेशा एक विशेष संचार प्रोटोकॉल (दक्षता और सुरक्षा कारणों से) का उपयोग करती हैं, तो उस सेवा सूची के अंदर सभी सेवाएँ ऐसे संचार प्रोटोकॉल पर बनाई जा सकती हैं, भले ही वह न हो सबसे व्यापक रूप से उपयोग किया जाने वाला प्रोटोकॉल।

थॉमस एर्ल द्वारा कैनोनिकल प्रोटोकॉल प्रतिरूप इस प्रश्न का उत्तर देता है: प्रोटोकॉल ब्रिजिंग से बचने के लिए सेवाओं को कैसे प्रारूप किया जा सकता है? समस्या यह है कि विभिन्न संचार प्रौद्योगिकियों का समर्थन करने वाली सेवाएँ अंतरसंचालनीयता से समझौता करती हैं, संभावित उपभोक्ताओं की मात्रा को सीमित करती हैं, और अवांछनीय प्रोटोकॉल ब्रिजिंग उपायों की आवश्यकता का परिचय देती हैं। आर्किटेक्चर के लिए इसका समाधान एकल संचार प्रौद्योगिकी को एकमात्र या प्राथमिक माध्यम के रूप में स्थापित करना है जिसके द्वारा सेवाएं बातचीत कर सकती हैं। इसलिए, सेवा सूची सीमा के अंदर उपयोग किए जाने वाले संचार प्रोटोकॉल (प्रोटोकॉल संस्करणों सहित) सभी सेवाओं के लिए मानकीकृत हैं (आरेख देखें)।

सबसे परिपक्व और व्यापक रूप से उपयोग किए जाने वाले संचार तंत्रों में से एक वेब सेवा ढांचे द्वारा प्रदान किया जाता है। संचार ढाँचे को चुनने के अलावा, वास्तविक संदेश प्रोटोकॉल को भी मानकीकृत करने की आवश्यकता है। उदाहरण के लिए, क्या वेब सेवाएँ HTTP पर SOAP का उपयोग करके बनाई गई हैं या केवल RESTful सेवाओं का उपयोग करके बनाई गई हैं। इसी प्रकार, SOAP आधारित वेब सेवाओं पर मानकीकरण करते समय, SOAP प्रोटोकॉल के विशिष्ट संस्करण यानी SOAP v 1.1 या SOAP v 1.2 पर भी सहमति की आवश्यकता होती है।

विचार
संचार प्रोटोकॉल पर मानकीकरण करने के लिए, सुरक्षा, दक्षता और लेनदेन समर्थन सहित सेवा इंटरैक्शन आवश्यकताओं के साथ प्रोटोकॉल की विशेषताओं की तुलना करने की आवश्यकता है। उदाहरण के लिए, वेब सेवाओं के मामले में, यदि किसी सेवा संरचना को स्पष्ट लेनदेन समर्थन की आवश्यकता होती है, तो HTTP पर SOAP RESTful सेवाओं का उपयोग करने से बेहतर विकल्प होगा।

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

संचार ढाँचा चुनते समय, परिपक्वता, स्केलेबिलिटी और किसी भी लाइसेंसिंग लागत को ध्यान में रखा जाना चाहिए क्योंकि निकट भविष्य में अप्रचलित होने वाले प्रोटोकॉल का उपयोग करके सेवाओं का निर्माण ऐसी सेवाओं की पुन: प्रयोज्यता को प्रभावित करेगा और इसके लिए काफी समय और प्रयासों की आवश्यकता होगी। सेवा को पुनः प्रारूप करने के लिए.

संदर्भ

 * Notes


 * Sources
 * Thomas Erl et al., (2009).SOA Design Patterns. Prentice Hall. ISBN 978-0-13-613516-6.

बाहरी संबंध

 * SOA Concepts
 * SOA Terms Glossary
 * SOA Design Patterns