जब मैंने अपना करियर शुरू किया था, तब मुझे बज़वर्ड्स की उम्मीद नहीं थी। उन दिनों, अधिकांश तकनीकी समाचार सूचना-वीक और नेटवर्क वर्ल्ड जैसे पेपर-आधारित साप्ताहिक प्रकाशनों में आते थे। मुझे याद है कि मैं खुद को सोच रहा था, "यार, वे हर हफ्ते इन्हीं शब्दों का बार-बार इस्तेमाल कर रहे हैं।"
यह उन लोगों के लिए अनुवादित होता है जो buzzwords का उपयोग करते हैं ... हर समय। उस समय, मेरे दो पसंदीदा buzzwords इंटरनेट को "वर्ल्ड वाइड वेब" और "सूचना सुपरहाइववे" के रूप में संदर्भित करते थे। मैं हमेशा सोचता था कि क्या कभी सुपर-डुपर-हाईवे होगा।
हालाँकि, हाल ही में, मैंने देखा कि buzzwords का उपयोग प्लेसहोल्डर के रूप में किया जाता है, जहाँ उनका कोई मतलब नहीं होता है। माइक्रोसर्विसेज, इवेंट-संचालित आर्किटेक्चर, एआई और एमएल जैसे शब्दों का उपयोग संदर्भों में किया जाता है, जो मुझे यह निष्कर्ष निकालने के लिए प्रेरित करता है कि बहुत से लोग इन शर्तों को पूरी तरह से नहीं समझते हैं। मुझे भी इसकी उम्मीद नहीं थी...
एक गलत समझे गए प्रश्न से संबंधित इस साधारण बातचीत की कल्पना करें:
व्यक्ति # 1: आपकी उड़ान कितने बजे रवाना होती है?
व्यक्ति # 2: इस साल के अंत में।
जबकि व्यक्ति # 2 एक उत्तर प्रदान करता है जो गलत नहीं है, उत्तर वास्तव में व्यक्ति # 1 की पूछताछ के लिए कोई मूल्य नहीं देता है।
उसी तर्ज पर, माइक्रोसर्विसेज में माइग्रेट करने की खोज ने समान चुनौतियों का सामना किया है। अधिक बार नहीं, मैंने उन ग्राहकों और निगमों के साथ काम किया है जिनके "माइक्रोसर्विस" डिज़ाइन के परिणामस्वरूप एकल मोनोसर्विस हुआ। असल में, एक मोनोलिथिक एप्लिकेशन को वास्तव में एक बड़े रीस्टफुल एपीआई के साथ बदल दिया गया था।
इस प्रकाशन के लिए, मैंने सोचा कि उद्देश्य-संचालित माइक्रोसर्विस डिज़ाइन बनाने के उदाहरण के माध्यम से चलना मज़ेदार होगा ... सही तरीका।
एक उद्देश्य-संचालित माइक्रोसर्विस एक ऐसी सेवा है जो अपने दम पर खड़ी हो सकती है, और इसमें आवश्यकता पड़ने पर एक समर्पित दृढ़ता स्टोर शामिल हो सकता है। उद्देश्य-चालित होने के कारण, माइक्रोसर्विस सूचना का एक केंद्रित सेट प्रदान करेगा और संबंधित एपीआई के भीतर शासित डेटा के लिए रिकॉर्ड की प्रणाली होगी।
उद्देश्य-संचालित माइक्रोसर्विस दृष्टिकोण को अपनाकर, उपयोगकर्ता उस समय के लिए एपीआई की जरूरतों को पूरा करने के लिए अतिरिक्त नोड्स जोड़ सकते हैं और मौजूदा नोड्स को छोटा कर सकते हैं।
एक उदाहरण के रूप में, आयकर के एक पहलू पर केंद्रित एक उद्देश्य-संचालित माइक्रोसर्विस वर्ष के पहले भाग के दौरान सबसे अधिक उपयोग देख सकता है और दूसरी छमाही में चलने वाले कम उदाहरणों की आवश्यकता होती है।
आइए एक बहुत ही सरल उदाहरण का उपयोग करके एक उद्देश्य-संचालित माइक्रोसर्विस डिज़ाइन के निर्माण पर ध्यान दें।
अफवाह यह है कि किंग राजवंश शाही परिवार बेटों के लिंग चयन के लिए इसी ग्रिड पर निर्भर था, जिन्हें काम और धन के लिए उनके परिवार के साथ-साथ परिवार के वंश को आगे बढ़ाने के लिए प्रदान किया जा सकता था।
नीचे चीनी जेंडर प्रेडिक्टर ग्रिड का एक उदाहरण दिया गया है:
उदाहरण के तौर पर, एक 18 वर्षीय मां जिसने जनवरी में एक बच्चे को जन्म दिया, वह एक मादा बच्चा पैदा करेगी।
इस प्रकाशन के लिए, हम एक उद्देश्य-संचालित माइक्रोसर्विस बनाएंगे जो समान मानदंड के आधार पर एक लिंग पूर्वानुमान देता है। ऊपर दिए गए उदाहरण के लिए परिणामी पेलोड नीचे दिखाए अनुसार दिखाई देगा:
{ "month": 1, "age": 18, "gender": "female", "errorMessage": null }
माइक्रोसर्विस जावा और स्प्रिंग बूट का उपयोग करेगा और सेवा को संकलित करने और एक डॉकर छवि बनाने के लिए एक बहु-चरण डॉकरफाइल को नियोजित करेगा जो जन्म-भविष्यवक्ता एपीआई की मेजबानी कर सकता है।
सेवा के लिए कोड GitLab पर निम्न पते पर पाया जा सकता है:
मैंने निम्नलिखित प्रकाशनों में __ Render __platform के बारे में लिखा है:
रेंडर पर चलने वाले मेरे व्यक्तिगत उदाहरणों के लिए, मैंने गो प्रोग्रामिंग भाषा, स्थिर साइट्स और पोस्टग्रेस इंस्टेंस का उपयोग किया है। इस बार, मैंने जावा/स्प्रिंग बूट में सेवा लिखी। जबकि जावा के लिए मूल समर्थन अभी तक मौजूद नहीं है, रेंडर प्लेटफॉर्म में डॉकर कंटेनर में चलने वाली किसी भी चीज़ के लिए समर्थन शामिल है।
चूंकि जन्म-पूर्वसूचक सेवा में एक बहु-चरण Dockerfile शामिल है, इसलिए मैं यह देखना चाहता था कि रेंडर प्लेटफॉर्म पर Docker- आधारित सेवा को तैनात करना कितना आसान है। हालाँकि, मैंने देखा
एक ब्लूप्रिंट कोड (IaC) के रूप में इन्फ्रास्ट्रक्चर का रेंडर का कार्यान्वयन है। IaC भी कुछ ऐसा है जिसे मैं "* कोड के रूप में" नामक एक बड़ी अवधारणा में समूहित करता हूं। जिन संगठनों को कई सेवाओं की तैनाती का प्रबंधन करने की आवश्यकता होती है या जिनके पास बहुत सारे विकल्पों की आवश्यकता वाली सेवाएं होती हैं, वे अपने रेंडर इंफ्रास्ट्रक्चर (सेवाएं, डेटाबेस और पर्यावरण समूह) को एक render.yaml फ़ाइल में कोड के रूप में परिभाषित कर सकते हैं।
ब्लूप्रिंट उदाहरण पर निर्माण प्रदान किया गया
services: - type: web name: restful-api-spring-boot env: docker region: ohio # optional (defaults to oregon) plan: free # optional (defaults to starter) branch: master # optional (uses repo default) numInstances: 1 # optional (defaults to 1) healthCheckPath: /actuator/health envVars: - key: SERVER_PORT value: 443
वहां से, मैंने नाम संपत्ति को अपडेट करने और रेपो संपत्ति जोड़ने के लिए जन्म-भविष्यवक्ता सेवा के लिए वाईएएमएल डेटा को अनुकूलित किया, जैसा कि नीचे बताया गया है:
services: - type: web name: birth-predictor env: docker repo: https://gitlab.com/johnjvester/birth-predictor region: ohio # optional (defaults to oregon) plan: free # optional (defaults to starter) branch: master # optional (uses repo default) numInstances: 1 # optional (defaults to 1) healthCheckPath: /actuator/health envVars: - key: SERVER_PORT value: 443
यह जानकारी birth-predictor
भंडार की जड़ में, render.yaml
नामक फ़ाइल में संग्रहीत की गई थी। इस परिवर्तन को करने और मर्ज करने के बाद, सेवा रेंडर प्लेटफॉर्म पर परिनियोजन के लिए तैयार थी।
रेंडर डैशबोर्ड से, मैंने नया चुना | खाका विकल्प:
इसके बाद, मैंने जन्म-भविष्यवक्ता भंडार का चयन किया, जिसे मैंने अपने GitLab खाते से जुड़े निर्देशों का उपयोग करके जोड़ा
चूंकि मैं एक ब्लूप्रिंट का उपयोग कर रहा था, मुझे बस अपनी नई सेवा के लिए एक सेवा समूह का नाम प्रदान करना था:
लागू करें बटन दबाने के बाद, परिनियोजन प्रक्रिया शुरू हुई:
कुछ मिनट बाद, सेवा को बिना किसी समस्या के तैनात किया गया:
जन्म-भविष्यवाणी सेवा चलने के साथ, मैं एक नई भविष्यवाणी प्राप्त करने के लिए निम्नलिखित कर्ल कमांड जारी कर सकता हूं:
curl --location --request POST 'https://birth-predictor.onrender.com/predict' \ --header 'Content-Type: application/json' \ --data-raw '{ "conceptionMonth" : 11, "conceptionAge" : 43 }'
परिणामी प्रतिक्रिया पेलोड इस तरह दिखता है:
{ "month": 11, "age": 43, "gender": "male", "errorMessage": null }
यह जानकारी सिर्फ गर्भधारण के महीने और मेरी पत्नी की उम्र से मेल खाती है जब हमारे बेटे (फिनी) की कल्पना की गई थी। अगस्त 2017 में, वह आया!
ठीक वैसे ही जैसे उन्होंने किंग राजवंश के दौरान किया था, हम अपने बच्चे के लिंग का सफलतापूर्वक पूर्वानुमान लगाने के लिए चीनी लिंग भविष्यवक्ता पर भरोसा करने में सक्षम थे।
2021 से, मैं निम्नलिखित मिशन वक्तव्य के अनुसार जीने की कोशिश कर रहा हूं, जो मुझे लगता है कि किसी भी आईटी पेशेवर पर लागू हो सकता है:
“अपना समय उन सुविधाओं/कार्यक्षमताओं को प्रदान करने पर केंद्रित करें जो आपकी बौद्धिक संपदा के मूल्य को बढ़ाती हैं। अन्य सभी चीजों के लिए ढांचे, उत्पादों और सेवाओं का लाभ उठाएं।"
- जे वेस्टर
रेंडर द्वारा ब्लूप्रिंट विनिर्देश फीचर और सर्विस टीमों को देवओप्स से संबंधित किसी भी चीज की चिंता किए बिना, स्थापित लक्ष्यों और लक्ष्यों के खिलाफ वितरण पर ध्यान केंद्रित करने की अनुमति देकर मेरे मिशन स्टेटमेंट का पालन करता है।
एक बार सेवा, घटक, या एप्लिकेशन तैयार हो जाने के बाद, टीमों को केवल अपने रिपॉजिटरी की जड़ में render.yaml फ़ाइल को शामिल करने की आवश्यकता होती है, फिर ब्लूप्रिंट विकल्प का उपयोग करके रेंडर प्लेटफॉर्म पर एक नई सेवा बनाएं। आगे बढ़ते हुए, कनेक्टेड रिपोजिटरी के लिए कोई भी अपडेट विख्यात शाखा को कोड देने के कुछ मिनट बाद ऑटो-डिप्लॉय करेगा।
रेंडर प्लेटफॉर्म एक जीरो देवओप्स मानसिकता से जीता है, जो ब्लूप्रिंट अवधारणा की उत्पत्ति में स्पष्ट है। फ़ीचर और सेवा डेवलपर अपने हितधारकों को सबसे अधिक मूल्य प्रदान करने वाले अपडेट और कार्यक्षमता प्रदान करने पर ध्यान केंद्रित करना चाहते हैं और करना चाहिए। रेंडर वास्तव में इस वास्तविकता को समझता है।
मुझे विश्वास है कि buzzwords हमेशा प्रौद्योगिकी क्षेत्र का हिस्सा रहेगा। हालाँकि, उन buzzwords के पीछे के सच्चे इरादे को समझना और अपनाना कुछ ऐसा है जो मुझे उम्मीद है कि प्रौद्योगिकीविद् इसका पीछा करेंगे।
यदि आप इस प्रकाशन के स्रोत कोड में रुचि रखते हैं, तो आप इसे निम्नलिखित पते पर GitLab पर पा सकते हैं:
आपका दिन वाकई बहुत अच्छा हो!