1. खास जानकारी
इस लैब में, Cloud Build की मदद से GKE के लिए कंटीन्यूअस डिलीवरी पाइपलाइन सेट अप करने का तरीका बताया गया है. इस लैब में, अलग-अलग Git इवेंट के लिए Cloud Build जॉब को ट्रिगर करने का तरीका बताया गया है. साथ ही, GKE में अपने-आप कैनरी रिलीज़ करने का आसान तरीका भी बताया गया है.
आपको यह तरीका अपनाना होगा:
- GKE ऐप्लिकेशन बनाना
- Git ब्रांच के लिए डिप्लॉयमेंट को ऑटोमेट करना
- git की मुख्य शाखा के लिए डिप्लॉयमेंट को ऑटोमेट करना
- git टैग के लिए डिप्लॉयमेंट को ऑटोमेट करना
2. शुरू करने से पहले
इस रेफ़रंस गाइड के लिए, आपके पास Google Cloud प्रोजेक्ट होना चाहिए. आपके पास नया प्रोजेक्ट बनाने या पहले से बनाए गए किसी प्रोजेक्ट को चुनने का विकल्प होता है:
- कोई Google Cloud प्रोजेक्ट चुनें या बनाएं.
प्रोजेक्ट चुनने वाले पेज पर जाएं
- अपने प्रोजेक्ट के लिए बिलिंग चालू करें.
3. आपका एनवायरमेंट तैयार किया जा रहा है
- इस पूरे ट्यूटोरियल में इस्तेमाल करने के लिए, एनवायरमेंट वैरिएबल बनाएं:
export PROJECT_ID=$(gcloud config get-value project) export PROJECT_NUMBER=$(gcloud projects describe $PROJECT_ID --format='value(projectNumber)') export ZONE=us-central1-b export CLUSTER=gke-progression-cluster export APP_NAME=myapp - इन एपीआई को चालू करें:
- रिसोर्स मैनेजर
- GKE (जीकेई)
- Cloud Source Repositories
- Cloud Build
- कंटेनर रजिस्ट्री
gcloud services enable \ cloudresourcemanager.googleapis.com \ container.googleapis.com \ sourcerepo.googleapis.com \ cloudbuild.googleapis.com \ containerregistry.googleapis.com \ --async - सैंपल सोर्स को क्लोन करें और लैब डायरेक्ट्री पर स्विच करें:
git clone https://github.com/GoogleCloudPlatform/software-delivery-workshop.git gke-progression cd gke-progression/labs/gke-progression rm -rf ../../.git - सैंपल रिपॉज़िटरी में मौजूद प्लेसहोल्डर वैल्यू को अपनी
PROJECT_IDसे बदलें:इस चरण में, अपने मौजूदा एनवायरमेंट के लिए यूनीक कॉन्फ़िगरेशन फ़ाइलों के इंस्टेंस बनाए जाते हैं.अपडेट किए जा रहे टेंप्लेट का उदाहरण देखने के लिए, यह कमांड चलाएं. नीचे दिए गए निर्देश को चलाकर, वैरिएबल को बदलें.cat k8s/deployments/dev/frontend-dev.yaml.tmpl बदलाव के बाद फ़ाइल का उदाहरण देखने के लिए, यह कमांड चलाएं.for template in $(find . -name '*.tmpl'); do envsubst '${PROJECT_ID} ${ZONE} ${CLUSTER} ${APP_NAME}' < ${template} > ${template%.*}; donecat k8s/deployments/dev/frontend-dev.yaml - अगर आपने Cloud Shell में पहले कभी Git का इस्तेमाल नहीं किया है, तो
user.nameऔरuser.emailके लिए अपनी पसंद की वैल्यू सेट करें:git config --global user.email "YOUR_EMAIL_ADDRESS" git config --global user.name "YOUR_USERNAME" - सैंपल रिपॉज़िटरी से कोड को Cloud Source Repositories में सेव करें:
gcloud source repos create gke-progression git init git config credential.helper gcloud.sh git remote add gcp https://source.developers.google.com/p/$PROJECT_ID/r/gke-progression git branch -m main git add . && git commit -m "initial commit" git push gcp main - अपना GKE क्लस्टर बनाएं.
gcloud container clusters create ${CLUSTER} \ --project=${PROJECT_ID} \ --zone=${ZONE} - अपने क्लस्टर को Cloud Build के अधिकार दें. Cloud Build, ऐप्लिकेशन को आपके GKE क्लस्टर पर डिप्लॉय करेगा. इसके लिए, उसे अधिकारों की ज़रूरत होगी.
gcloud projects add-iam-policy-binding ${PROJECT_ID} \ --member=serviceAccount:${PROJECT_NUMBER}@cloudbuild.gserviceaccount.com \ --role=roles/container.developer
आपका एनवायरमेंट तैयार है!
4. GKE ऐप्लिकेशन बनाना
इस सेक्शन में, शुरुआती प्रोडक्शन ऐप्लिकेशन बनाया और डिप्लॉय किया जाता है. इसका इस्तेमाल इस पूरे ट्यूटोरियल में किया जाता है.
- Cloud Build की मदद से ऐप्लिकेशन बनाएं:
gcloud builds submit --tag gcr.io/$PROJECT_ID/$APP_NAME:1.0.0 src/ - कैनरी और प्रोडक्शन एनवायरमेंट में मैन्युअल तरीके से डिप्लॉय करें:
kubectl applyकमांड का इस्तेमाल करके, प्रोडक्शन और कैनरी डिप्लॉयमेंट और सेवाएं बनाएं. यहां डिप्लॉय की गई सेवा, ट्रैफ़िक को कैनरी और प्रॉडक्ट, दोनों डिप्लॉयमेंट पर रूट करेगी.kubectl create ns production kubectl apply -f k8s/deployments/prod -n production kubectl apply -f k8s/deployments/canary -n production kubectl apply -f k8s/services -n production - चल रहे पॉड की संख्या की समीक्षा करें. पुष्टि करें कि फ़्रंटएंड के लिए चार पॉड चल रहे हैं. इनमें से तीन पॉड, प्रोडक्शन ट्रैफ़िक के लिए और एक पॉड, कैनरी रिलीज़ के लिए चल रहा है. इसका मतलब है कि कैनरी रिलीज़ में किए गए बदलावों का असर, सिर्फ़ चार में से एक (25%) उपयोगकर्ता पर पड़ेगा.
kubectl get pods -n production -l app=$APP_NAME -l role=frontend - प्रोडक्शन सेवाओं के लिए एक्सटर्नल आईपी पता पाएं.
लोड बैलेंसर के आईपी पते की जानकारी देने के बाद, अगले चरण पर जाएंkubectl get service $APP_NAME -n production - यह कुकी, बाहरी आईपी को बाद में इस्तेमाल करने के लिए सेव करती है.
export PRODUCTION_IP=$(kubectl get -o jsonpath="{.status.loadBalancer.ingress[0].ip}" --namespace=production services $APP_NAME) - आवेदन की समीक्षा करें. सेवा के वर्शन का आउटपुट देखें. यह Hello World v1.0 होना चाहिए
curl http://$PRODUCTION_IP
बधाई हो! आपने सैंपल ऐप्लिकेशन डिप्लॉय कर दिया है! इसके बाद, बदलावों को लगातार डिप्लॉय करने के लिए ट्रिगर सेट अप करें.
5. Git ब्रांच के लिए डिप्लॉयमेंट को अपने-आप होने के लिए सेट करना
इस सेक्शन में, आपको एक ट्रिगर सेट अप करना होगा. इससे main के अलावा किसी अन्य ब्रांच को कमिट करने पर, Cloudbuild जॉब को एक्ज़ीक्यूट किया जा सकेगा. यहां इस्तेमाल की गई Cloud Build फ़ाइल, किसी भी मौजूदा या नई ब्रांच के लिए अपने-आप नेमस्पेस और डिप्लॉयमेंट बना देगी. इससे डेवलपर, मुख्य ब्रांच के साथ इंटिग्रेट करने से पहले अपने कोड की झलक देख पाएंगे.
- ट्रिगर सेट अप करें:इस ट्रिगर का मुख्य कॉम्पोनेंट,
mainऔरinvertRegexपैरामीटर को मैच करने के लिएbranchNameपैरामीटर का इस्तेमाल करना है.invertRegexपैरामीटर को सही पर सेट किया जाता है. साथ ही, यहbranchNameपैटर्न को बदलकर,mainसे अलग किसी भी वैल्यू से मैच करने के लिए सेट किया जाता है. आपकी जानकारी के लिए,build/branch-trigger.jsonमें ये लाइनें दी गई हैं. इसके अलावा, इस ट्रिगर के साथ इस्तेमाल की गई Cloud Build फ़ाइल की आखिरी कुछ लाइनें, उस ब्रांच के नाम पर एक नेमस्पेस बनाती हैं जिसने जॉब को ट्रिगर किया है. इसके बाद, यह ऐप्लिकेशन और सेवा को नए नेमस्पेस में डिप्लॉय करती है. आपकी जानकारी के लिए,"branchName": "main", "invertRegex": true
build/branch-cloudbuild.yamlमें ये लाइनें दी गई हैं अब आपको इस्तेमाल किए जा रहे तरीकों के बारे में पता चल गया है. इसलिए, नीचे दी गई gcloud कमांड का इस्तेमाल करके ट्रिगर बनाएं.kubectl get ns ${BRANCH_NAME} || kubectl create ns ${BRANCH_NAME} kubectl apply --namespace ${BRANCH_NAME} --recursive -f k8s/deployments/dev kubectl apply --namespace ${BRANCH_NAME} --recursive -f k8s/servicesgcloud beta builds triggers create cloud-source-repositories \ --trigger-config build/branch-trigger.json - ट्रिगर की समीक्षा करने के लिए, Console में Cloud Build ट्रिगर पेज पर जाएं.ट्रिगर पर जाएं
- नई ब्रांच बनाएं:
git checkout -b new-feature-1 - कोड में बदलाव करके v1.1 के बारे में बताएं
src/app.pyमें बदलाव करें और जवाब को 1.0 से बदलकर 1.1 करें@app.route('/') def hello_world(): return 'Hello World v1.1' - बदलाव को सेव करें और रिमोट रिपॉज़िटरी में पुश करें:
git add . && git commit -m "updated" && git push gcp new-feature-1 - बनाए जा रहे बिल्ड की समीक्षा करने के लिए, Console में Cloud Build का इतिहास पेज पर जाएं.बिल्ड पर जाएंबिल्ड पूरा होने के बाद, अगले चरण पर जाएं
- हाल ही में डिप्लॉय की गई ब्रांच सेवा के लिए, बाहरी आईपी पता वापस पाएं.
लोड बैलेंसर के आईपी पते की जानकारी देने के बाद, अगले चरण पर जाएंkubectl get service $APP_NAME -n new-feature-1 - यह कुकी, बाहरी आईपी को बाद में इस्तेमाल करने के लिए सेव करती है.
export BRANCH_IP=$(kubectl get -o jsonpath="{.status.loadBalancer.ingress[0].ip}" --namespace=new-feature-1 services $APP_NAME) - आवेदन की समीक्षा करें. सेवा के वर्शन का आउटपुट देखें. यह Hello World v1.0 होना चाहिए
curl http://$BRANCH_IP
6. Git की मुख्य शाखा के लिए डिप्लॉयमेंट को अपने-आप होने की सुविधा
कोड को प्रोडक्शन के लिए रिलीज़ करने से पहले, आम तौर पर लाइव ट्रैफ़िक के छोटे सबसेट के लिए कोड रिलीज़ किया जाता है. इसके बाद, पूरे ट्रैफ़िक को नए कोड बेस पर माइग्रेट किया जाता है.
इस सेक्शन में, आपको एक ऐसा ट्रिगर लागू करना है जो मुख्य ब्रांच में कोड सबमिट होने पर चालू हो जाए. ट्रिगर, कैनरी डिप्लॉयमेंट को लागू करता है. इससे नए वर्शन को 25% लाइव ट्रैफ़िक मिलता है.
- मुख्य ब्रांच के लिए ट्रिगर सेट अप करें:
gcloud beta builds triggers create cloud-source-repositories \ --trigger-config build/main-trigger.json - नए ट्रिगर की समीक्षा करने के लिए, Console में Cloud Build ट्रिगर पेज पर जाएं.ट्रिगर पर जाएं
- ब्रांच को मुख्य लाइन में मर्ज करें और रिमोट रिपॉज़िटरी में पुश करें:
git checkout main git merge new-feature-1 git push gcp main - बनाई जा रही इमेज की समीक्षा करने के लिए, Console में Cloud Build का इतिहास पेज पर जाएं.बिल्ड पर जाएंबिल्ड पूरा होने के बाद, अगले चरण पर जाएं
- सर्वर से मिले कई जवाबों की समीक्षा करें. इसके लिए, यह कमांड चलाएं. ध्यान दें कि लगभग 25% जवाबों में, Hello World v1.1 का नया जवाब दिख रहा है
जब आप जारी रखने के लिए तैयार हों, तो लूप से बाहर निकलने के लिएwhile true; do curl -w "\n" http://$PRODUCTION_IP; sleep 1; doneCtrl+cदबाएं.
7. git टैग के लिए डिप्लॉयमेंट को ऑटोमेट करना
जब ट्रैफ़िक के छोटे सबसेट के साथ कैनरी डिप्लॉयमेंट की पुष्टि हो जाती है, तब डिप्लॉयमेंट को बाकी लाइव ट्रैफ़िक के लिए रिलीज़ किया जाता है.
इस सेक्शन में, एक ऐसा ट्रिगर सेट अप किया जाता है जो रिपॉज़िटरी में टैग बनाने पर चालू होता है. ट्रिगर, इमेज को सही टैग के साथ लेबल करता है. इसके बाद, अपडेट को प्रोडक्शन एनवायरमेंट में डिप्लॉय करता है. इससे यह पक्का होता है कि 100% ट्रैफ़िक, टैग की गई इमेज को ऐक्सेस कर रहा है.
- टैग ट्रिगर सेट अप करें:
gcloud beta builds triggers create cloud-source-repositories \ --trigger-config build/tag-trigger.json - नए ट्रिगर की समीक्षा करने के लिए, Console में Cloud Build ट्रिगर पेज पर जाएं.ट्रिगर पर जाएं
- नया टैग बनाएं और उसे रिमोट रिपॉज़िटरी में पुश करें:
git tag 1.1 git push gcp 1.1 - बिल्ड की प्रोसेस देखने के लिए, Console में Cloud Build का इतिहास पेज पर जाएं.बिल्ड पर जाएं
- सर्वर से मिले कई जवाबों की समीक्षा करें. इसके लिए, यह कमांड चलाएं और ध्यान दें कि 100% जवाबों में, Hello World v1.1 का नया जवाब दिख रहा है. इसमें कुछ समय लग सकता है, क्योंकि नए पॉड को GKE में डिप्लॉय किया जाता है और उनकी सेहत की जांच की जाती है
जब आप जारी रखने के लिए तैयार हों, तो लूप से बाहर निकलने के लिएwhile true; do curl -w "\n" http://$PRODUCTION_IP; sleep 1; doneCtrl+cदबाएं.बधाई हो! आपने GKE पर अपने ऐप्लिकेशन डिप्लॉय करने के लिए, Cloud Build में ब्रांच और टैग के लिए CI/CD ट्रिगर बनाए हों.
8. साफ़-सफ़ाई सेवा
प्रोजेक्ट मिटाना
- Cloud Console में, संसाधन मैनेज करें पेज पर जाएं.
- प्रोजेक्ट की सूची में, वह प्रोजेक्ट चुनें जिसे आपको मिटाना है. इसके बाद, मिटाएं पर क्लिक करें.
- डायलॉग बॉक्स में, प्रोजेक्ट आईडी टाइप करें. इसके बाद, प्रोजेक्ट मिटाने के लिए बंद करें पर क्लिक करें.