1. ওভারভিউ
Microsoft .NET Core হল .NET-এর একটি ওপেন-সোর্স এবং ক্রস-প্ল্যাটফর্ম সংস্করণ যা স্থানীয়ভাবে পাত্রে চলতে পারে। .NET কোর GitHub-এ উপলব্ধ এবং Microsoft এবং .NET সম্প্রদায় দ্বারা রক্ষণাবেক্ষণ করা হয়। এই ল্যাবটি Google Kubernetes Engine (GKE) এ একটি কন্টেইনারাইজড .NET কোর অ্যাপ স্থাপন করে।
এই ল্যাবটি একটি সাধারণ বিকাশের প্যাটার্ন অনুসরণ করে যেখানে অ্যাপ্লিকেশনগুলি বিকাশকারীদের স্থানীয় পরিবেশে তৈরি করা হয় এবং তারপরে উত্পাদনে স্থাপন করা হয়। ল্যাবের প্রথম অংশে, একটি উদাহরণ .NET কোর অ্যাপ ক্লাউড শেলে চলমান একটি কন্টেইনার ব্যবহার করে যাচাই করা হয়েছে। একবার যাচাই হয়ে গেলে, অ্যাপটি তারপর GKE ব্যবহার করে Kubernetes- এ স্থাপন করা হয়। ল্যাবটিতে একটি GKE ক্লাস্টার তৈরি করার পদক্ষেপগুলি অন্তর্ভুক্ত রয়েছে।
ল্যাবের দ্বিতীয় অংশে, অ্যাপটিতে একটি ছোটখাট পরিবর্তন করা হয়েছে যা সেই অ্যাপ ইনস্ট্যান্সটি চালাচ্ছে এমন ধারকটির হোস্টনাম দেখায়। আপডেট করা অ্যাপ্লিকেশনটি তারপর ক্লাউড শেলে যাচাই করা হয় এবং নতুন সংস্করণ ব্যবহার করার জন্য স্থাপনা আপডেট করা হয়। নিম্নলিখিত চিত্রটি এই ল্যাবে কার্যক্রমের ক্রম দেখায়:
খরচ
আপনি যদি এই ল্যাবটি ঠিক লিখিতভাবে চালান তবে নিম্নলিখিত পরিষেবাগুলির জন্য স্বাভাবিক খরচ প্রযোজ্য হবে
2. সেটআপ এবং প্রয়োজনীয়তা
পূর্বশর্ত
এই ল্যাবটি সম্পূর্ণ করতে, একটি Google ক্লাউড অ্যাকাউন্ট এবং প্রকল্প প্রয়োজন৷ কীভাবে একটি নতুন প্রকল্প তৈরি করতে হয় সে সম্পর্কে আরও বিস্তারিত নির্দেশাবলীর জন্য, এই কোডল্যাবটি পড়ুন।
এই ল্যাবটি ক্লাউড শেল -এ চলমান ডকার ব্যবহার করে, যা Google ক্লাউড কনসোলের মাধ্যমে উপলব্ধ এবং অনেকগুলি দরকারী টুল যেমন gcloud এবং Docker সহ পূর্ব-কনফিগার করা হয়। ক্লাউড শেলটিতে কীভাবে অ্যাক্সেস করবেন তা নীচে দেখানো হয়েছে। কনসোল উইন্ডোর নীচের ফলকে এটি প্রকাশ করতে উপরের ডানদিকে ক্লাউড শেল আইকনে ক্লিক করুন।
GKE ক্লাস্টারের জন্য বিকল্প কনফিগারেশন বিকল্প (ঐচ্ছিক)
এই ল্যাবের জন্য একটি Kubernetes ক্লাস্টার প্রয়োজন। পরবর্তী বিভাগে, একটি সাধারণ কনফিগারেশন সহ একটি GKE ক্লাস্টার তৈরি করা হয়েছে। এই বিভাগটি কিছু gcloud
কমান্ড দেখায় যেগুলি GKE ব্যবহার করে একটি Kubernetes ক্লাস্টার তৈরি করার সময় ব্যবহার করার জন্য বিকল্প কনফিগারেশন বিকল্প প্রদান করে। উদাহরণস্বরূপ, নীচের কমান্ডগুলি ব্যবহার করে বিভিন্ন মেশিনের ধরন, অঞ্চল এবং এমনকি জিপিইউ (অ্যাক্সিলারেটর) সনাক্ত করা সম্ভব।
- এই কমান্ডের সাহায্যে মেশিনের প্রকারের তালিকা করুন
gcloud compute machine-types list
- এই কমান্ডের সাহায্যে GPU গুলি তালিকাভুক্ত করুন
gcloud compute accelerator-types list
- এই কমান্ডের সাহায্যে কম্পিউট জোন তালিকাভুক্ত করুন
gcloud compute zones list
- যেকোন gcloud কমান্ড
gcloud container clusters --help
- উদাহরণস্বরূপ, এটি একটি kubernetes ক্লাস্টার
gcloud container clusters create --help
- উদাহরণস্বরূপ, এটি একটি kubernetes ক্লাস্টার
GKE-এর জন্য কনফিগারেশন বিকল্পগুলির একটি সম্পূর্ণ তালিকার জন্য, এই নথিটি দেখুন
কুবারনেটস ক্লাস্টার তৈরি করার জন্য প্রস্তুত করুন
ক্লাউড শেল-এ, কিছু পরিবেশ ভেরিয়েবল সেট করা এবং gcloud ক্লায়েন্ট কনফিগার করা প্রয়োজন। এটি নিম্নলিখিত কমান্ড দিয়ে সম্পন্ন করা হয়।
export PROJECT_ID=YOUR_PROJECT_ID
export DEFAULT_ZONE=us-central1-c
gcloud config set project ${PROJECT_ID}
gcloud config set compute/zone ${DEFAULT_ZONE}
একটি GKE ক্লাস্টার তৈরি করুন
যেহেতু এই ল্যাবটি কুবারনেটে .NET কোর অ্যাপ স্থাপন করে, তাই একটি ক্লাস্টার তৈরি করা প্রয়োজন৷ GKE ব্যবহার করে Google ক্লাউডে একটি নতুন Kubernetes ক্লাস্টার তৈরি করতে নিম্নলিখিত কমান্ডটি ব্যবহার করুন।
gcloud container clusters create dotnet-cluster \
--zone ${DEFAULT_ZONE} \
--num-nodes=1 \
--node-locations=${DEFAULT_ZONE},us-central1-b \
--enable-stackdriver-kubernetes \
--machine-type=n1-standard-1 \
--workload-pool=${PROJECT_ID}.svc.id.goog \
--enable-ip-alias
-
--num-nodes
হল প্রতি জোন যোগ করার জন্য নোডের সংখ্যা এবং পরে স্কেল করা যেতে পারে -
--node-locations
হল একটি কমা দ্বারা বিভক্ত অঞ্চলগুলির তালিকা। এই ক্ষেত্রে আপনি উপরের পরিবেশ পরিবর্তনশীল এবংus-central1-b
এ যে জোনটি চিহ্নিত করেছেন তা ব্যবহার করা হয়- দ্রষ্টব্য: এই তালিকায় ডুপ্লিকেট থাকতে পারে না
-
--workload-pool
কাজের চাপের পরিচয় প্রতিষ্ঠা করে যাতে GKE ওয়ার্কলোডগুলি Google ক্লাউড পরিষেবাগুলি অ্যাক্সেস করতে পারে৷
ক্লাস্টার তৈরি করার সময় নিম্নলিখিতটি প্রদর্শিত হয়
Creating cluster dotnet-cluster in us-central1-b... Cluster is being deployed...⠼
kubectl কনফিগার করুন
kubectl
CLI হল একটি Kubernetes ক্লাস্টারের সাথে ইন্টারঅ্যাক্ট করার প্রাথমিক উপায়। এইমাত্র তৈরি করা নতুন ক্লাস্টারের সাথে এটি ব্যবহার করার জন্য, ক্লাস্টারের বিরুদ্ধে প্রমাণীকরণের জন্য এটি কনফিগার করা দরকার। তিনি আদেশ অনুসরণ করে এটি করা হয়।
$ gcloud container clusters get-credentials dotnet-cluster --zone ${DEFAULT_ZONE}
Fetching cluster endpoint and auth data.
kubeconfig entry generated for dotnet-cluster.
ক্লাস্টারের সাথে ইন্টারঅ্যাক্ট করতে kubectl
ব্যবহার করা এখন সম্ভব হওয়া উচিত।
$ kubectl get nodes
NAME STATUS ROLES AGE VERSION
gke-dotnet-cluster-default-pool-02c9dcb9-fgxj Ready <none> 2m15s v1.16.13-gke.401
gke-dotnet-cluster-default-pool-ed09d7b7-xdx9 Ready <none> 2m24s v1.16.13-gke.401
3. স্থানীয়ভাবে পরীক্ষা করুন এবং পছন্দসই কার্যকারিতা নিশ্চিত করুন
এই ল্যাবটি ডকার হাবের অফিসিয়াল .NET সংগ্রহস্থল থেকে নিম্নলিখিত ধারক চিত্রগুলি ব্যবহার করে৷
কার্যকারিতা যাচাই করতে স্থানীয়ভাবে ধারক চালান
ক্লাউড শেলে, যাচাই করুন যে ডকার সঠিকভাবে চলছে এবং .NET কন্টেইনার নিম্নলিখিত ডকার কমান্ডটি চালিয়ে প্রত্যাশিতভাবে কাজ করে:
$ docker run --rm mcr.microsoft.com/dotnet/samples
Hello from .NET!
__________________
\
\
....
....'
....
..........
.............'..'..
................'..'.....
.......'..........'..'..'....
........'..........'..'..'.....
.'....'..'..........'..'.......'.
.'..................'... ......
. ......'......... .....
. ......
.. . .. ......
.... . .......
...... ....... ............
................ ......................
........................'................
......................'..'...... .......
.........................'..'..... .......
........ ..'.............'..'.... ..........
..'..'... ...............'....... ..........
...'...... ...... .......... ...... .......
........... ....... ........ ......
....... '...'.'. '.'.'.' ....
....... .....'.. ..'.....
.. .......... ..'........
............ ..............
............. '..............
...........'.. .'.'............
............... .'.'.............
.............'.. ..'..'...........
............... .'..............
......... ..............
.....
Environment:
.NET 5.0.1-servicing.20575.16
Linux 5.4.58-07649-ge120df5deade #1 SMP PREEMPT Wed Aug 26 04:56:33 PDT 2020
ওয়েব অ্যাপ কার্যকারিতা নিশ্চিত করুন
একটি নমুনা ওয়েব অ্যাপ্লিকেশন এছাড়াও ক্লাউড শেল যাচাই করা যেতে পারে. নীচের ডকার রান কমান্ডটি একটি নতুন কন্টেইনার তৈরি করে যা পোর্ট 80
প্রকাশ করে এবং localhost
পোর্ট 8080
-এ ম্যাপ করে। মনে রাখবেন যে localhost
এই ক্ষেত্রে ক্লাউড শেল এ রয়েছে।
$ docker run -it --rm -p 8080:80 --name aspnetcore_sample mcr.microsoft.com/dotnet/samples:aspnetapp
warn: Microsoft.AspNetCore.DataProtection.Repositories.FileSystemXmlRepository[60]
Storing keys in a directory '/root/.aspnet/DataProtection-Keys' that may not be persisted outside of the container. Protected data will be unavailable when container is destroyed.
warn: Microsoft.AspNetCore.DataProtection.KeyManagement.XmlKeyManager[35]
No XML encryptor configured. Key {64a3ed06-35f7-4d95-9554-8efd38f8b5d3} may be persisted to storage in unencrypted form.
info: Microsoft.Hosting.Lifetime[0]
Now listening on: http://[::]:80
info: Microsoft.Hosting.Lifetime[0]
Application started. Press Ctrl+C to shut down.
info: Microsoft.Hosting.Lifetime[0]
Hosting environment: Production
info: Microsoft.Hosting.Lifetime[0]
Content root path: /app
যেহেতু এটি একটি ওয়েব অ্যাপ, এটি একটি ওয়েব ব্রাউজারে দেখা এবং যাচাই করা প্রয়োজন৷ পরবর্তী বিভাগ দেখায় কিভাবে ক্লাউড শেল ওয়েব প্রিভিউ ব্যবহার করে এটি করতে হয়।
4. "ওয়েব প্রিভিউ" ব্যবহার করে ক্লাউড শেল থেকে পরিষেবাগুলি অ্যাক্সেস করুন
ক্লাউড শেল ওয়েব প্রিভিউ অফার করে, একটি বৈশিষ্ট্য যা ক্লাউড শেল ইনস্ট্যান্সে চলমান প্রক্রিয়াগুলির সাথে ইন্টারঅ্যাক্ট করার জন্য একটি ব্রাউজার ব্যবহার করা সম্ভব করে।
ক্লাউড শেলে অ্যাপ দেখতে "ওয়েব প্রিভিউ" ব্যবহার করুন
ক্লাউড শেল-এ, ওয়েব প্রিভিউ বোতামে ক্লিক করুন এবং " পোর্ট 8080 এর পূর্বরূপ " (অথবা যে কোনো পোর্ট ওয়েব প্রিভিউ ব্যবহার করার জন্য সেট করা আছে) বেছে নিন।
এটি এই মত একটি ঠিকানা সহ একটি ব্রাউজার উইন্ডো খুলবে:
https://8080-cs-754738286554-default.us-central1.cloudshell.dev/?authuser=0
ওয়েব প্রিভিউ ব্যবহার করে .NET নমুনা অ্যাপ্লিকেশন দেখুন
শেষ ধাপে শুরু করা নমুনা অ্যাপটি এখন ওয়েব প্রিভিউ শুরু করে এবং প্রদত্ত URL লোড করে দেখা যাবে। এটি এই মত কিছু দেখা উচিত:
5. কুবারনেটে স্থাপন করুন
YAML ফাইল তৈরি করুন এবং আবেদন করুন
পরবর্তী ধাপে দুটি Kubernetes সম্পদ, একটি স্থাপনা এবং একটি পরিষেবা বর্ণনা করে একটি YAML ফাইল প্রয়োজন৷ ক্লাউড শেলে dotnet-app.yaml
নামে একটি ফাইল তৈরি করুন এবং এতে নিম্নলিখিত বিষয়বস্তু যোগ করুন।
apiVersion: apps/v1
kind: Deployment
metadata:
name: dotnet-deployment
labels:
app: dotnetapp
spec:
replicas: 3
selector:
matchLabels:
app: dotnetapp
template:
metadata:
labels:
app: dotnetapp
spec:
containers:
- name: dotnet
image: mcr.microsoft.com/dotnet/samples:aspnetapp
ports:
- containerPort: 80
---
apiVersion: v1
kind: Service
metadata:
name: dotnet-service
spec:
selector:
app: dotnetapp
ports:
- protocol: TCP
port: 8080
targetPort: 80
এখন এই ফাইলটি kubernetes এ প্রয়োগ করতে kubectl
ব্যবহার করুন।
$ kubectl apply -f dotnet-app.yaml
deployment.apps/dotnet-deployment created
service/dotnet-service created
বার্তাগুলি লক্ষ্য করুন যা নির্দেশ করে যে কাঙ্ক্ষিত সংস্থানগুলি তৈরি করা হয়েছে।
ফলাফল সম্পদ অন্বেষণ
উপরে তৈরি করা সংস্থানগুলি পরীক্ষা করতে আমরা kubectl
CLI ব্যবহার করতে পারি। প্রথমে, ডিপ্লয়মেন্ট রিসোর্স দেখুন এবং নিশ্চিত করুন যে নতুন স্থাপনা সেখানে আছে।
$ kubectl get deployment
NAME READY UP-TO-DATE AVAILABLE AGE
dotnet-deployment 3/3 3 3 80s
এর পরে রেপ্লিকাসেটগুলি দেখুন। উপরোক্ত স্থাপনার দ্বারা তৈরি একটি ReplicaSet থাকা উচিত।
$ kubectl get replicaset
NAME DESIRED CURRENT READY AGE
dotnet-deployment-5c9d4cc4b9 3 3 3 111s
সবশেষে, পডগুলি দেখুন। স্থাপনা নির্দেশ করেছে যে তিনটি উদাহরণ থাকা উচিত। নীচের কমান্ডটি দেখানো উচিত যে তিনটি উদাহরণ রয়েছে। -o wide
বিকল্পটি যোগ করা হয়েছে যাতে নোডগুলি যেখানে সেই দৃষ্টান্তগুলি চলছে তা দেখানো হবে।
$ kubectl get pod -o wide
NAME READY STATUS RESTARTS AGE IP NODE NOMINATED NODE READINESS GATES
dotnet-deployment-5c9d4cc4b9-cspqd 1/1 Running 0 2m25s 10.16.0.8 gke-dotnet-cluster-default-pool-ed09d7b7-xdx9 <none> <none>
dotnet-deployment-5c9d4cc4b9-httw6 1/1 Running 0 2m25s 10.16.1.7 gke-dotnet-cluster-default-pool-02c9dcb9-fgxj <none> <none>
dotnet-deployment-5c9d4cc4b9-vvdln 1/1 Running 0 2m25s 10.16.0.7 gke-dotnet-cluster-default-pool-ed09d7b7-xdx9 <none> <none>
পরিষেবা সংস্থান পর্যালোচনা করুন
Kubernetes-এ একটি পরিষেবা সংস্থান হল একটি লোড ব্যালেন্সার। শেষ পয়েন্টগুলি পডের লেবেল দ্বারা নির্ধারিত হয়। এইভাবে, উপরের kubectl scale deployment
অপারেশনের মাধ্যমে স্থাপনায় নতুন পড যোগ করার সাথে সাথে, ফলস্বরূপ পডগুলি সেই পরিষেবা দ্বারা পরিচালনা করা অনুরোধগুলির জন্য অবিলম্বে উপলব্ধ।
নিম্নলিখিত কমান্ডটি পরিষেবা সংস্থান প্রদর্শন করা উচিত।
$ kubectl get svc
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
dotnet-service ClusterIP 10.20.9.124 <none> 8080/TCP 2m50s
...
নিম্নলিখিত কমান্ডের সাহায্যে পরিষেবা সম্পর্কে আরও বিশদ দেখতে পাওয়া সম্ভব।
$ kubectl describe svc dotnet-service
Name: dotnet-service
Namespace: default
Labels: <none>
Annotations: <none>
Selector: app=dotnetapp
Type: ClusterIP
IP: 10.20.9.124
Port: <unset> 8080/TCP
TargetPort: 80/TCP
Endpoints: 10.16.0.7:80,10.16.0.8:80,10.16.1.7:80
Session Affinity: None
Events: <none>
লক্ষ্য করুন যে পরিষেবাটি ClusterIP
প্রকারের। এর মানে হল যে ক্লাস্টারের মধ্যে যেকোনো পড তার IP ঠিকানায় পরিষেবার নাম, dotnet-service
সমাধান করতে পারে। পরিষেবাতে পাঠানো অনুরোধগুলি সমস্ত দৃষ্টান্ত (পড) জুড়ে ভারসাম্যপূর্ণ হবে। উপরের Endpoints
মানটি এই পরিষেবার জন্য বর্তমানে উপলব্ধ পডগুলির আইপিগুলি দেখায়৷ উপরের আউটপুট যে Pods এর IP এর সাথে তুলনা করুন।
চলমান অ্যাপ যাচাই করুন
এই মুহুর্তে অ্যাপ্লিকেশনটি লাইভ এবং ব্যবহারকারীর অনুরোধের জন্য প্রস্তুত। এটি অ্যাক্সেস করার জন্য, একটি প্রক্সি ব্যবহার করুন। নিম্নলিখিত কমান্ডটি একটি স্থানীয় প্রক্সি তৈরি করে যা পোর্ট 8080
-এ অনুরোধগুলি গ্রহণ করে এবং সেগুলিকে কুবারনেটস ক্লাস্টারে প্রেরণ করে।
$ kubectl proxy --port 8080
Starting to serve on 127.0.0.1:8080
এখন ওয়েব অ্যাপ্লিকেশন অ্যাক্সেস করতে ক্লাউড শেল-এ ওয়েব প্রিভিউ ব্যবহার করুন।
ওয়েব প্রিভিউ দ্বারা উত্পন্ন URL-এ নিম্নলিখিত যোগ করুন: /api/v1/namespaces/default/services/dotnet-service:8080/proxy/
। এটি এই মত কিছু দেখতে শেষ হবে:
https://8080-cs-473655782854-default.us-central1.cloudshell.dev/api/v1/namespaces/default/services/dotnet-service:8080/proxy/
Google Kubernetes ইঞ্জিনে একটি .NET কোর অ্যাপ স্থাপন করার জন্য অভিনন্দন। পরবর্তীতে আমরা অ্যাপটিতে একটি পরিবর্তন করব এবং পুনরায় স্থাপন করব।
6. অ্যাপটি পরিবর্তন করুন
এই বিভাগে, উদাহরণটি যে হোস্টে চলছে তা দেখানোর জন্য অ্যাপ্লিকেশনটি পরিবর্তন করা হবে। এটি নিশ্চিত করা সম্ভব করবে যে লোড ব্যালেন্সিং কাজ করছে এবং উপলব্ধ পডগুলি প্রত্যাশিতভাবে সাড়া দিচ্ছে।
সোর্স কোড পান
git clone https://github.com/dotnet/dotnet-docker.git
cd dotnet-docker/samples/aspnetapp/
হোস্টের নাম অন্তর্ভুক্ত করতে অ্যাপটি আপডেট করুন
vi aspnetapp/Pages/Index.cshtml
<tr>
<td>Host</td>
<td>@Environment.MachineName</td>
</tr>
একটি নতুন ধারক চিত্র তৈরি করুন এবং স্থানীয়ভাবে পরীক্ষা করুন
আপডেট করা কোড দিয়ে নতুন কন্টেইনার ইমেজ তৈরি করুন।
docker build --pull -t aspnetapp:alpine -f Dockerfile.alpine-x64 .
আগের মতো, স্থানীয়ভাবে নতুন অ্যাপ্লিকেশন পরীক্ষা করুন
$ docker run --rm -it -p 8080:80 aspnetapp:alpine
warn: Microsoft.AspNetCore.DataProtection.Repositories.FileSystemXmlRepository[60]
Storing keys in a directory '/root/.aspnet/DataProtection-Keys' that may not be persisted outside of the container. Protected data will be unavailable when container is destroyed.
warn: Microsoft.AspNetCore.DataProtection.KeyManagement.XmlKeyManager[35]
No XML encryptor configured. Key {f71feb13-8eae-4552-b4f2-654435fff7f8} may be persisted to storage in unencrypted form.
info: Microsoft.Hosting.Lifetime[0]
Now listening on: http://[::]:80
info: Microsoft.Hosting.Lifetime[0]
Application started. Press Ctrl+C to shut down.
info: Microsoft.Hosting.Lifetime[0]
Hosting environment: Production
info: Microsoft.Hosting.Lifetime[0]
Content root path: /app
আগের মতো, অ্যাপটি ওয়েব প্রিভিউ ব্যবহার করে অ্যাক্সেস করা যেতে পারে। এই সময় হোস্ট প্যারামিটারটি দৃশ্যমান হওয়া উচিত, যেমনটি এখানে দেখানো হয়েছে:
ক্লাউড শেলে একটি নতুন ট্যাব খুলুন এবং কন্টেইনার আইডি উপরে দেখানো হোস্ট মানের সাথে মেলে তা দেখতে docker ps
চালান।
$ docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
ab85ce11aecd aspnetapp:alpine "./aspnetapp" 2 minutes ago Up 2 minutes 0.0.0.0:8080->80/tcp relaxed_northcutt
ছবিটি ট্যাগ করুন এবং পুশ করুন যাতে এটি Kubernetes-এর কাছে উপলব্ধ হয়
কুবারনেটস যাতে এটি টানতে সক্ষম হয় তার জন্য ছবিটিকে ট্যাগ এবং পুশ করতে হবে। ধারক চিত্রগুলি তালিকাবদ্ধ করে শুরু করুন এবং পছন্দসই চিত্র সনাক্ত করুন।
$ docker image list
REPOSITORY TAG IMAGE ID CREATED SIZE
aspnetapp alpine 95b4267bb6d0 6 days ago 110MB
এরপরে, সেই ছবিটিকে ট্যাগ করুন এবং এটিকে Google কন্টেইনার রেজিস্ট্রিতে পুশ করুন। উপরের IMAGE আইডি ব্যবহার করে, এটি এইরকম দেখাবে
docker tag 95b4267bb6d0 gcr.io/${PROJECT_ID}/aspnetapp:alpine
docker push gcr.io/${PROJECT_ID}/aspnetapp:alpine
7. আপডেট করা অ্যাপ্লিকেশন পুনরায় ব্যবহার করুন
YAML ফাইলটি সম্পাদনা করুন
dotnet-app.yaml
ফাইলটি সংরক্ষণ করা হয়েছে এমন ডিরেক্টরিতে ফিরে যান। YAML ফাইলে নিম্নলিখিত লাইন খুঁজুন
image: mcr.microsoft.com/dotnet/core/samples:aspnetapp
উপরে gcr.io-এ তৈরি এবং পুশ করা কন্টেইনার ইমেজটিকে রেফারেন্স করার জন্য এটি পরিবর্তন করা দরকার।
image: gcr.io/PROJECT_ID/aspnetapp:alpine
আপনার PROJECT_ID
ব্যবহার করতে এটি সংশোধন করতে ভুলবেন না। আপনার কাজ শেষ হলে এটি এইরকম কিছু দেখা উচিত
image: gcr.io/myproject/aspnetapp:alpine
আপডেট করা YAML ফাইলটি প্রয়োগ করুন
$ kubectl apply -f dotnet-app.yaml
deployment.apps/dotnet-deployment configured
service/dotnet-service unchanged
লক্ষ্য করুন যে ডিপ্লয়মেন্ট রিসোর্স আপডেট করা হয়েছে এবং সার্ভিস রিসোর্স অপরিবর্তিত দেখাচ্ছে। আপডেট করা পডগুলিকে kubectl get pod
কমান্ডের সাথে আগের মতই দেখা যাবে, কিন্তু এবার আমরা -w
যোগ করব, যা সমস্ত পরিবর্তন ঘটলে তা দেখবে।
$ kubectl get pod -w
NAME READY STATUS RESTARTS AGE
dotnet-deployment-5c9d4cc4b9-cspqd 1/1 Running 0 34m
dotnet-deployment-5c9d4cc4b9-httw6 1/1 Running 0 34m
dotnet-deployment-5c9d4cc4b9-vvdln 1/1 Running 0 34m
dotnet-deployment-85f6446977-tmbdq 0/1 ContainerCreating 0 4s
dotnet-deployment-85f6446977-tmbdq 1/1 Running 0 5s
dotnet-deployment-5c9d4cc4b9-vvdln 1/1 Terminating 0 34m
dotnet-deployment-85f6446977-lcc58 0/1 Pending 0 0s
dotnet-deployment-85f6446977-lcc58 0/1 Pending 0 0s
dotnet-deployment-85f6446977-lcc58 0/1 ContainerCreating 0 0s
dotnet-deployment-5c9d4cc4b9-vvdln 0/1 Terminating 0 34m
dotnet-deployment-85f6446977-lcc58 1/1 Running 0 6s
dotnet-deployment-5c9d4cc4b9-cspqd 1/1 Terminating 0 34m
dotnet-deployment-85f6446977-hw24v 0/1 Pending 0 0s
dotnet-deployment-85f6446977-hw24v 0/1 Pending 0 0s
dotnet-deployment-5c9d4cc4b9-cspqd 0/1 Terminating 0 34m
dotnet-deployment-5c9d4cc4b9-vvdln 0/1 Terminating 0 34m
dotnet-deployment-5c9d4cc4b9-vvdln 0/1 Terminating 0 34m
dotnet-deployment-85f6446977-hw24v 0/1 Pending 0 2s
dotnet-deployment-85f6446977-hw24v 0/1 ContainerCreating 0 2s
dotnet-deployment-5c9d4cc4b9-cspqd 0/1 Terminating 0 34m
dotnet-deployment-5c9d4cc4b9-cspqd 0/1 Terminating 0 34m
dotnet-deployment-85f6446977-hw24v 1/1 Running 0 3s
dotnet-deployment-5c9d4cc4b9-httw6 1/1 Terminating 0 34m
dotnet-deployment-5c9d4cc4b9-httw6 0/1 Terminating 0 34m
উপরের আউটপুট রোলিং আপডেট দেখায় যেমন এটি ঘটে। প্রথমত, নতুন কন্টেইনারগুলি চালু করা হয়, এবং যখন তারা চলমান হয়, পুরানো পাত্রগুলি বন্ধ করা হয়।
চলমান অ্যাপ যাচাই করুন
এই মুহুর্তে অ্যাপ্লিকেশনটি আপডেট করা হয়েছে এবং ব্যবহারকারীর অনুরোধের জন্য প্রস্তুত। আগের মতো, এটি একটি প্রক্সি ব্যবহার করে অ্যাক্সেস করা যেতে পারে।
$ kubectl proxy --port 8080
Starting to serve on 127.0.0.1:8080
এখন ওয়েব অ্যাপ্লিকেশন অ্যাক্সেস করতে ক্লাউড শেল-এ ওয়েব প্রিভিউ ব্যবহার করুন।
ওয়েব প্রিভিউ দ্বারা উত্পন্ন URL-এ নিম্নলিখিত যোগ করুন: /api/v1/namespaces/default/services/dotnet-service:8080/proxy/
। এটি এই মত কিছু দেখতে শেষ হবে:
https://8080-cs-473655782854-default.us-central1.cloudshell.dev/api/v1/namespaces/default/services/dotnet-service:8080/proxy/
নিশ্চিত করুন Kubernetes পরিষেবা লোড বিতরণ করছে
এই ইউআরএলটি বেশ কয়েকবার রিফ্রেশ করুন এবং লক্ষ্য করুন যে পরিষেবার বিভিন্ন পড জুড়ে অনুরোধগুলি ভারসাম্যপূর্ণ হওয়ার কারণে হোস্টের পরিবর্তন হয়। উপরে থেকে পডের তালিকার সাথে হোস্ট মান তুলনা করুন যে সমস্ত পড ট্র্যাফিক পাচ্ছে।
স্কেল আপ দৃষ্টান্ত
Kubernetes-এ অ্যাপ স্কেল করা সহজ। অনুসরণ কমান্ড প্রয়োগের 6 টি দৃষ্টান্ত পর্যন্ত স্থাপনার স্কেল করবে।
$ kubectl scale deployment dotnet-deployment --replicas 6
deployment.apps/dotnet-deployment scaled
এই কমান্ড দিয়ে নতুন পড এবং তাদের বর্তমান অবস্থা দেখা যাবে
kubectl get pod -w
লক্ষ্য করুন যে একই ব্রাউজার উইন্ডো রিফ্রেশ করা দেখায় যে সমস্ত নতুন পড জুড়ে ট্র্যাফিক এখন ভারসাম্যপূর্ণ হচ্ছে।
8. অভিনন্দন!
এই ল্যাবে, একটি .NET কোর নমুনা ওয়েব অ্যাপ্লিকেশন একটি বিকাশকারী পরিবেশে যাচাই করা হয়েছিল এবং পরবর্তীতে GKE ব্যবহার করে কুবারনেটে স্থাপন করা হয়েছিল। অ্যাপটি তখন যে কন্টেইনারে চলছিল তার হোস্টনাম প্রদর্শন করতে পরিবর্তন করা হয়েছিল। Kubernetes স্থাপনাটি তখন নতুন সংস্করণে আপডেট করা হয়েছিল এবং অতিরিক্ত দৃষ্টান্তগুলিতে কীভাবে লোড বিতরণ করা হয় তা প্রদর্শন করার জন্য অ্যাপটিকে স্কেল করা হয়েছিল।
.NET এবং Kubernetes সম্পর্কে আরও জানতে, এই টিউটোরিয়ালগুলি বিবেচনা করুন। আরও পরিশীলিত রাউটিং এবং স্থিতিস্থাপকতার নিদর্শনগুলির জন্য ইস্টিও পরিষেবা জাল প্রবর্তন করে এই ল্যাবে যা শিখেছিল তার উপর ভিত্তি করে এটি তৈরি করে।
9. পরিষ্কার করুন
অনিচ্ছাকৃত খরচ এড়ানোর জন্য, এই ল্যাবে তৈরি করা ক্লাস্টার এবং কন্টেইনার ইমেজ মুছে ফেলতে নিম্নলিখিত কমান্ডগুলি ব্যবহার করুন।
gcloud container clusters delete dotnet-cluster --zone ${DEFAULT_ZONE}
gcloud container images delete gcr.io/${PROJECT_ID}/aspnetapp:alpine