Şunlar için geçerlidir: Azure Yerel 22H2'de AKS, Windows Server'da AKS
Bu kılavuzda, Azure Arc tarafından etkinleştirilen AKS'deki Kubernetes kümenizde web ön ucu ve Redis veritabanı örneği içeren çok kapsayıcılı bir uygulamanın nasıl dağıtılacağı açıklanmaktadır. Ayrıca uygulamanızı test etmeyi ve ölçeklendirmeyi de öğrenirsiniz.
Bu nasıl yapılır kılavuzu, Kubernetes kavramlarını temel olarak anlamayı varsayar. Daha fazla bilgi için bkz . Kubernetes temel kavramları.
Başlamadan önce
Aşağıdaki önkoşullara sahip olduğunuzu doğrulayın:
En az bir Linux çalışan düğümü bulunan ve çalışır durumda olan bir AKS kümesi.
Kümeye erişmek için bir kubeconfig dosyası.
AksHci PowerShell modülü yüklenir. Daha fazla bilgi için bkz . Install-AksHci.
Yordamları gerçekleştirdiğinizde:
Komutları yönetici ayrıcalıklarıyla açılan bir PowerShell penceresinde çalıştırın.
İşletim sistemine özgü iş yüklerinin uygun kapsayıcı konağına yüklendiğinden emin olun. Kubernetes kümenizde Linux ve Windows çalışan düğümlerinin bir karışımı varsa düğüm seçicileri veya toint ve toleransları kullanabilirsiniz. Daha fazla bilgi için bkz . Düğüm seçicileri, renk tonlarını ve toleransları kullanma.
Not
Bir ağı başka bir hedef kümeyle paylaşan bir hedef kümenin dağıtılması yük dengeleyici IP adresi çakışmalarına neden olabilir.
Aynı AksHciClusterNetwork nesneyi paylaşan hedef kümelerde farklı bağlantı noktaları kullanan iki iş yükü dağıtırsanız IP adresi çakışmaları oluşabilir. IP adreslerinin ve bağlantı noktası eşlemelerinin HA Proxy'si içinde ayrılma şekli nedeniyle, yinelenen IP adreslerinin atanmasına yol açabilir. Bu durumda, iş yüklerinizi yeniden dağıtana kadar bir veya iki iş yükü rastgele ağ bağlantısı sorunlarıyla karşılaşabilir. İş yüklerinizi yeniden dağıtırken, her iş yüküne bir hizmet IP adresi atayan aynı bağlantı noktasını kullanabilir veya farklı nesneler kullanan AksHciClusterNetwork hedef kümelerde iş yüklerinizi yeniden dağıtabilirsiniz.
Uygulamayı dağıtma
Kubernetes bildirim dosyası, hangi kapsayıcı görüntülerinin çalıştırıldığı gibi küme için istenen durumu tanımlar. Bu öğreticide, Azure vote uygulamasını çalıştırmak için gereken tüm nesneleri oluşturmak için bir bildirim kullanılır. Bu bildirim iki Kubernetes dağıtımı içerir: biri örnek Azure Vote Python uygulamaları için, diğeri redis örneği için. İki Kubernetes hizmeti de oluşturulur: Redis örneği için bir iç hizmet ve Azure Vote uygulamasına İnternet'ten erişmek için bir dış hizmet.
azure-vote.yaml adlı bir dosya oluşturun ve aşağıdaki YAML tanımını kopyalayıp yapıştırın:
komutunu kullanarak uygulamayı dağıtın kubectl apply ve YAML bildiriminizin adını belirtin:
kubectl apply -f azure-vote.yaml
Aşağıdaki örnek çıktı, başarıyla oluşturulan dağıtımları ve hizmetleri gösterir:
deployment "azure-vote-back" created
service "azure-vote-back" created
deployment "azure-vote-front" created
service "azure-vote-front" created
Uygulamayı test etme
Uygulama çalıştırıldığında Kubernetes hizmeti uygulamanın ön ucunu İnternet'te kullanıma sunar. Bu işlemin tamamlanması birkaç dakika sürebilir.
İlerleme durumunu kubectl get service izlemek için komutunu bağımsız değişkeniyle --watch birlikte kullanın:
kubectl get service azure-vote-front --watch
Başlangıçta, azure-vote-front hizmeti için EXTERNAL-IP beklemede olarak gösterilir:
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
azure-vote-front LoadBalancer 10.0.37.27 <pending> 80:30572/TCP 22m
EXTERNAL-IP adresi beklemedengerçek bir genel IP adresine değiştiğinde, izleme işlemini durdurmak için CTRL-Ckubectl. Aşağıdaki örnek çıktıda hizmete atanmış geçerli bir genel IP adresi gösterilmektedir:
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
azure-vote-front LoadBalancer 10.0.37.27 52.179.23.131 80:30572/TCP 24m
Azure Vote uygulamasının çalıştığını görmek için hizmetinizin dış IP adresine bir web tarayıcısı açın.
Uygulama podlarını ölçeklendirme
Azure Voting Uygulaması ön ucu ve Redis örneğinin tek bir çoğaltmasını oluşturduk. Kümenizdeki podların sayısını ve durumunu görmek için komutunu kubectl get kullanın:
kubectl get pods -n default
Aşağıdaki örnek çıktıda bir ön uç podu ve bir arka uç podu gösterilmektedir:
NAME READY STATUS RESTARTS AGE
azure-vote-back-6bdcb87f89-g2pqg 1/1 Running 0 25m
azure-vote-front-84c8bf64fc-cdq86 1/1 Running 0 25m
azure-vote-front dağıtımındaki kubectl scale Aşağıdaki örnekte ön uç podlarının sayısı 5'e çıkarılmaktadır:
Ek podların oluşturulduğunu doğrulamak için yeniden çalıştırın kubectl get pods . Yaklaşık bir dakika sonra ek podlar kümenizde kullanılabilir duruma gelir:
Diğer geliştiriciler ve uzmanlarla gerçek dünyadaki kullanım örneklerini temel alan ölçeklenebilir yapay zeka çözümleri oluşturmak için toplantı serisine katılın.