Google Distributed Cloud unterstützt die Verwendung von OpenStack als private Cloud-Plattform. In diesem Leitfaden wird beschrieben, wie Sie einen Google Distributed Cloud-Cluster für die Zusammenarbeit mit einem externen Cloud-Anbieter konfigurieren. Wenn Sie Google Distributed Cloud-Cluster in OpenStack ausführen, können Sie die folgenden OpenStack-Dienste nutzen:
Infrastructure as a Service (IaaS)
Load balancing as a Service (LBaaS)
Speicher
So konfigurieren Sie einen Cluster für OpenStack:
Beim Erstellen des Clusters fügen Sie die Annotation
baremetal.cluster.gke.io/external-cloud-provider
hinzu.Diese Annotation bewirkt, dass Google Distributed Cloud ein Kubelet-Flag
cloud-provider=external
hinzufügtDas Kubelet fügt den Clusterknoten dann
node.cloudprovider.kubernetes.io/uninitialized:NoSchedule
-Markierungen hinzu
Mit dieser Konfiguration können Sie und OpenStack Inhaber der Init-Prozesse des Knotens sein. Sie können beispielsweise Google Distributed Cloud auf OpenStack bereitstellen, um automatisch LBaaS-Ressourcen (OpenStack Load Balancing as a Service) bereitzustellen oder andere OpenStack-Funktionen zu nutzen. Die LBaaS-Ressourcen können die MetalLB-Ressourcen ersetzen, um Dienste, die in Ihren Google Distributed Cloud-Clustern ausgeführt werden, für andere OpenStack-Mandanten oder außerhalb des OpenStack-Netzwerks verfügbar zu machen. Weitere Informationen zu den Features und Vorteilen von OpenStack finden Sie in der OpenStack-Dokumentation.
Ähnliche Beispiele
In diesem Dokument wird nur beschrieben, wie Sie Ihren Cluster für die Verwendung mit OpenStack konfigurieren. Im Folgenden werden Sie durch eine Beispielbereitstellung geführt:
Unter Google Distributed Cloud-Cluster auf OpenStack bereitstellen wird die Beispielbereitstellung eines Google Distributed Cloud-Hybridclusters auf virtuellen Maschinen (VMs) von OpenStack beschrieben. Die Bereitstellung vereinfacht die Installation mithilfe eines Skripts. Außerdem erfahren Sie, wie Sie Load Balancing as a Service (LBaaS) aktivieren können.
Unter OpenStack Cloud Provider für Kubernetes konfigurieren erfahren Sie, wie Sie den OpenStack Cloud Provider auf einem Google Distributed Cloud-Cluster installieren, der auf OpenStack bereitgestellt wurde. Der OpenStack-Cloud-Anbieter ist nicht erforderlich, um Google Distributed Cloud mit OpenStack zu verwenden.
Hinweise
Entscheiden Sie, welche GKE-Cluster OpenStack LBaaS-Ressourcen verwenden müssen.
Nachdem Sie einen Cluster erstellt haben, der für die Verwendung von OpenStack-LBaaS-Ressourcen konfiguriert ist, können Sie die Konfiguration nicht mehr ändern, um zu MetalLB-Ressourcen zu wechseln. Achten Sie darauf, dass Sie Ihre Cluster mit der richtigen Cloud-Anbieterkonfiguration initialisieren.
Achten Sie darauf, dass Sie Zugriff auf die Maschinen haben, die Sie konfigurieren möchten.
Weitere Informationen zum Ausführen von cloud-controller-manager finden Sie in der Kubernetes-Dokumentation.
Clusterkonfigurationsdatei ändern
Der Cloud-Anbieter von OpenStack erfordert, dass kubelet
auf allen Knoten mit dem folgenden Argument ausgeführt wird:
cloud-provider: "external"
Damit Ihr GKE-Cluster diese Anforderung erfüllt, fügen Sie der Clusterkonfigurationsdatei im Abschnitt „Metadaten“ die Annotation baremetal.cluster.gke.io/external-cloud-provider: "true"
hinzu, bevor Sie den Cluster erstellen.
Der Eintrag in Ihrer Konfigurationsdatei sollte folgendermaßen aussehen:
apiVersion: baremetal.cluster.gke.io/v1
kind: Cluster
metadata:
name: cluster1
namespace: cluster-cluster1
annotations:
baremetal.cluster.gke.io/external-cloud-provider: "true"
spec:
...
Einige Cloud-Anbieter auf anderen Cloud-Plattformen benötigen ein spezielles Format für providerID
. Google Distributed Cloud generiert für jede Knotenmaschine eine providerID
mit einem Format wie baremetal://MACHINE_ADDRESS
. Wenn Sie eine andere providerID
verwenden möchten, können Sie eine für jeden Knoten zusammen mit der IP-Adresse angeben.
Die folgende Beispielclusterkonfigurationsdatei zeigt, wie Sie providerID
für Ihre Clusterknoten angeben:
apiVersion: baremetal.cluster.gke.io/v1
kind: Cluster
metadata:
name: cluster1
namespace: cluster-cluster1
spec:
clusterNetwork:
pods:
cidrBlocks:
- 192.168.0.0/16
services:
cidrBlocks:
- 10.96.0.0/20
controlPlane:
nodePoolSpec:
nodes:
- address: 10.200.0.1
+ providerID: some-prefix://unique-string
- address: 10.200.0.2
+ providerID: some-prefix2://unique-string2
...
---
apiVersion: baremetal.cluster.gke.io/v1
kind: NodePool
metadata:
name: nodepool1
namespace: cluster-cluster1
spec:
clusterName: cluster1
nodes:
- address: 172.18.0.2
+ providerID: some-prefix3://unique-string3
Cluster erstellen
Nachdem Sie die Konfigurationsdatei bearbeitet haben, können Sie den folgenden Befehl ausführen, um Ihren Cluster zu initialisieren:
bmctl create cluster -c cluster1
Weitere Informationen zum Erstellen von Clustern finden Sie unter Clustererstellung – Übersicht.
Knotenkonfiguration
Wenn Sie einen für OpenStack konfigurierten Cluster erstellen, werden an den Clusterknoten folgende Änderungen vorgenommen:
Alle Knoten in
cluster1
werden mit dem erforderlichen Argument ausgeführt:cloud-provider: "external"
.Alle Knoten haben außerdem die folgende Markierung zu ihren Konfigurationsdateien:
taints: - effect: NoSchedule key: node.cloudprovider.kubernetes.io/uninitialized value: "true"
Diese Markierungen werden entfernt, nachdem Sie Ihren Cloud-Anbieter in diesem Cluster initialisiert haben.
kubelet
wird mit derproviderID
ausgeführt, die Sie in der Clusterkonfigurationsdatei angegeben haben.