Cluster für die Verwendung von OpenStack konfigurieren

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ügt

  • Das 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.

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 der providerID ausgeführt, die Sie in der Clusterkonfigurationsdatei angegeben haben.

Nächste Schritte