Read this post in: de_DEen_USes_ESfr_FRid_IDjapl_PLpt_PTru_RUvizh_CNzh_TW

UML घटक आरेखों का व्यापक गाइड

UML22 hours ago

UML घटक आरेखों में परिचय

सॉफ्टवेयर इंजीनियरिंग की जटिल दुनिया में, एक प्रणाली के विभिन्न हिस्सों के बीच अंतरक्रिया को समझना महत्वपूर्ण है। एक घटक आरेख में परिभाषित 14 मूलभूत आरेख प्रकारों में से एक हैUML2.5। इसका श्रेणी में शामिल हैसंरचनात्मक आरेखऔर विशेष रूप से एक प्रणाली के भीतर भौतिक या तार्किक घटकों के संगठन और वायरिंग को दृश्यीकृत करने के लिए डिज़ाइन किया गया है।

What is Component Diagram?

इन आरेखों को महत्वपूर्ण संरचनात्मक प्रश्नों के उत्तर देने के लिए आवश्यक है, जैसे:

  • प्रणाली के मुख्य बदले जा सकने वाले या पुनर्उपयोगी हिस्से क्या हैं?
  • इन हिस्सों में एक दूसरे पर निर्भरता कैसे है?
  • विशिष्ट घटक कौन सी इंटरफेस प्रदान करते हैं, और कौन सी उन्हें आवश्यकता होती है?
  • सॉफ्टवेयर को वास्तविक डेप्लॉयमेंट आर्टिफैक्ट्स जैसे JARs, DLLs, या एक्जीक्यूटेबल्स के रूप में कैसे मैप किया जाता है?

घटक आरेख क्लास आरेखों से उच्च स्तरीय अभिन्नता पर ध्यान केंद्रित करके अलग होते हैं। ये बड़े पैमाने पर एंटरप्राइज प्रणालियों, घटक-आधारित संरचनाओं (जैसे SOA, माइक्रोसर्विसेज या OSGi), और Maven मॉड्यूल या Docker इमेज जैसी पैकेजिंग संरचनाओं के दस्तावेजीकरण के लिए विशेष रूप से मूल्यवान हैं।

चरण 1: मुख्य अवधारणाओं और नोटेशन को समझना

एक प्रभावी आरेख बनाने के लिए, आपको पहले मानक नोटेशन को समझना होगा। नीचे घटक आरेखों में उपयोग किए जाने वाले प्राथमिक प्रतीकों का विश्लेषण दिया गया है।

प्रतीक नाम अर्थ दृश्य प्रतिनिधित्व
घटक एक प्रणाली का एक मॉड्यूलर, बदले जा सकने वाला हिस्सा जो कार्यान्वयन को संकलित करता है और इंटरफेस प्रदर्शित करता है। «घटक» शब्दांक के साथ लेबल किया गया आयत या घटक आइकन (बाईं ओर दो छोटे आयत)।
प्रदान की गई इंटरफेस घटक द्वारा अन्य घटकों को प्रदान की जाने वाली कार्यक्षमता। घटक के सीमा पर एक गोलाकार या “बॉल” द्वारा दर्शाया जाता है (आमतौर पर लॉलीपॉप कहलाता है)।
आवश्यक इंटरफेस घटक के कार्य करने के लिए बाहरी स्रोतों से आवश्यक कार्यक्षमता। घटक की सीमा पर आधा वृत्त या “सॉकेट” द्वारा दर्शाया जाता है।
पोर्ट एक घटक पर एक विशिष्ट अंतरक्रिया बिंदु, जिसका उपयोग अक्सर इंटरफेस के समूह के लिए किया जाता है। घटक के किनारे पर एक छोटा वर्ग।
असेंबली कनेक्टर एक आवश्यक इंटरफेस (सॉकेट) को एक प्रदान किए गए इंटरफेस (लॉलीपॉप) से जोड़ने वाला तार। सॉकेट और बॉल को जोड़ने वाली रेखा।
डिलीगेशन कनेक्टर घटक की बाहरी सीमा पर एक पोर्ट को इसके आंतरिक कार्यान्वयन से जोड़ता है। एक बाहरी पोर्ट से आंतरिक भाग या इंटरफेस तक की रेखा।
निर्भरता यह दर्शाता है कि एक घटक दूसरे घटक का उपयोग करता है (इंटरफेस कनेक्शन की तुलना में कम विस्तृत)। निर्भरता की ओर इशारा करने वाली बिंदीदार तीर।
कलाकृति एक भौतिक फ़ाइल या डेप्लॉयमेंट इकाई (जैसे JAR, WAR, DLL)। शब्द «कलाकृति» के साथ लेबल वाला आयत।

चरण 2: इंटरफेस को परिभाषित करना

एक के मुख्य शक्ति हैघटक आरेखइंटरफेस के माध्यम से उपयोग से कार्यान्वयन को अलग करने की क्षमता में निहित है। आपको मॉडल करने के लिए दो अलग-अलग प्रकार के इंटरफेस हैं:

प्रदान किए गए इंटरफेस (लॉलीपॉप)

एक प्रदान किया गया इंटरफेस एक ऐसे संवाद का प्रतिनिधित्व करता है जो घटक पूरा करता है। यह वह सेवा है जो घटक तंत्र के बाकी हिस्से को प्रदान करता है। दृश्य रूप से, इसे एक पूर्ण वृत्त (गेंद) के रूप में दर्शाया जाता है जो ठोस रेखा के माध्यम से घटक से जुड़ा होता है।

