SDLC - राड मॉडल
RAD (Rapid Application Development)मॉडल प्रोटोटाइपिंग और पुनरावृत्त विकास पर आधारित है जिसमें कोई विशिष्ट योजना शामिल नहीं है। सॉफ्टवेयर लिखने की प्रक्रिया में उत्पाद को विकसित करने के लिए आवश्यक योजना शामिल है।
रैपिड एप्लिकेशन डेवलपमेंट कार्यशालाओं या फ़ोकस समूहों के माध्यम से ग्राहकों की आवश्यकताओं को इकट्ठा करने पर केंद्रित है, पुनरावृत्त अवधारणा का उपयोग करके ग्राहक द्वारा प्रोटोटाइप का प्रारंभिक परीक्षण, मौजूदा प्रोटोटाइप (घटकों) का पुन: उपयोग, निरंतर एकीकरण और तेजी से वितरण।
राड क्या है?
रैपिड एप्लिकेशन डेवलपमेंट एक सॉफ्टवेयर डेवलपमेंट मेथोडोलॉजी है जो रैपिड प्रोटोटाइप के पक्ष में न्यूनतम नियोजन का उपयोग करता है। एक प्रोटोटाइप एक कामकाजी मॉडल है जो कार्यात्मक रूप से उत्पाद के एक घटक के बराबर है।
आरएडी मॉडल में, कार्यात्मक मॉड्यूल को प्रोटोटाइप के रूप में समानांतर में विकसित किया जाता है और तेजी से उत्पाद वितरण के लिए पूर्ण उत्पाद बनाने के लिए एकीकृत किया जाता है। चूंकि कोई विस्तृत प्रीप्लेनिंग नहीं है, इसलिए विकास प्रक्रिया के भीतर परिवर्तनों को शामिल करना आसान हो जाता है।
आरएडी परियोजनाएं पुनरावृत्त और वृद्धिशील मॉडल का पालन करती हैं और इसमें छोटे दल होते हैं जिनमें डेवलपर्स, डोमेन विशेषज्ञ, ग्राहक प्रतिनिधि और उनके घटक या प्रोटोटाइप पर उत्तरोत्तर काम करने वाले अन्य आईटी संसाधन शामिल होते हैं।
इस मॉडल के सफल होने के लिए सबसे महत्वपूर्ण पहलू यह सुनिश्चित करना है कि विकसित किए गए प्रोटोटाइप पुन: प्रयोज्य हैं।
राड मॉडल डिजाइन
आरएडी मॉडल लघु, पुनरावृत्त विकास चक्रों की श्रृंखला में विश्लेषण, डिजाइन, निर्माण और परीक्षण वितरित करता है।
राड मॉडल के विभिन्न चरण निम्नलिखित हैं -
बिजनेस मॉडलिंग
विकास के तहत उत्पाद के लिए व्यवसाय मॉडल को सूचना के प्रवाह और विभिन्न व्यावसायिक चैनलों के बीच सूचना के वितरण के संदर्भ में डिज़ाइन किया गया है। व्यवसाय के लिए महत्वपूर्ण जानकारी प्राप्त करने के लिए एक पूर्ण व्यवसाय विश्लेषण किया जाता है, यह कैसे प्राप्त किया जा सकता है, कैसे और कब संसाधित जानकारी है और जानकारी के सफल प्रवाह को चलाने वाले कारक क्या हैं।
डेटा मॉडलिंग
बिजनेस मॉडलिंग चरण में एकत्र की गई जानकारी की समीक्षा की जाती है और व्यापार के लिए महत्वपूर्ण डेटा ऑब्जेक्ट के सेट बनाने के लिए विश्लेषण किया जाता है। सभी डेटा सेट की विशेषताओं को पहचाना और परिभाषित किया गया है। इन डेटा ऑब्जेक्ट्स के बीच का संबंध व्यवसाय मॉडल के लिए प्रासंगिकता में विस्तार से स्थापित और परिभाषित किया गया है।
प्रक्रिया मॉडलिंग
डेटा मॉडलिंग चरण में परिभाषित डेटा ऑब्जेक्ट सेट को व्यवसाय मॉडल के अनुसार विशिष्ट व्यावसायिक उद्देश्यों को प्राप्त करने के लिए आवश्यक व्यावसायिक सूचना प्रवाह को स्थापित करने के लिए परिवर्तित किया जाता है। डेटा ऑब्जेक्ट सेट में किसी भी परिवर्तन या वृद्धि के लिए प्रक्रिया मॉडल इस चरण में परिभाषित किया गया है। डेटा ऑब्जेक्ट को जोड़ने, हटाने, पुनर्प्राप्त करने या संशोधित करने के लिए प्रक्रिया विवरण दिए गए हैं।
अनुप्रयोग पीढ़ी
वास्तविक प्रणाली को बनाया गया है और प्रक्रिया और डेटा मॉडल को वास्तविक प्रोटोटाइप में बदलने के लिए स्वचालन उपकरणों का उपयोग करके कोडिंग की जाती है।
परीक्षण और कारोबार
आरएडी मॉडल में समग्र परीक्षण समय कम हो जाता है क्योंकि प्रोटोटाइप को हर पुनरावृत्ति के दौरान स्वतंत्र रूप से परीक्षण किया जाता है। हालांकि, सभी घटकों के बीच डेटा प्रवाह और इंटरफेस को पूरी तरह से परीक्षण कवरेज के साथ अच्छी तरह से जांचने की आवश्यकता है। चूंकि अधिकांश प्रोग्रामिंग घटकों का परीक्षण पहले ही किया जा चुका है, इसलिए यह किसी भी प्रमुख मुद्दों के जोखिम को कम करता है।
निम्नलिखित उदाहरण राड मॉडल के बारे में विस्तार से बताते हैं।
राड मॉडल बनाम पारंपरिक एसडीएलसी
पारंपरिक एसडीएलसी आवश्यकता विश्लेषण और कोडिंग शुरू होने से पहले एकत्रित होने पर अधिक जोर देने के साथ एक कठोर प्रक्रिया मॉडल का पालन करता है। यह परियोजना शुरू होने से पहले आवश्यकताओं पर हस्ताक्षर करने के लिए ग्राहक पर दबाव डालता है और ग्राहक को उत्पाद की अनुभूति नहीं होती है क्योंकि लंबे समय तक कोई कार्य निर्माण उपलब्ध नहीं है।
सॉफ्टवेयर को देखने के लिए ग्राहक को कुछ परिवर्तनों की आवश्यकता हो सकती है। हालांकि, परिवर्तन प्रक्रिया काफी कठोर है और पारंपरिक एसडीएलसी में उत्पाद में बड़े बदलाव को शामिल करना संभव नहीं है।
आरएडी मॉडल ग्राहक को काम करने वाले मॉडल के पुनरावृत्त और वृद्धिशील वितरण पर केंद्रित है। यह उत्पाद के पूर्ण विकास चक्र के दौरान ग्राहक और ग्राहक की भागीदारी के लिए तेजी से वितरण के परिणामस्वरूप वास्तविक उपयोगकर्ता आवश्यकताओं के साथ गैर-अनुरूपता के जोखिम को कम करता है।
राड मॉडल - अनुप्रयोग
रेड मॉडल को उन परियोजनाओं के लिए सफलतापूर्वक लागू किया जा सकता है जिनमें स्पष्ट रूप से संशोधन संभव है। यदि परियोजना मॉड्यूल में नहीं तोड़ी जा सकती है, तो RAD विफल हो सकता है।
निम्नलिखित संकेत उन विशिष्ट परिदृश्यों का वर्णन करते हैं जहां आरएडी का उपयोग किया जा सकता है -
राड का उपयोग केवल तब किया जाना चाहिए जब एक प्रणाली को वृद्धिशील तरीके से वितरित करने के लिए संशोधित किया जा सकता है।
यदि मॉडलिंग के लिए डिजाइनरों की अधिक उपलब्धता है तो इसका उपयोग किया जाना चाहिए।
इसका उपयोग केवल तभी किया जाना चाहिए जब बजट स्वचालित कोड जनरेटिंग टूल के उपयोग की अनुमति देता है।
राड एसडीएलसी मॉडल को केवल तभी चुना जाना चाहिए जब डोमेन विशेषज्ञ प्रासंगिक व्यावसायिक ज्ञान के साथ उपलब्ध हों।
उपयोग किया जाना चाहिए जहां परियोजना के दौरान आवश्यकताओं में परिवर्तन होता है और 2-3 महीनों के छोटे पुनरावृत्तियों में ग्राहक को प्रस्तुत करना होता है।
राड मॉडल - पेशेवरों और विपक्ष
राड मॉडल तेजी से वितरण को सक्षम करता है क्योंकि यह घटकों के पुन: प्रयोज्य और समानांतर विकास के कारण समग्र विकास समय को कम करता है। राड तभी अच्छा काम करता है जब उच्च कुशल इंजीनियर उपलब्ध हों और ग्राहक निर्धारित समय सीमा में लक्षित प्रोटोटाइप प्राप्त करने के लिए भी प्रतिबद्ध हो। अगर दोनों तरफ प्रतिबद्धता की कमी है तो मॉडल विफल हो सकता है।
राड मॉडल के फायदे इस प्रकार हैं -
बदलती आवश्यकताओं को समायोजित किया जा सकता है।
प्रगति को मापा जा सकता है।
शक्तिशाली आरएडी उपकरणों के उपयोग के साथ Iteration का समय कम हो सकता है।
थोड़े समय में कम लोगों के साथ उत्पादकता।
विकास का समय कम कर दिया।
घटकों की पुन: प्रयोज्यता बढ़ाता है।
त्वरित प्रारंभिक समीक्षाएं होती हैं।
ग्राहकों की प्रतिक्रिया को प्रोत्साहित करता है।
बहुत शुरुआत से एकीकरण एकीकरण मुद्दों का एक बहुत हल करती है।
राड मॉडल के नुकसान इस प्रकार हैं -
व्यावसायिक आवश्यकताओं की पहचान के लिए तकनीकी रूप से मजबूत टीम के सदस्यों पर निर्भरता।
केवल सिस्टम जिसे मॉड्यूलर किया जा सकता है वह आरएडी का उपयोग करके बनाया जा सकता है।
अत्यधिक कुशल डेवलपर्स / डिजाइनरों की आवश्यकता है।
मॉडलिंग कौशल पर अत्यधिक निर्भरता।
मॉडलिंग और स्वचालित कोड पीढ़ी की लागत के रूप में सस्ती परियोजनाओं के लिए अनुपयुक्त बहुत अधिक है।
प्रबंधन की जटिलता अधिक है।
उन प्रणालियों के लिए उपयुक्त है जो घटक आधारित और स्केलेबल हैं।
पूरे जीवन चक्र में उपयोगकर्ता की भागीदारी की आवश्यकता है।
छोटे विकास समय की आवश्यकता वाले प्रोजेक्ट के लिए उपयुक्त है।