कुबेरनेट्स - नौकरियां
नौकरी का मुख्य कार्य एक या एक से अधिक फली बनाना और फली की सफलता के बारे में पता लगाना है। वे सुनिश्चित करते हैं कि फली की निर्दिष्ट संख्या सफलतापूर्वक पूरी हो गई है। जब पॉड्स के सफल रन की एक निर्दिष्ट संख्या पूरी हो जाती है, तो नौकरी को पूरा माना जाता है।
नौकरी पैदा करना
नौकरी बनाने के लिए निम्नलिखित कमांड का उपयोग करें -
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 कमांड चलाएगा और एक कंटेनर के अंदर सभी चल रही प्रक्रिया को सूचीबद्ध करेगा।
यह अनुसूचित नौकरी की अवधारणा तब उपयोगी होती है जब हम निर्धारित समय पर कार्यों का एक सेट बनाने और चलाने की कोशिश कर रहे होते हैं और फिर प्रक्रिया को पूरा करते हैं।