Required and provided interface

आवश्यक इंटरफेस (सॉकेट)

एक आवश्यक इंटरफेस एक निर्भरता का प्रतिनिधित्व करता है। यह बताता है कि घटक को अपना काम करने के लिए क्या चाहिए। दृश्य रूप से, इसे घटक से जुड़े एक अर्धवृत्त (सॉकेट) के रूप में दर्शाया जाता है।

जब आप एक को जोड़ते हैंसॉकेटएक घटक से दूसरे केलॉलीपॉपको जोड़ते हैं, तो आप एक बनाते हैंअसेंबली कनेक्टर। इससे यह संकेत मिलता है कि पहले घटक की आवश्यकता दूसरे घटक द्वारा प्रदान की गई कार्यक्षमता द्वारा पूरी की जाती है।

चरण 3: पोर्ट्स और आंतरिक संरचना का उपयोग करना

जटिल प्रणालियों के लिए, विशेष रूप से माइक्रोसर्विसेज या परतदार आर्किटेक्चर में, घटकों में आंतरिक संरचना या विशिष्ट अंतरक्रिया बिंदु हो सकते हैं जिन्हें कहा जाता हैपोर्ट्स.

पोर्ट्स का उपयोग करना

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

आंतरिक संयुक्त संरचना

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

चरण 4: कलाकृतियों और डेप्लॉयमेंट के लिए मैपिंग

जबकि घटक तार्किक इकाइयों का प्रतिनिधित्व करते हैं, कलाकृतियाँभौतिक फ़ाइलों का प्रतिनिधित्व करते हैं जो डेप्लॉय किए जाते हैं। मैनिफेस्ट संबंध यह दिखाता है कि घटकों को कैसे पैकेज किया जाता है।

उदाहरण के लिए, आपके पास एक तार्किक घटक हो सकता है जिसका नाम हैऑर्डर सेवाभौतिक दुनिया में, इसे एक फ़ाइल में पैक किया जा सकता है जिसका नाम हैऑर्डर-सर्विस.jarआप इस संबंध को एक डैश्ड तीर के साथ दिखाते हैं जिस पर लेबल है«मैनिफेस्ट»कलाकृति से घटक की ओर इशारा करते हुए।

चरण 5: वास्तविक दुनिया के उपयोग के मामले

घटक आरेख लचीले होते हैं। यहां कुछ सामान्य स्थितियां हैं जहां वे उत्कृष्ट प्रदर्शन करते हैं:

  • माइक्रोसर्विस आर्किटेक्चर: प्रत्येक सेवा को घटक के रूप में मॉडलिंग और परिभाषित करनाREST या gRPC एंडपॉइंट्स को इंटरफेस के रूप में।
  • तृतीय-पक्ष एकीकरण: बाहरी प्रणालियों जैसे स्ट्राइप या SAP से जुड़ने वाले आवश्यक इंटरफेस को स्पष्ट रूप से दिखाना।
  • पुराने आधुनिकीकरण: पुनर्गठन से पहले निर्भरताओं को समझने के लिए पुराने DLLs या लाइब्रेरियों का विवरण तैयार करना।
  • CI/CD योजना: तार्किक घटकों को Docker छवियों या NuGet पैकेजों से मैप करना ताकि जांच की जा सकेडेप्लॉयमेंट रणनीतियाँ.

चरण 6: प्रभावी आरेखों के लिए सर्वोत्तम प्रथाएँ

अपने को सुनिश्चित करने के लिएघटक आरेखपठनीय और उपयोगी हों, इन सर्वोत्तम प्रथाओं का पालन करें:

  1. उचित दायरे को निर्धारित करें: एक ही आरेख में पूरी एंटरप्राइज को मॉडल न करने की कोशिश करें। विशिष्ट उपप्रणालियों के लिए अलग-अलग आरेख बनाएं।
  2. इंटरफेस को प्राथमिकता दें: इस आरेख का मूल्य दिखाने में हैअनुबंध सुनिश्चित करें कि आप प्रदान किए गए और आवश्यक इंटरफेस के बीच स्पष्ट अंतर बनाएं।
  3. स्टेरियोटाइप्स का उपयोग करें: घटक की प्रकृति को स्पष्ट करने के लिए «सेवा», «डेटाबेस», या «फेसेड» जैसे लेबल का उपयोग करें।
  4. स्पैगेटी से बचें: केवल महत्वपूर्ण निर्भरताओं को दिखाएं। यदि प्रत्येक घटक एक उपयोगिता लाइब्रेरी पर निर्भर है, तो आमतौर पर प्रत्येक घटक से उस लाइब्रेरी तक रेखा खींचने की आवश्यकता नहीं होती है; यह दृश्य को भ्रमित करता है।
  5. स्थिरता: आरेख के दौरान एक ही आइकन शैली (स्टेरियोटाइप टेक्स्ट या घटक आइकन) का पालन करें।

निष्कर्ष

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

निम्नलिखित लेख और ट्यूटोरियल बनाने और उपयोग करने के बारे में जानकारी प्रदान करते हैं UML कंपोनेंट डायग्राम, जिसमें AI द्वारा सुधारित डायग्राम भी शामिल हैं, Visual Paradigm वातावरण के भीतर:

Sidebar
Loading

Signing-in 3 seconds...

Signing-up 3 seconds...