हम ओवर-इंजीनियर सॉफ्टवेयर क्यों (और आदत को कैसे तोड़ें)
सार्वजनिक क्लाउड कंप्यूटिंग, कंटेनर ऑर्केस्ट्रेटर्स और माइक्रोसर्विसेज आर्किटेक्चर के लिए तैयार पहुंच के साथ, यह लगभग असीम पैमाने और जटिलता के वितरित सिस्टम बनाने के लिए तुच्छ हो गया है। जबकि इन सभी उपकरणों का अपना उद्देश्य है, इंजीनियरों के लिए यह महत्वपूर्ण है कि वे ध्यान से विचार करें कि उन्हें कब और विशेष रूप से छोटे संगठनों में उपयोग करना है या नहीं। गलत चुनाव करना आपको कम चुस्त, आर्थिक रूप से कम मजबूत और कम सफल बना सकता है। यह लेख कुछ संभावित कारणों की पड़ताल करता है और अनावश्यक जटिलता के सामान्य विरोधी पैटर्न के लिए कुछ उपाय प्रस्तावित करता है।
समस्या
हम जटिलता से शुरू करते हैं
जब हम सॉफ्टवेयर इंजीनियरिंग नौकरियों के लिए साक्षात्कार करते हैं, तो हमें संभावित नियोक्ताओं को यह साबित करने के लिए एक सिंथेटिक, चुनौतीपूर्ण और अक्सर तनावपूर्ण साक्षात्कार प्रक्रिया को नेविगेट करना चाहिए कि हम उन चीजों को जारी रखने के योग्य हैं जो हम पिछले कई वर्षों से कर रहे हैं। इस प्रक्रिया के दौरान, हमें कम समय में कई मध्यम या कठिन एल्गोरिथम प्रश्नों को हल करने के लिए कहा जा सकता है, जो कोडिंग की तुलना में एक दर्शक खेल की तरह अधिक लगता है। हमें आमतौर पर एक घंटे के भीतर एक नई प्रणाली डिजाइन करने की आवश्यकता होती है, जिसकी आवश्यकताओं को हमें पहले साक्षात्कारकर्ता से लेना चाहिए। इनमें से कोई भी अभ्यास उतना नहीं है जितना हम अपनी वास्तविक नौकरियों में करते हैं, बल्कि इसके बजाय "सिग्नल" की अलग-अलग डिग्री का उत्पादन करने के लिए डिज़ाइन की गई चुनौतियाँ हैं जो कि काम पर रखने वाली समितियाँ स्तर और उम्मीदवारों को अलग करने के लिए उपयोग कर सकती हैं।
सिस्टम डिज़ाइन साक्षात्कार , विशेष रूप से, एक ऐसा निर्माण है जहां उम्मीदवारों को बड़े पैमाने पर सिस्टम की व्यापक और गहरी समझ प्रदर्शित करने के लिए कहा जाता है जो आपको बहुत बड़ी कंपनियों में मिल सकता है। हम माइक्रोसर्विसेज , कंसिस्टेंट हैशिंग , इवेंट बसेस , सर्विस मेश , प्रोटोकॉल बफ़र्स , वेबसाकेट्स , कुबेरनेट्स , एपीआई गेटवे , डेटा पाइपलाइन , डेटा लेक जैसी अवधारणाओं का उपयोग करते हैं।, और अन्य प्रौद्योगिकी buzzwords यह दिखाने के लिए कि हम जानते हैं कि वे क्या हैं और उनका उपयोग कैसे किया जाता है। यह संभावित नियोक्ताओं को विश्वास दिलाता है कि हम सभी नवीनतम तकनीकों और उपकरणों पर अद्यतित हैं और हमसे जो कहा जा सकता है वह कर सकते हैं।
जटिलता जटिलता को जन्म देती है
यदि हमें नौकरी मिलती है, तो हमें व्यवसाय के लिए समस्याओं को हल करने के लिए भर्ती प्रक्रिया के दौरान प्रदर्शित सभी उन्नत ज्ञान का उपयोग करने का अवसर दिया जाता है। हम इन तकनीकों को कर्तव्यपरायणता से नियोजित करते हैं और अक्सर Google, लिंक्डइन, मेटा, अमेज़ॅन, ऐप्पल और नेटफ्लिक्स द्वारा अग्रणी आर्किटेक्चरल पैटर्न के आधार पर बल्कि जटिल सिस्टम बनाते हैं।
इस जटिलता को देखकर कॉर्पोरेट नेतृत्व अक्सर खुश होता है क्योंकि यह दर्शाता है कि कंपनी अब परिपक्व हो गई है, "इंजीनियरिंग बार" उच्च है, और कंपनी के सिस्टम व्यवसाय के साथ बड़े पैमाने पर बढ़ने में सक्षम होंगे, चाहे व्यवसाय कितना भी बढ़ जाए। उम्मीदवारों को दिखाने के लिए इस जटिलता को एक भर्ती उपकरण के रूप में आगे बढ़ाया जाता है कि उन्हें सभी नवीनतम तकनीकों के साथ काम करने को मिलेगा और यह कि उनके भविष्य के सहकर्मी उज्ज्वल हैं और आधुनिक उपकरणों और तकनीकों पर अद्यतित हैं।
उसमें गलत क्या है?
इस दृष्टिकोण के साथ समस्या यह है कि कई कंपनियां कभी भी पर्याप्त रूप से बड़ी नहीं होंगी या इस जटिलता के लाभकारी होने के लिए पर्याप्त पैमाना हासिल नहीं करेंगी। सबसे बड़ी कंपनियों ने पैमाने की गंभीर समस्याओं से निपटने के लिए इन नई तकनीकों और पैटर्न को विकसित किया, जिसका सामना उन्हें अपने उपयोगकर्ता आधार और लेनदेन की मात्रा के रूप में विस्तारित अवधि में तेजी से हुआ। कई मामलों में, कोई अच्छा समाधान मौजूद नहीं था, इसलिए उन्होंने व्यवसाय को हासिल किए गए पैमाने के लिए अपने स्वयं के समाधान बनाए, अक्सर बड़ी प्रारंभिक और चल रही लागत पर। इनमें से कई कंपनियों ने व्यापक प्रौद्योगिकी पारिस्थितिकी तंत्र की भलाई के लिए अपनी कुछ तकनीकों को खुले तौर पर ओपन-सोर्स किया, जिससे वे अन्य कंपनियों के लिए "उपयोग करने के लिए स्वतंत्र" बन गईं।
जब बड़े पैमाने पर संचालन नहीं किया जाता है, तो उपरोक्त कई पैटर्न और प्रौद्योगिकियां खतरनाक होती हैं क्योंकि वे प्रगति को धीमा कर सकते हैं, नाटकीय रूप से लागत में वृद्धि कर सकते हैं और इंजीनियरिंग कर्मचारियों पर संज्ञानात्मक भार बढ़ा सकते हैं। यह छोटी कंपनियों के लिए एक बड़ी समस्या है क्योंकि यह व्यवसाय को उन तरीकों से खराब करता है जो सबसे ज्यादा मायने रखते हैं; चपलता और लाभप्रदता। यह उन व्यवसायों के लिए एक जाल बनाता है जो खुद को आर्थिक मंदी या अचानक अधिक प्रतिस्पर्धी बाजार क्षेत्र में पाते हैं क्योंकि मार्जिन कड़ा हो जाता है। इस बेमेल को और बढ़ा दिया गया है क्योंकि इंजीनियरिंग कर्मचारियों के लिए इनाम प्रणाली अक्सर बेहतर प्रदर्शन करने वाले व्यवसाय से पर्याप्त रूप से जुड़ी नहीं होती है (आने वाले लेख में उस पर अधिक)।
दो उदाहरण
आइए एक सरल प्रणाली से शुरू करें जो समझने में अपेक्षाकृत आसान है और जब हम इसे ओवर-इंजीनियर करते हैं तो इसके न्यूनतम रूप की तुलना क्या हो सकती है। इस चर्चा के लिए, मान लें कि हमारे पास एक सामान्य वेबसाइट है जहां उपयोगकर्ता पंजीकरण कर सकते हैं और चीजें खरीद सकते हैं।
सरल संस्करण
एक साधारण ई-कॉमर्स वेबसाइट के लिए न्यूनतम आर्किटेक्चर को अक्सर मोनोलिथ के रूप में संदर्भित किया जाता है, जिसका अर्थ है कि संपूर्ण कोडबेस एकल स्रोत रिपॉजिटरी में समाहित है और आमतौर पर एक इकाई के रूप में तैनात किया जाता है। कई स्टार्टअप यहां शुरू होते हैं, क्योंकि यह कोडबेस और इंजीनियरिंग टीमों के छोटे होने पर उन्हें जल्दी से आगे बढ़ने की अनुमति देता है। अतिरिक्त लाभ यह है कि आसान स्थानीय विकास के लिए पूरा सिस्टम अक्सर एक लैपटॉप पर फिट हो सकता है।
ऊपर दिए गए आरेख में, हम टूलिंग को सेवाओं के अनुरूप बनाए रखने के लिए एकल क्लाउड प्रदाता (इस मामले में Amazon Web Services या AWS) से कुछ समझदार चूक चुन सकते हैं:
- प्राथमिक विकास भाषा/ढांचा: रूबी+रेल
हम पायथन+Django, Go+Buffalo, या कोई अन्य समझदार भाषा/ढांचा भी चुन सकते हैं - फ्रंटएंड लैंग्वेज/फ्रेमवर्क: जावास्क्रिप्ट/टाइपस्क्रिप्ट + रिएक्ट
लगभग सभी आधुनिक वेब फ्रेमवर्क के लिए कुछ जावास्क्रिप्ट फ्रेमवर्क की आवश्यकता होगी, और रिएक्ट बहुत लोकप्रिय है - बैच/बैकग्राउंड प्रोसेसिंग: रूबी+साइडकीक
पायथन+सेलेरी, गो+फैक्टरी विकल्प होंगे यदि हम एक अलग प्राथमिक भाषा चुनते हैं - स्रोत नियंत्रण: गिट/गिटहब
- सीआई/सीडी: गिटहब क्रियाएं + टेराफॉर्म
- इमेज रिपॉजिटरी: एडब्ल्यूएस ईसीआर
- कंटेनर ऑर्केस्ट्रेशन सिस्टम: एडब्ल्यूएस ईसीएस
- कुंजी: एडब्ल्यूएस केएमएस
- राज: एडब्ल्यूएस रहस्य प्रबंधक
- फायरवॉल/टियर कैश: क्लाउडफ्लेयर
- डीएनएस: क्लाउडफ्लेयर
- लोड बैलेंसर: एडब्ल्यूएस ईएलबी या एएलबी
- फ़ाइल/ऑब्जेक्ट संग्रहण: AWS S3
- कैश + कैश नोड्स: Redis के लिए AWS ElastiCache
- डेटाबेस + प्रतिकृतियां पढ़ें: AWS RDS पर पोस्टग्रेज
- मैसेजिंग: सेंडग्रिड
- भुगतान प्रसंस्करण: पट्टी
- पहचान/एसएसओ: ओक्टा
- लॉग्स एंड ऑब्जर्वेबिलिटी: डेटाडॉग
इस डिज़ाइन में 16 महत्वपूर्ण घटक शामिल हैं जिनमें आउटेज उपयोगकर्ता-सामना, साइट-व्यापी आउटेज या गिरावट का कारण बन सकते हैं। क्योंकि सिस्टम न्यूनतम है, अधिकांश घटक महत्वपूर्ण हैं लेकिन अनावश्यक परिनियोजन डाउनटाइम के कारण विफलताओं के जोखिम को कम करने में मदद करते हैं।
जटिल संस्करण
हम यह तर्क दे सकते हैं कि उपरोक्त सरल संस्करण वास्तव में सरल नहीं है, लेकिन हम अपनी वास्तुकला की ताकत को फ्लेक्स कर सकते हैं और सिस्टम को थोड़ा अधिक प्रभावशाली बना सकते हैं।
आइए (आंशिक रूप से) मोनोलिथ को माइक्रोसर्विसेज में तोड़कर शुरू करें। आइए एक एपीआई गेटवे, कुबेरनेट्स, एक इवेंट बस (काफ्का का उपयोग करके), सर्विस मेश, कई डीएनएस सिस्टम, कई सीआई/सीडी पाइपलाइन, डेटा पाइपलाइन (एक अलग काफ्का क्लस्टर का उपयोग करके), और एक डेटा लेक भी पेश करते हैं। REST API के अलावा, आइए gRPC API (जिसमें प्रोटोकॉल बफ़र शामिल हैं) के लिए समर्थन जोड़ें क्योंकि हम जानते हैं कि यह REST की तुलना में बहुत तेज़ है और हम उच्च प्रदर्शन चाहते हैं। हम एक दूसरा CI/CD सिस्टम (जेनकींस) जोड़ेंगे क्योंकि कुछ कर्मचारी इसे GitHub क्रियाओं के लिए पसंद करते हैं।
आइए डेवलपर्स को अधिक विकल्प देने के लिए एक अतिरिक्त भाषा और फ्रेमवर्क (पायथन/Django/सेलेरी) जोड़ें, और सुनिश्चित करें कि हम समर्थित भाषाओं की अपनी सूची में गो और ग्रूवी को जोड़ना याद रखें क्योंकि हम जेनकिंस (ग्रोवी डीएसएल के साथ) और कुबेरनेट्स का उपयोग कर रहे हैं। इसलिए हमारे द्वारा बनाए जाने वाले कुछ कस्टम संसाधनों को प्रबंधित करने के लिए हमें कुबेरनेट्स (गो) ऑपरेटरों की आवश्यकता हो सकती है। बेहतर प्रदर्शन और डिकॉप्लिंग के लिए, हम अपने बैकएंड मोनोलिथ से अपने फ्रंटएंड यूआई परिनियोजन को पूरी तरह से अलग कर देंगे। लॉगिंग और ऑब्जर्वेबिलिटी (सूमो लॉजिक) के लिए एक और विकल्प भी जोड़ते हैं क्योंकि हमारी पहली पसंद (डेटाडॉग) को हमारे सभी लॉग को शिप करने के लिए बहुत महंगा माना जाता था।
आइए देखें कि कैसे इन वास्तुशिल्प उत्कर्षों ने हमारे सिस्टम को बदल दिया है:
यदि हम मानते हैं कि हमारी पायथन सेवा और डेटा प्लेटफ़ॉर्म मिशन-क्रिटिकल नहीं हैं, तो अब हमारे पास 33 महत्वपूर्ण घटक हैं जिनमें प्रति-घटक आउटेज साइट-व्यापी समस्याएँ पैदा कर सकते हैं। हम उपलब्धता की गणना कैसे करते हैं इसके आधार पर , इससे आउटेज की संभावना बहुत अधिक हो जाती है क्योंकि समग्र सिस्टम केवल उतना ही उपलब्ध हो सकता है जितना कि उसका सबसे कम उपलब्ध आश्रित घटक। हमारे पास अधिक निर्भर घटक हैं, इसलिए समान उपलब्धता को एक सरल प्रणाली के रूप में रखने के लिए बहुत अधिक कठोरता की आवश्यकता होती है। व्यवहार में, जितने अधिक घटक होते हैं, उतने ही कठिन निरंतर उच्च मानकों को लागू करना होता है।
हमने विश्वसनीय स्थानीय लाइब्रेरी कॉल्स को ओवर-द-नेटवर्क API कॉल्स से बदल दिया है। इसका दोहरा प्रभाव पड़ता है:
- नेटवर्क विलंबता जोड़ता है, एक दूरस्थ सेवा के प्रत्येक आह्वान को स्थानीय पुस्तकालय कॉल की तुलना में थोड़ा धीमा कर देता है
- कोई भी नेटवर्क कॉल विफल हो सकती है या दर-सीमित हो सकती है, जिसका अर्थ है कि हमें त्रुटि से निपटने के बारे में अधिक सावधान रहने की आवश्यकता है, अगर हम स्थानीय रूप से उपलब्ध लाइब्रेरी में केवल कॉल कोड कर रहे थे
अब हमारे पास इंटीग्रेशन पैटर्न के लिए 3 विकल्प हैं :
- बाकी एपीआई
- जीआरपीसी
- इवेंट बस
11 शुद्ध नए घटक :
- एपीआई गेटवे (अमेज़ॅन एपीआई गेटवे)
- फ्रंटएंड प्लेटफॉर्म+एज कंप्यूट (वर्सेल)
- आंतरिक डीएनएस (एडब्ल्यूएस रूट53)
- इवेंट बस के लिए काफ्का (AWS MSK)
- डेटा पाइपलाइनों के लिए काफ्का (AWS MSK)
- विभिन्न डेटाबेस और विषयों से पढ़ने/लिखने के लिए एकाधिक काफ्का कनेक्ट स्रोत और सिंक परिनियोजन
- डेटा लेक: हम क्वेरी के लिए Amazon Athena के साथ AWS लेक फॉर्मेशन और डेटा स्टोरेज के लिए S3+Parquet मानेंगे
- एमटीएलएस के लिए इस्तियो सर्विस मेश और एपीआई गेटवे और हमारे पायथन माइक्रोसर्विस के बीच रूटिंग
- एकाधिक कुबेरनेट क्लस्टर (एडब्ल्यूएस ईकेएस)
- प्रवेश लोड बैलेंसर्स (एडब्ल्यूएस एएलबी)
- जेनकींस सीआई/सीडी
लगभग 16 डुप्लिकेट किए गए घटक :
- 3 डेटाबेस + प्रतिकृतियां पढ़ें
- 3 रेडिस क्लस्टर (एक मोनोलिथ प्लस एक प्रति माइक्रोसर्विस के लिए)
- 2 काफ्का क्लस्टर
- 2 डीएनएस सिस्टम
क्लाउडफ्लेयर एक्सटर्नल + रूट53 इंटरनल। इसमें कुबेरनेट्स आंतरिक क्लस्टर डीएनएस शामिल नहीं है - 2 सीआई/सीडी सिस्टम
- 2 लॉगिंग और पर्यवेक्षण समाधान
- 2 कुबेरनेट्स क्लस्टर
लगभग 10-15 गुना परिचालन लागत में वृद्धि
अतिरिक्त कंटेनरों, तैनाती, प्रबंधित सेवाओं और आवश्यक कर्मचारियों की गणना करते हुए, हम परिचालन लागत के काफी अधिक होने की उम्मीद कर सकते हैं। यहां तक कि माइक्रोसर्विसेज और पब्लिक क्लाउड के सबसे उत्साही प्रमोटरों में से एक अमेज़ॅन ने भी कुछ आंतरिक उद्देश्यों के लिए लागत को निषेधात्मक पाया है।
पूर्ण-स्टैक स्थानीय विकास के लिए बहुत बड़ा
परिनियोजन कॉन्फ़िगरेशन के छोटे आकार के साथ भी, डॉकर या मिनीक्यूब में डेवलपर के लैपटॉप पर पूर्ण सिस्टम को चलाने की अनुमति देने के लिए बहुत अधिक चलने वाले हिस्से होने की संभावना है। क्लाउड में विकास को सक्षम करने के तरीके हैं, लेकिन पूरी तरह कार्यात्मक प्रणाली का अनुकरण करने के लिए डेवलपर्स को नकली या सेवाओं के साझा विकास उदाहरणों की आवश्यकता होगी।
हम इन गलतियों से कैसे बचें?
उपरोक्त सरल या जटिल सिस्टम उदाहरणों में तकनीकी रूप से कुछ भी गलत नहीं है। वे दोनों समान कार्यक्षमता प्रदान करते हैं, और जटिल प्रणाली, जबकि इसे बनाने और संचालित करने के लिए बहुत अधिक लागत आती है, कुछ कंपनियों के लिए एक निश्चित आकार और पैमाने पर एक अच्छा फिट हो सकता है। उस ने कहा, ज्यादातर कंपनियों के लिए जटिल उदाहरण शायद सबसे अच्छा शुरुआती बिंदु नहीं है। समयपूर्व अनुकूलन से बचने के लिए, निम्नलिखित दृष्टिकोण सहायक होते हैं:
ऐसी संस्कृति विकसित करें जो सादगी को पुरस्कृत करे
उम्मीदवारों का साक्षात्कार करते समय, उन्हें अपने ज्ञान की व्यापकता और गहराई से आपको प्रभावित करने और वेब स्केल पर सिस्टम डिजाइन करने के लिए प्रोत्साहित करने के बजाय, वास्तु सरलीकरण पर विचार करें, जो कि आप उनका मूल्यांकन करने के लिए उपयोग किए जाने वाले प्रमुख मानदंडों में से एक हैं। ऐसे प्रश्न पूछें, "क्या आप इस प्रणाली को सरल या अधिक विश्वसनीय बनाने के तरीकों के बारे में सोच सकते हैं?" यदि वे अपने डिजाइन में उन चीजों की पहचान कर सकते हैं जिनकी उन्हें आवश्यकता नहीं है, तो उन्हें इसके लिए पुरस्कृत करें। यदि वे अनावश्यक घटकों को पहली जगह में नहीं जोड़ते हैं, तो और भी बेहतर।
एक व्यक्तिगत योगदानकर्ता को काम पर रखने के बाद, विशेष रूप से अधिक वरिष्ठ स्तरों पर, वास्तुशिल्प सरलीकरण को उनके प्रदर्शन मूल्यांकन का एक हिस्सा बनाएं। उन कर्मचारियों को पुरस्कृत करें जो जटिल और भंगुर प्रणालियों को लेते हैं और उन्हें सरल और अधिक मजबूत बनाते हैं। कार्यकुशलता और सरलीकरण की तलाश में तकनीकी कर्मचारी होने से यह सुनिश्चित होगा कि सिस्टम उतने ही फुर्तीले और विश्वसनीय हैं जितने तब हो सकते हैं जब आपको जल्दी से आगे बढ़ने की आवश्यकता हो।
समकालिक परिवर्तनों की संख्या न्यूनतम करें
जब कोई कंपनी एक कठिन अभ्यास शुरू करती है जैसे बंधे हुए संदर्भों को एक मोनोलिथ से बाहर ले जाना, प्रलोभन एक एकल "बिग बैंग" ऑपरेशन में निकालने, अनुवाद करने और रिफैक्टर करने का होता है। यदि टीमों को लगता है कि वे एक अलग भाषा में या विभिन्न टूलिंग (जो वे सीखना भी चाहते हैं) का उपयोग करते हुए एक चिंता को लागू करना चाहते हैं, तो इस अनुवाद अभ्यास को निष्कर्षण प्रयास के एक वैध और आवश्यक भाग के रूप में बेचना आम है।
यह मानते हुए कि मौजूदा भाषा और ढांचा अभी भी कार्यभार के लिए पर्याप्त है, आमतौर पर पहले किसी बाहरी सेवा के लिए कोड को निकालना बेहतर होता है और निष्कर्षण पूरा होने के बाद, अगर कुछ अभी भी कमी है तो रिफैक्टरिंग, पोर्टिंग, या अन्यथा सेवा के पुनर्गठन पर विचार करें। मैंने कई प्रवासन प्रयासों को एक साथ बहुत सारे काम करने के लिए संघर्ष करते देखा है और समग्र प्रयास की सफलता को जोखिम में डालते हैं या बहुत, बहुत धीमी गति से प्रगति करते हैं। यदि मौजूदा कोड रूबी में लिखा गया है, तो आमतौर पर उस सेवा को तब तक स्थिर रखना सबसे अच्छा होता है जब तक कि सेवा वास्तव में एक अलग चिंता का विषय न हो। आप अन्य इंजीनियरों से अधिक सहायता प्राप्त कर सकते हैं यदि आप जितना संभव हो उतना कम बदल रहे हैं और वे अभी भी आपके द्वारा चलाए जा रहे कोड को समझ सकते हैं।
मानकों और आम सहमति को प्रोत्साहित करें
मैंने निर्देशकों, इंजीनियरों और वास्तुकारों के बीच लड़ाई देखी है, जो सभी पक्षों द्वारा अपने तरीके से करने का निर्णय लेने और नए उपकरणों और तकनीकों के साथ ग्रीनफ़ील्ड विकास के पक्ष में सम्मेलनों और मानकों से बचने के द्वारा हल की जाती हैं। जबकि यह निडर इंजीनियर के लिए सशक्त हो सकता है, यह आमतौर पर पहले से आरक्षित समाधानों में समाप्त होता है जो पारिस्थितिकी तंत्र के अन्य भागों के साथ अच्छी तरह से काम नहीं करते हैं और परिचालन लागत में वृद्धि करते हैं क्योंकि वे सभी गलत तरीकों से "असाधारण" हैं।
अलग करने के बजाय, आम सहमति को प्रोत्साहित करें जिसके परिणामस्वरूप किसी चिंता को दूर करने का एक ही तरीका है जिसे व्यापक रूप से अपनाया जा सकता है। अपने या अपनी तत्काल टीम के लिए उपकरण विकसित करने के बजाय, आप जो कुछ भी बनाते हैं, उसके बारे में सोचें, जिसे आप अपने पूरे इंजीनियरिंग संगठन के साथ साझा करेंगे। यदि समस्या कई इंजीनियरों के लिए आम है लेकिन आपको नहीं लगता कि आपका समाधान अपनाया जाएगा, तो कुछ ऐसा बढ़ाने पर विचार करें जो पहले से ही व्यापक रूप से उपयोग किया जा रहा है या अन्य इंजीनियरों के साथ चिंता पर चर्चा करें जब तक कि आप समझौते और खरीद-इन प्राप्त नहीं कर लेते हैं कि आपका दृष्टिकोण व्यापक रूप से हो सकता है उपयोग किया जाता है और वे आपको पूरे संगठन में गोद लेने को प्रोत्साहित करने में मदद करेंगे।
गलत काम करने से ज्यादा कुछ न करने को तरजीह दें
कई संगठन वेग से जुनूनी हो जाते हैं, और स्क्रम जैसे "प्रवाह को अधिकतम करने" और टीमों के थ्रूपुट के लिए चुस्त पद्धतियों का उपयोग करते हैं। कई मामलों में, एक व्यवसाय को ठीक से पता नहीं होता है कि उसे क्या करने की आवश्यकता है, इसलिए वह केवल यह सुनिश्चित करने की कोशिश करता है कि इंजीनियरों को व्यस्त रखा जाए ताकि वे तेजी से निष्पादन के निरंतर मोड में रहें।
इस दृष्टिकोण के साथ समस्या यह है कि अक्सर ऐसी चीजें बन जाती हैं जिनकी आवश्यकता नहीं होती है, लेकिन उन्हें फेंकने के बजाय उन्हें एक चलती हुई चिंता के रूप में माना जाता है जिसके लिए समर्थन और निरंतर निवेश की आवश्यकता होती है। इसका कारण यह है कि ज्यादातर इंजीनियर अपने काम पर गर्व करते हैं और "थ्रोअवे" सॉफ्टवेयर पर काम नहीं करना चाहते हैं।
ऐसे समय में जहां यह स्पष्ट नहीं है कि क्या करने की आवश्यकता है, इस समय का उपयोग इंजीनियरों को प्रयोग करने, कौशल अपडेट करने, या उत्पाद प्रबंधकों और अन्य नेतृत्व के साथ सहयोग करने की अनुमति देने के लिए करें ताकि यह निर्धारित किया जा सके कि आगे क्या किया जाना चाहिए। यह "क्रूफ्ट" के निर्माण को रोकेगा और स्वामित्व में वृद्धि करेगा जब यह तेजी से निष्पादित करने का समय होगा जब आप यह पता लगा लेंगे कि क्या बनाना है।
अनुकूलन को तब तक के लिए टालें जब तक कि इसकी आवश्यकता न हो
व्यवसाय को प्रभावित करने से पहले सक्रिय होना और प्रदर्शन और उपलब्धता की समस्याओं को हल करना हमेशा बेहतर होता है। यह आक्रामक रूप से "भविष्य के सबूत" समाधानों को आवश्यकता से पहले बड़े पैमाने पर स्केल-आउट का समर्थन करने के लिए आकर्षक हो सकता है, लेकिन यह आमतौर पर एक गलती है ।
इसके बजाय, SLI की परिभाषा, निगरानी और क्षमता योजना को सेवा स्वामित्व का हिस्सा बनाएं । जब एक टीम यह सुनिश्चित करने के लिए जिम्मेदार होती है कि सेवा स्तर के संकेतक अच्छी तरह से परिभाषित हैं और लक्ष्य उद्देश्यों को पूरा करते हैं, तो अनुकूलन अनुबंध का हिस्सा है। यदि किसी नए उत्पाद लॉन्च या साझेदारी के आधार पर किसी सेवा के उपयोग के पैटर्न में काफी बदलाव आएगा, तो सेवा मालिकों से परामर्श किया जाना चाहिए और उनकी योजना में इसे शामिल करने की अनुमति दी जानी चाहिए और यह सुनिश्चित करना चाहिए कि वे बढ़े हुए ट्रैफ़िक के साथ संकेतकों को उचित श्रेणी में रख सकें। यदि कोई टीम बहुत अधिक ट्रैफ़िक लेते हुए SLO को सुसंगत रखती है, तो उन्हें (वित्तीय रूप से) पुरस्कृत करें क्योंकि अधिक मात्रा का अर्थ अधिक राजस्व होना चाहिए।
सुनिश्चित करें कि इंजीनियरिंग की सफलता और कंपनी की सफलता का गहरा संबंध है
बहुत बार, इंजीनियरों को तकनीकी रूप से प्रभावशाली समाधान बनाने के लिए पुरस्कृत किया जाता है, और यह "बार उठाना" है कि वे संगठन के भीतर आगे बढ़ने को कैसे उचित ठहरा सकते हैं। इसे अक्सर "रिज्यूमे बिल्डिंग" के रूप में संदर्भित किया जाता है, जहां इंजीनियर भविष्य के नियोक्ताओं को प्रभावशाली सिस्टम दिखा सकते हैं, जिस पर उन्होंने काम किया है ताकि वे बाहर निकल सकें और आगे बढ़ सकें। यह दुर्भाग्यपूर्ण है क्योंकि आपका विषय वस्तु विशेषज्ञ उनके द्वारा बनाई गई किसी ऐसी चीज के गुणों का गुणगान करते हुए भवन छोड़ देता है जिसकी आपको आवश्यकता नहीं हो सकती है। अब आपको इस निर्माण को अतिरिक्त स्टाफिंग के साथ समर्थन करने या आंतरिक ज्ञान की कमी के कारण इसे डीकमीशन करने का निर्णय लेना चाहिए।
इसके बजाय, यह सुनिश्चित करके इंजीनियरों को तकनीकी रूप से प्रभावशाली समाधानों के आगे व्यवसाय की जरूरतों को पूरा करने के लिए प्रोत्साहित करें कि जब कंपनी बेहतर करती है तो वे हमेशा बेहतर करते हैं। मैं इस विषय पर एक और लेख समर्पित करूंगा, लेकिन टीएल; डीआर यह सुनिश्चित करता है कि आप (वित्तीय रूप से) उस इंजीनियरिंग व्यवहार को पुरस्कृत कर रहे हैं जिसकी आपको वास्तव में व्यवसाय को बढ़ाने और सुधारने के लिए आवश्यकता है।