कुबेरनेट्स - नौकरियां

नौकरी का मुख्य कार्य एक या एक से अधिक फली बनाना और फली की सफलता के बारे में पता लगाना है। वे सुनिश्चित करते हैं कि फली की निर्दिष्ट संख्या सफलतापूर्वक पूरी हो गई है। जब पॉड्स के सफल रन की एक निर्दिष्ट संख्या पूरी हो जाती है, तो नौकरी को पूरा माना जाता है।

नौकरी पैदा करना

नौकरी बनाने के लिए निम्नलिखित कमांड का उपयोग करें -

apiVersion: v1
kind: Job ------------------------> 1
metadata:
   name: py
   spec:
   template:
      metadata
      name: py -------> 2
      spec:
         containers:
            - name: py ------------------------> 3
            image: python----------> 4
            command: ["python", "SUCCESS"]
            restartPocliy: Never --------> 5

उपरोक्त कोड में, हमने परिभाषित किया है -

  • kind: Job → हमने अय्यूब के रूप में उस प्रकार को परिभाषित किया है जो बताएगा kubectl कि yaml फ़ाइल का उपयोग एक कार्य प्रकार पॉड बनाने के लिए किया जाता है।

  • Name:py → यह उस टेम्पलेट का नाम है जिसका हम उपयोग कर रहे हैं और कल्पना टेम्पलेट को परिभाषित करती है।

  • name: py → हमने एक नाम दिया है py कंटेनर स्पेक के तहत जो पॉड की पहचान करने में मदद करता है जो इससे बाहर निकलने वाला है।

  • Image: python → वह छवि जिसे हम कंटेनर बनाने के लिए खींचने जा रहे हैं जो फली के अंदर चलेगा।

  • restartPolicy: Never →छवि को पुनरारंभ करने की यह शर्त कभी नहीं दी जाती है, जिसका अर्थ है कि यदि कंटेनर को मार दिया गया है या यदि वह गलत है, तो वह स्वयं को पुनरारंभ नहीं करेगा।

हम yaml के साथ निम्नलिखित कमांड का उपयोग करके कार्य बनाएंगे जिसे नाम के साथ सहेजा गया है py.yaml

$ kubectl create –f py.yaml

उपरोक्त कमांड एक नौकरी पैदा करेगा। यदि आप नौकरी की स्थिति की जांच करना चाहते हैं, तो निम्न कमांड का उपयोग करें।

$ kubectl describe jobs/py

उपरोक्त कमांड एक नौकरी पैदा करेगा। यदि आप नौकरी की स्थिति की जांच करना चाहते हैं, तो निम्न कमांड का उपयोग करें।

अनुसूचित नौकरी

कुबेरनेट्स में अनुसूचित नौकरी का उपयोग करता है Cronetes, जो कुबेरनेट्स नौकरी लेता है और उन्हें कुबेरनेट क्लस्टर में लॉन्च करता है।

  • एक समयबद्धन एक निर्दिष्ट समय पर एक पॉड चलाएगा।
  • इसके लिए एक पैरोडिक जॉब बनाई जाती है जो अपने आप ही इनवॉइस करती है।

Note - अनुसूचित नौकरी की सुविधा संस्करण 1.4 द्वारा समर्थित है और बीट / v2alpha 1 एपीआई 1 पास करके चालू है –runtime-config=batch/v2alpha1 API सर्वर लाते समय।

हम उसी yaml का उपयोग करेंगे जिसका उपयोग हम नौकरी बनाने के लिए करते हैं और इसे एक निर्धारित कार्य बनाते हैं।

apiVersion: v1
kind: Job
metadata:
   name: py
spec:
   schedule: h/30 * * * * ? -------------------> 1
   template:
      metadata
         name: py
      spec:
         containers:
         - name: py
         image: python
         args:
/bin/sh -------> 2
-c
ps –eaf ------------> 3
restartPocliy: OnFailure

उपरोक्त कोड में, हमने परिभाषित किया है -

  • schedule: h/30 * * * * ? → नौकरी को हर 30 मिनट में चलाने के लिए शेड्यूल करें।

  • /bin/sh: यह कंटेनर में / बिन / श के साथ प्रवेश करेगा

  • ps –eaf → मशीन पर ps -eaf कमांड चलाएगा और एक कंटेनर के अंदर सभी चल रही प्रक्रिया को सूचीबद्ध करेगा।

यह अनुसूचित नौकरी की अवधारणा तब उपयोगी होती है जब हम निर्धारित समय पर कार्यों का एक सेट बनाने और चलाने की कोशिश कर रहे होते हैं और फिर प्रक्रिया को पूरा करते हैं।