सॉफ्टवेयर वास्तुकला और डिजाइन परिचय
एक प्रणाली की वास्तुकला इसके प्रमुख घटकों, उनके संबंधों (संरचनाओं) का वर्णन करती है, और वे एक दूसरे के साथ कैसे बातचीत करते हैं। सॉफ्टवेयर वास्तुकला और डिजाइन में कई योगदान कारक शामिल हैं जैसे कि व्यापार रणनीति, गुणवत्ता गुण, मानव गतिशीलता, डिजाइन और आईटी वातावरण।
हम सॉफ्टवेयर आर्किटेक्चर और डिजाइन को दो अलग-अलग चरणों में अलग कर सकते हैं: सॉफ्टवेयर आर्किटेक्चर और सॉफ्टवेयर डिजाइन। मेंArchitecture, गैर-न्यायिक निर्णय कार्यात्मक आवश्यकताओं द्वारा डाले और अलग किए जाते हैं। डिजाइन में, कार्यात्मक आवश्यकताओं को पूरा किया जाता है।
सॉफ़्टवेयर वास्तुशिल्प
आर्किटेक्चर एक के रूप में कार्य करता है blueprint for a system। यह सिस्टम जटिलता का प्रबंधन करने और घटकों के बीच एक संचार और समन्वय तंत्र स्थापित करने के लिए एक अमूर्तता प्रदान करता है।
यह एक परिभाषित करता है structured solution प्रदर्शन और सुरक्षा जैसी सामान्य गुणवत्ता विशेषताओं का अनुकूलन करते हुए, सभी तकनीकी और परिचालन आवश्यकताओं को पूरा करने के लिए।
इसके अलावा, इसमें सॉफ्टवेयर विकास से संबंधित संगठन के बारे में महत्वपूर्ण निर्णय शामिल हैं और इनमें से प्रत्येक निर्णय गुणवत्ता, रखरखाव, प्रदर्शन और अंतिम उत्पाद की समग्र सफलता पर काफी प्रभाव डाल सकता है। इन फैसलों में शामिल हैं -
संरचनात्मक तत्वों का चयन और उनके इंटरफेस जिसके द्वारा सिस्टम की रचना की जाती है।
उन तत्वों के बीच सहयोग में निर्दिष्ट व्यवहार।
इन संरचनात्मक और व्यवहार तत्वों की संरचना बड़े उपतंत्र में।
वास्तु संबंधी निर्णय व्यावसायिक उद्देश्यों के साथ संरेखित होते हैं।
स्थापत्य शैली संगठन का मार्गदर्शन करती है।
सॉफ्टवेर डिज़ाइन
सॉफ्टवेयर डिजाइन प्रदान करता है design planसिस्टम के तत्वों का वर्णन करता है कि वे कैसे फिट होते हैं, और सिस्टम की आवश्यकता को पूरा करने के लिए एक साथ काम करते हैं। एक डिजाइन योजना के उद्देश्य निम्नानुसार हैं -
सिस्टम आवश्यकताओं पर बातचीत करने के लिए, और ग्राहकों, विपणन और प्रबंधन कर्मियों के साथ अपेक्षाएं निर्धारित करने के लिए।
विकास प्रक्रिया के दौरान एक खाका के रूप में कार्य करें।
विस्तृत डिजाइन, कोडिंग, एकीकरण और परीक्षण सहित कार्यान्वयन कार्यों को निर्देशित करें।
यह विस्तृत डिजाइन, कोडिंग, एकीकरण, और परीक्षण से पहले और डोमेन विश्लेषण, आवश्यकताओं के विश्लेषण, और जोखिम विश्लेषण के बाद आता है।
आर्किटेक्चर के लक्ष्य
आर्किटेक्चर का प्राथमिक लक्ष्य उन आवश्यकताओं की पहचान करना है जो एप्लिकेशन की संरचना को प्रभावित करते हैं। एक अच्छी तरह से रखी गई वास्तुकला एक तकनीकी समाधान के निर्माण से जुड़े व्यावसायिक जोखिमों को कम करती है और व्यापार और तकनीकी आवश्यकताओं के बीच एक पुल का निर्माण करती है।
कुछ अन्य लक्ष्य इस प्रकार हैं -
सिस्टम की संरचना को उजागर करें, लेकिन इसके कार्यान्वयन के विवरण छिपाएं।
सभी उपयोग-मामलों और परिदृश्यों का एहसास करें।
विभिन्न हितधारकों की आवश्यकताओं को संबोधित करने का प्रयास करें।
कार्यात्मक और गुणवत्ता दोनों आवश्यकताओं को संभालें।
स्वामित्व के लक्ष्य को कम करें और संगठन के बाजार की स्थिति में सुधार करें।
गुणवत्ता और कार्यक्षमता में सुधार प्रणाली द्वारा की पेशकश की।
संगठन या सिस्टम में बाहरी आत्मविश्वास में सुधार करें।
सीमाओं
सॉफ्टवेयर इंजीनियरिंग के भीतर सॉफ्टवेयर आर्किटेक्चर अभी भी एक उभरता हुआ अनुशासन है। इसकी निम्नलिखित सीमाएँ हैं -
वास्तुकला का प्रतिनिधित्व करने के लिए उपकरणों की कमी और मानकीकृत तरीके।
विश्लेषण के तरीकों का अभाव यह अनुमान लगाने के लिए कि क्या वास्तुकला उन कार्यान्वयनों के परिणामस्वरूप होगा जो आवश्यकताओं को पूरा करते हैं।
सॉफ्टवेयर विकास के लिए वास्तुशिल्प डिजाइन के महत्व के बारे में जागरूकता का अभाव।
सॉफ्टवेयर आर्किटेक्ट की भूमिका को समझने और हितधारकों के बीच खराब संचार की कमी।
डिजाइन प्रक्रिया, डिजाइन अनुभव और डिजाइन के मूल्यांकन की समझ का अभाव।
सॉफ्टवेयर आर्किटेक्ट की भूमिका
एक सॉफ्टवेयर आर्किटेक्ट एक समाधान प्रदान करता है जिसे तकनीकी टीम पूरे एप्लिकेशन के लिए बना और डिज़ाइन कर सकती है। एक सॉफ्टवेयर आर्किटेक्ट को निम्नलिखित क्षेत्रों में विशेषज्ञता होनी चाहिए -
डिजाइन विशेषज्ञता
सॉफ्टवेयर डिजाइन में विशेषज्ञ, विभिन्न तरीकों और दृष्टिकोणों जैसे ऑब्जेक्ट-ओरिएंटेड डिज़ाइन, ईवेंट-संचालित डिज़ाइन इत्यादि।
विकास टीम का नेतृत्व करें और डिजाइन की अखंडता के लिए विकास के प्रयासों का समन्वय करें।
डिजाइन प्रस्तावों और आपस में व्यापार की समीक्षा करने में सक्षम होना चाहिए।
प्रक्षेत्र विशेषज्ञता
विकसित किए जा रहे सिस्टम पर विशेषज्ञ और सॉफ्टवेयर विकास के लिए योजना।
आवश्यकता जांच प्रक्रिया में सहायता, पूर्णता और स्थिरता का आश्वासन।
विकसित किए जा रहे सिस्टम के लिए डोमेन मॉडल की परिभाषा को समन्वित करें।
प्रौद्योगिकी विशेषज्ञता
उपलब्ध प्रौद्योगिकियों पर विशेषज्ञ जो सिस्टम के कार्यान्वयन में मदद करते हैं।
प्रोग्रामिंग लैंग्वेज, फ्रेमवर्क, प्लेटफॉर्म, डेटाबेस इत्यादि का चयन समन्वय करें।
मेथडोलॉजिकल विशेषज्ञता
एसडीएलसी (सॉफ्टवेयर डेवलपमेंट लाइफ साइकिल) के दौरान अपनाया जा सकता है कि सॉफ्टवेयर विकास के तरीकों पर विशेषज्ञ।
विकास के लिए उपयुक्त दृष्टिकोण चुनें जो पूरी टीम की मदद करता है।
सॉफ्टवेयर वास्तुकार की छिपी भूमिका
टीम के सदस्यों के बीच तकनीकी कार्य को सुगम बनाता है और टीम में विश्वास संबंध को मजबूत करता है।
सूचना विशेषज्ञ जो ज्ञान साझा करता है और विशाल अनुभव रखता है।
बाहरी सदस्यों से टीम के सदस्यों को सुरक्षित रखें जो उन्हें विचलित कर देगा और परियोजना के लिए कम मूल्य लाएगा।
वास्तुकार के उद्धार
कार्यात्मक लक्ष्यों का एक स्पष्ट, पूर्ण, सुसंगत और प्राप्त करने योग्य सेट
अपघटन की कम से कम दो परतों के साथ प्रणाली का एक कार्यात्मक विवरण
प्रणाली के लिए एक अवधारणा
अपघटन की कम से कम दो परतों के साथ प्रणाली के रूप में एक डिजाइन
समय, ऑपरेटर विशेषताओं, और कार्यान्वयन और संचालन योजनाओं की एक धारणा
एक दस्तावेज या प्रक्रिया जो कार्यात्मक अपघटन सुनिश्चित करती है, का पालन किया जाता है और इंटरफेस के रूप को नियंत्रित किया जाता है
गुणवत्ता गुण
गुणवत्ता उत्कृष्टता या कमियों या दोषों से मुक्त होने की स्थिति का एक उपाय है। गुणवत्ता गुण सिस्टम गुण हैं जो सिस्टम की कार्यक्षमता से अलग हैं।
गुणवत्ता विशेषताओं को लागू करने से एक अच्छी प्रणाली को एक बुरे से अलग करना आसान हो जाता है। विशेषताएँ समग्र कारक हैं जो रनटाइम व्यवहार, सिस्टम डिज़ाइन और उपयोगकर्ता अनुभव को प्रभावित करते हैं।
उन्हें इस प्रकार वर्गीकृत किया जा सकता है -
स्थिर गुणवत्ता गुण
एक प्रणाली और संगठन की संरचना को प्रतिबिंबित करें, जो सीधे वास्तुकला, डिजाइन और स्रोत कोड से संबंधित है। वे एंड-यूज़र के लिए अदृश्य हैं, लेकिन विकास और रखरखाव की लागत को प्रभावित करते हैं, जैसे: प्रतिरूपकता, परीक्षणशीलता, रखरखाव, आदि।
गतिशील गुणवत्ता गुण
इसके निष्पादन के दौरान सिस्टम के व्यवहार को प्रतिबिंबित करें। वे सीधे सिस्टम की वास्तुकला, डिजाइन, स्रोत कोड, कॉन्फ़िगरेशन, परिनियोजन पैरामीटर, पर्यावरण और प्लेटफ़ॉर्म से संबंधित हैं।
वे एंड-यूज़र को दिखाई देते हैं और रनटाइम पर मौजूद होते हैं, जैसे थ्रूपुट, मजबूती, स्केलेबिलिटी आदि।
गुणवत्ता परिदृश्य
गुणवत्ता परिदृश्य निर्दिष्ट करते हैं कि किसी गलती को विफलता बनने से कैसे रोका जाए। उन्हें उनकी विशेषता विशिष्टताओं के आधार पर छह भागों में विभाजित किया जा सकता है -
Source - आंतरिक या बाहरी इकाई जैसे कि लोग, हार्डवेयर, सॉफ्टवेयर, या भौतिक अवसंरचना जो उत्तेजना पैदा करते हैं।
Stimulus - एक ऐसी स्थिति जिसे सिस्टम पर आने पर विचार करने की आवश्यकता होती है।
Environment - उत्तेजना कुछ शर्तों के भीतर होती है।
Artifact - एक पूरी प्रणाली या इसका कुछ हिस्सा जैसे प्रोसेसर, संचार चैनल, लगातार भंडारण, प्रक्रियाएं आदि।
Response - उत्तेजना के आने के बाद की गई गतिविधि जैसे दोष का पता लगाना, गलती से उबरना, घटना स्रोत को निष्क्रिय करना आदि।
Response measure - हुई प्रतिक्रियाओं को मापना चाहिए ताकि आवश्यकताओं का परीक्षण किया जा सके।
सामान्य गुणवत्ता गुण
निम्न तालिका सामान्य गुणवत्ता की विशेषता बताती है जो एक सॉफ्टवेयर वास्तुकला में होनी चाहिए -
वर्ग | गुणवत्ता गुण | विवरण |
---|---|---|
डिजाइन की योग्यता | वैचारिक अखंडता | समग्र डिजाइन की स्थिरता और सुसंगतता को परिभाषित करता है। इसमें घटकों या मॉड्यूल को डिजाइन करने का तरीका शामिल है। |
रख-रखाव | आसानी से एक डिग्री के साथ परिवर्तन से गुजरना प्रणाली की क्षमता। | |
पुनर्प्रयोग | अन्य अनुप्रयोगों में उपयोग के लिए उपयुक्त होने के लिए घटकों और उप-प्रणालियों की क्षमता को परिभाषित करता है। | |
रन-टाइम योग्यता | इंटरोऑपरेबिलिटी | किसी बाहरी पार्टी द्वारा लिखी और चलाई गई अन्य बाहरी प्रणालियों के साथ सूचना का संचार और आदान-प्रदान करके सफलतापूर्वक संचालित करने के लिए एक प्रणाली या विभिन्न प्रणालियों की क्षमता। |
प्रबंधन क्षमता | परिभाषित करता है कि सिस्टम प्रशासक के लिए आवेदन का प्रबंधन करना कितना आसान है। | |
विश्वसनीयता | समय के साथ चालू रहने के लिए एक प्रणाली की क्षमता। | |
अनुमापकता | सिस्टम के प्रदर्शन को प्रभावित किए बिना लोड वृद्धि को संभालने की क्षमता या आसानी से बढ़े हुए होने की क्षमता। | |
सुरक्षा | डिज़ाइन किए गए उपयोगों के बाहर दुर्भावनापूर्ण या आकस्मिक कार्यों को रोकने के लिए एक प्रणाली की क्षमता। | |
प्रदर्शन | एक निश्चित समय अंतराल के भीतर किसी भी कार्रवाई को निष्पादित करने के लिए एक प्रणाली की जवाबदेही का संकेत। | |
उपलब्धता | समय के अनुपात को परिभाषित करता है कि प्रणाली कार्यात्मक और काम कर रही है। इसे पूर्वनिर्धारित अवधि में कुल सिस्टम डाउनटाइम के प्रतिशत के रूप में मापा जा सकता है। | |
सिस्टम की योग्यता | supportability | जब यह सही ढंग से काम करने में विफल रहता है तो मुद्दों की पहचान करने और हल करने के लिए सूचना प्रदान करने के लिए प्रणाली की क्षमता। |
testability | माप कितना आसान है यह प्रणाली और इसके घटकों के लिए परीक्षण मानदंड बनाना है। | |
उपयोगकर्ता की योग्यता | प्रयोज्य | परिभाषित करता है कि एप्लिकेशन उपयोगकर्ता और उपभोक्ता की आवश्यकताओं को सहज रूप से पूरा करता है। |
वास्तुकला की गुणवत्ता | यथार्थता | सिस्टम की सभी आवश्यकताओं को पूरा करने के लिए जवाबदेही। |
गैर-रनटाइम गुणवत्ता | पोर्टेबिलिटी | विभिन्न कंप्यूटिंग वातावरण के तहत चलने की प्रणाली की क्षमता। |
समाकलन | सिस्टम के अलग-अलग विकसित घटकों को एक साथ सही ढंग से काम करने की क्षमता। | |
परिवर्तनीयता | आसानी जिसके साथ प्रत्येक सॉफ्टवेयर सिस्टम अपने सॉफ्टवेयर में बदलाव को समायोजित कर सकता है। | |
व्यावसायिक गुणवत्ता के गुण | लागत और अनुसूची | बाजार के लिए समय के साथ प्रणाली की लागत, अपेक्षित परियोजना जीवनकाल और विरासत का उपयोग। |
बेचने को योग्यता | बाजार की प्रतिस्पर्धा के संबंध में प्रणाली का उपयोग। |