कुबेरनेट्स - एपीआई
कुबेरनेट्स एपीआई सिस्टम के लिए घोषणात्मक कॉन्फ़िगरेशन स्कीमा की नींव के रूप में कार्य करता है। KubectlAPI ऑब्जेक्ट बनाने, अपडेट करने, हटाने और प्राप्त करने के लिए कमांड-लाइन टूल का उपयोग किया जा सकता है। कुबेरनेट्स एपीआई कुबेरनेट्स के विभिन्न घटकों के बीच एक संचारक का कार्य करता है।
कुबेरनेट्स में एपीआई जोड़ना
Kubernetes में एक नया API जोड़ने से Kubernetes में नई सुविधाएँ जोड़ी जाएंगी, जिससे Kubernetes की कार्यक्षमता बढ़ जाएगी। हालांकि, इसके साथ ही यह प्रणाली की लागत और स्थिरता को भी बढ़ाएगा। लागत और जटिलता के बीच संतुलन बनाने के लिए, इसके लिए कुछ सेट निर्धारित हैं।
जो API जोड़ा जा रहा है वह 50% से अधिक उपयोगकर्ताओं के लिए उपयोगी होना चाहिए। कुबेरनेट्स में कार्यक्षमता को लागू करने का कोई अन्य तरीका नहीं है। कुबेरनेट्स की सामुदायिक बैठक में असाधारण परिस्थितियों पर चर्चा की जाती है, और फिर एपीआई को जोड़ा जाता है।
एपीआई परिवर्तन
कुबेरनेट्स की क्षमता बढ़ाने के लिए, सिस्टम में लगातार परिवर्तन किए जाते हैं। यह कुबेरनेट्स टीम द्वारा सिस्टम की मौजूदा कार्यक्षमता को हटाने या प्रभावित किए बिना कुबेरनेट्स में कार्यक्षमता जोड़ने के लिए किया जाता है।
सामान्य प्रक्रिया को प्रदर्शित करने के लिए, यहाँ एक (काल्पनिक) उदाहरण है -
एक उपयोगकर्ता एक पॉड वस्तु को पोस्ट करता है /api/v7beta1/...
JSON एक में अनारक्षित है v7beta1.Pod संरचना
डिफ़ॉल्ट मानों पर लागू होते हैं v7beta1.Pod
v7beta1.Pod में परिवर्तित हो जाता है api.Pod संरचना
api.Pod मान्य किया गया है, और उपयोगकर्ता को कोई भी त्रुटि दी गई है
api.Pod v6 में कनवर्ट किया जाता है। पोड (क्योंकि v6 नवीनतम स्थिर संस्करण है)
v6.Pod JSON में marshalled है और को लिखा गया है etcd
अब जब हमारे पास पॉड ऑब्जेक्ट संग्रहीत है, तो उपयोगकर्ता किसी भी समर्थित एपीआई संस्करण में उस ऑब्जेक्ट को प्राप्त कर सकता है। उदाहरण के लिए -
एक उपयोगकर्ता फली से प्राप्त करता है /api/v5/...
JSON से पढ़ा जाता है etcd तथा unmarshalled में v6.Pod संरचना
डिफ़ॉल्ट मानों पर लागू होते हैं v6.Pod
v6.Pod को api.Pod संरचना में बदल दिया जाता है
api.Pod में परिवर्तित हो जाता है v5.Pod संरचना
v5.Pod JSON में marshalled है और उपयोगकर्ता को भेजा जाता है
इस प्रक्रिया का निहितार्थ यह है कि एपीआई परिवर्तन सावधानीपूर्वक और पीछे की ओर से किया जाना चाहिए।
एपीआई संस्करण
कई संरचनाओं का समर्थन करना आसान बनाने के लिए, कुबेरनेट्स विभिन्न एपीआई पथ जैसे प्रत्येक एपीआई के कई संस्करणों का समर्थन करता है /api/v1 या /apsi/extensions/v1beta1
कुबेरनेट्स में संस्करण मानकों को कई मानकों में परिभाषित किया गया है।
अल्फा स्तर
इस संस्करण में अल्फा शामिल है (उदाहरण के लिए v1alpha1)
यह संस्करण छोटी गाड़ी हो सकती है; सक्षम संस्करण में बग हो सकते हैं
बग के लिए समर्थन किसी भी समय गिराया जा सकता है।
केवल अल्पकालिक परीक्षण में उपयोग किए जाने की सिफारिश की जाती है क्योंकि हर समय समर्थन मौजूद नहीं हो सकता है।
बीटा स्तर
संस्करण नाम में बीटा शामिल है (उदाहरण v2beta3)
कोड का पूरी तरह से परीक्षण किया गया है और सक्षम संस्करण को स्थिर माना जाता है।
सुविधा का समर्थन गिराया नहीं जाएगा; कुछ छोटे बदलाव हो सकते हैं।
केवल गैर-व्यावसायिक-महत्वपूर्ण उपयोगों के लिए अनुशंसित क्योंकि बाद के रिलीज में असंगत परिवर्तन की क्षमता है।
स्थिर स्तर
संस्करण का नाम है vX कहाँ पे X एक पूर्णांक है।
सुविधाओं के स्थिर संस्करण बाद के कई संस्करणों के लिए जारी किए गए सॉफ़्टवेयर में दिखाई देंगे।