Tutorial - Bereitstellen Ihrer ersten Anwendung
Ziele
Dieses Tutorial führt Sie Schritt für Schritt durch die Bereitstellung Ihrer ersten Anwendung auf einem Managed Kubernetes-Cluster. Am Ende dieses Leitfadens haben Sie:
- Eine einfache Webanwendung bereitgestellt.
- Diese Anwendung innerhalb des Clusters über einen Service freigegeben.
- Die Anwendung über einen Ingress von Internet aus zugänglich gemacht.
Voraussetzungen
- Sie haben Ihren Zugriff auf den Cluster wie in der Schnellstartanleitung beschrieben konfiguriert.
- Sie verfügen über ein Namespace, in dem Sie über Bereitstellungsrechte verfügen. In diesem Tutorial verwenden wir ein Namespace mit dem Namen
hello-world.
Schritt 1: Namespace erstellen
Falls noch nicht geschehen, erstellen Sie einen Namespace, um Ihre Anwendung zu isolieren.
kubectl create namespace hello-world
Schritt 2: Bereitstellen einer "Hello World"-Anwendung
Wir stellen eine Demo-Anwendung bereit, die eine einfache Webseite anzeigt.
-
Erstellen Sie eine Datei namens
deployment.yamlmit dem folgenden Inhalt:apiVersion: apps/v1kind: Deploymentmetadata:name: hello-world-deploymentnamespace: hello-worldlabels:app: hello-worldspec:replicas: 2selector:matchLabels:app: hello-worldtemplate:metadata:labels:app: hello-worldspec:containers:- name: hello-worldimage: nginxdemos/hello:plain-textports:- containerPort: 80 -
Wenden Sie dieses Manifest auf Ihren Cluster an:
kubectl apply -f deployment.yaml -
Überprüfen Sie, ob das Deployment erstellt wurde und die Pods ausgeführt werden:
kubectl get deployment -n hello-world# Sie sollten Ihr Deployment mit 2/2 einsatzbereiten Replikaten sehen.NAME READY UP-TO-DATE AVAILABLE AGEhello-world-deployment 2/2 2 2 102skubectl get pods -n hello-world# Sie sollten zwei Pods mit dem Status "Running" sehen.NAME READY STATUS RESTARTS AGEhello-world-deployment-669dfbd799-294zz 1/1 Running 0 2m21shello-world-deployment-669dfbd799-plcbg 1/1 Running 0 2m21s
Schritt 3: Die Anwendung im Cluster exponieren (Service)
Um die verschiedenen Komponenten des Clusters mit unserer Anwendung kommunizieren zu lassen, müssen wir einen Service erstellen.
-
Erstellen Sie eine Datei mit dem Namen
service.yaml:apiVersion: v1kind: Servicemetadata:name: hello-world-servicenamespace: hello-worldspec:selector:app: hello-worldports:- protocol: TCPport: 80targetPort: 80type: ClusterIP -
Wenden Sie das Manifest an :
kubectl apply -f service.yamlIhre Anwendung ist jetzt über den Namen
hello-world-service.hello-worldvon jedem anderen Pod im Cluster aus erreichbar.
Schritt 4: Die Anwendung über das Internet zugänglich machen (Ingress)
Um unseren Dienst im Internet zugänglich zu machen, verwenden wir eine Ingress-Ressource. Das Managed Kubernetes-Angebot stellt mehrere vorkonfigurierte ingressClassName-Werte bereit. Wir verwenden nginx-external für den öffentlichen Zugriff.
-
Erstellen Sie eine Datei
ingress.yaml. Ersetzen Sievotre-cluster-iddurch die ID Ihres Clusters (z. B.ctodev).apiVersion: networking.k8s.io/v1kind: Ingressmetadata:name: hello-world-ingressnamespace: hello-worldspec:ingressClassName: nginx-externalrules:- host: "hello-world.external.votre-cluster-id.mk.ms-cloud-temple.com" # changez moihttp:paths:- path: /pathType: Prefixbackend:service:name: hello-world-serviceport:number: 80 -
Wenden Sie das Manifest an:
kubectl apply -f ingress.yaml
Schritt 5: Zugriff überprüfen
Ein DNS-Eintrag "*" leitet bereits alle URLs, die auf ".external.votre-cluster-id.mk.ms-cloud-temple.com" enden, auf die IP-Adresse des "external"-Ingresses weiter. Auf diesem DNS-Suffix veröffentlichte Anwendungen sind daher direkt erreichbar.
curl http://hello-world.external.votre-cluster-id.mk.ms-cloud-temple.com
Sie sollten eine Antwort vom Demo-NGINX-Server erhalten.
StatusCode : 200
StatusDescription : OK
Content : Server address: 10.247.1.223:80
Server name: hello-world-deployment-669dfbd799-plcbg
Date: 29/Oct/2025:15:40:04 +0000
URI: /
Request ID: 2df985e0630c3a123b5cde23b687a033
RawContent : HTTP/1.1 200 OK
Connection: keep-alive
Content-Length: 170
Cache-Control: no-cache
Content-Type: text/plain
Date: Wed, 29 Oct 2025 15:40:04 GMT
Expires: Wed, 29 Oct 2025 15:40:03 GMT
Server: ng...
:::warning[Vertiefung: Sicherheit in der Produktion ] Dieses Tutorial hat Ihnen die Grundlagen des Deployments gezeigt. Für eine Produktionsumgebung ist es entscheidend, zusätzliche Sicherheitsmaßnahmen anzuwenden:
- Verwenden Sie sichere Images: Bevorzugen Sie Images aus Ihrer gesicherten Unternehmens-Registry wie Harbor anstelle von öffentlichen Images.
- Steuern Sie den Netzwerkverkehr: Richten Sie
NetworkPoliciesein, um die Kommunikation auf die für Ihre Anwendungen erforderlichen Flüsse zu beschränken. - Wenden Sie Governance-Richtlinien an: Nutzen Sie Tools wie Kyverno, um Sicherheitsregeln durchzusetzen (z. B. das Verbot von "root"-Containern, die Anforderung von Ressourcenanfragen (
requests) und -grenzen (limits) usw.). :::
Bereinigung
Um alle Ressourcen zu löschen, die Sie während dieses Tutorials erstellt haben, können Sie einfach den Namespace löschen:
kubectl delete namespace hello-world
Herzlichen Glückwunsch, Sie haben Ihre erste Anwendung auf Managed Kubernetes bereitgestellt und freigegeben!