Instanzen, Cluster und Knoten

Zur Verwendung von Bigtable erstellen Sie Instanzen, die Cluster enthalten, die mit denen Ihre Anwendungen eine Verbindung herstellen können. Jeder Cluster enthält Knoten, also Recheneinheiten, die Ihre Daten verwalten und Wartungsaufgaben ausführen.

Diese Seite enthält weitere Informationen zu Bigtable-Instanzen, -Clustern und -Knoten.

Voraussetzung dafür ist die Kenntnis der Übersicht über Bigtable.

Instanzen

Eine Bigtable-Instanz ist ein Container für Ihre Daten. Instanzen haben einen oder mehrere Cluster, die sich in verschiedenen Zonen befinden. Jeder Cluster hat mindestens einen Knoten.

Eine Tabelle gehört nicht zu einem Cluster oder Knoten, sondern zu einer Instanz. Wenn Sie eine Instanz mit mehr als einem Cluster haben, verwenden Sie die Replikation. Das bedeutet, dass Sie einem einzelnen Cluster keine Tabelle zuweisen und keine eindeutige Richtlinien für die automatische Speicherbereinigung für jeden Cluster in einer Instanz erstellen können. Sie können außerdem nicht festlegen, dass jeder Cluster einen anderen Datensatz in derselben Tabelle speichert.

Eine Instanz hat einige wichtige Eigenschaften, die Sie kennen sollten:

  • Speichertyp (SSD oder HDD)
  • Die Anwendungsprofile, die hauptsächlich für Instanzen mit Replikation verwendet werden

In den folgenden Abschnitten werden diese Eigenschaften beschrieben.

Speichertypen

Wenn Sie eine Instanz erstellen, müssen Sie auswählen, ob die Cluster der Instanz Daten auf SSD oder Festplattenlaufwerken speichern. SSD ist oft, aber nicht immer, die effizienteste und kostengünstigste Wahl.

Die Wahl zwischen SSD und HDD ist unumkehrbar und jeder Cluster in Ihrer Instanz muss denselben Speichertyp verwenden. Aus diesem Grund sollten Sie sich bei der Wahl des richtigen Speichertyps für Ihren Anwendungsfall sicher sein. Weitere Informationen, die Ihnen bei dieser Entscheidung helfen können, finden Sie unter Zwischen SSD- und HDD-Speicher wählen.

Anwendungsprofile

Nachdem Sie eine Instanz erstellt haben, verwendet Bigtable die Instanz, um Anwendungsprofile zu speichern. Bei Instanzen mit Replikation steuern Anwendungsprofile, wie Ihre Anwendungen Verbindungen zu den Clustern der Instanz herstellen.

Auch bei Instanzen ohne Replikation können Sie Anwendungsprofile verwenden, um separate Kennzeichnungen für jede Anwendung oder jede Funktion in einer Anwendung anzugeben. Sie haben dann die Möglichkeit, eigene Diagramme für jedes Anwendungsprofil in der Google Cloud Console aufzurufen.

Weitere Informationen zu Anwendungsprofilen finden Sie unter Anwendungsprofile. Unter Anwendungsprofile konfigurieren wird beschrieben, wie Anwendungsprofile einer Instanz eingerichtet werden.

Cluster

Ein Cluster stellt den Bigtable-Dienst an einem bestimmten Standort dar. Jeder Cluster gehört zu genau einer Bigtable-Instanz und eine Instanz kann Cluster in bis zu acht Regionen haben. Wenn Ihre Anwendung Anfragen an eine Bigtable-Instanz sendet, werden diese Anfragen von einem der Cluster in der Instanz verarbeitet.

Jeder Cluster befindet sich in genau einer Zone. Eine Instanz kann Cluster in bis zu acht Regionen haben, in denen Bigtable verfügbar ist. Jede Zone in einer Region kann nur einen Cluster enthalten. Wenn eine Instanz beispielsweise einen Cluster in us-east1-b hat, können Sie einen Cluster in einer anderen Zone in derselben Region, z. B. us-east1-c, oder in einer Zone in einer separaten Region wie europe-west2-a hinzufügen.

Die Anzahl der Cluster, die Sie in einer Instanz erstellen können, hängt von der Anzahl der verfügbaren Zonen in den ausgewählten Regionen ab. Wenn Sie beispielsweise Cluster in 8 Regionen mit jeweils 3 Zonen, die maximale Anzahl von Clustern die die Instanz haben kann, 24 ist. Für eine Liste der Zonen und Regionen, Bigtable ist verfügbar, siehe Bigtable-Standorte

Bigtable-Instanzen mit nur 1 Cluster nutzen nicht Replikation. Wenn Sie eine Instanz um einen zweiten Cluster erweitern, beginnt Bigtable automatisch mit der Replikation Ihrer Daten. Dazu werden in jeder Zone des Clusters separate Datenkopien gespeichert und Updates zwischen den Kopien synchronisiert. Sie können entscheiden, zu welchem Cluster Ihre Anwendungen eine Verbindung herstellen. Dadurch lassen sich verschiedene Arten von Traffic voneinander isolieren. Sie können Bigtable auch den Traffic zwischen Clustern ausgleichen lassen. Wenn ein Cluster nicht mehr verfügbar ist, kann ein Failover von einem Cluster auf einen anderen erfolgen. Weitere Informationen zur Funktionsweise der Replikation finden Sie unter Replikation – Übersicht.

In den meisten Fällen sollten Sie Autoscaling für einen sodass Bigtable Knoten nach Bedarf hinzugefügt und entfernt, um die Arbeitslasten des Clusters verarbeiten kann.

Knoten

Jeder Cluster in einer Instanz hat einen oder mehrere Knoten. Das sind Rechenressourcen, die Bigtable zur Verwaltung Ihrer Daten verwendet.

Im Hintergrund teilt Bigtable alle Daten in einer Tabelle in separate Tabellenreihen auf. Tabellenreihen werden getrennt von den Knoten auf dem Laufwerk gespeichert, jedoch in derselben Zone, in der sich die Knoten befinden. Eine Tabellenreihe ist einem einzelnen Knoten zugeordnet.

Jeder Knoten ist für Folgendes verantwortlich:

  • Nachverfolgen bestimmter Tabellenreihen auf dem Laufwerk
  • Verarbeitung eingehender Lese- und Schreibvorgänge für die ihm zugeordneten Tabellenreihen
  • Pflegen der ihm zugeordneten Tabellenreihen, z. B. durch regelmäßige Kompaktionen.

Ein Cluster muss genug Knoten haben, um seine aktuelle Arbeitslast und die Menge der gespeicherten Daten bewältigen zu können. Ansonsten ist der Cluster unter Umständen nicht in der Lage, eingehende Anfragen zu verarbeiten, was eine erhöhte Latenz zur Folge haben kann. Cluster überwachen CPU und Laufwerksnutzung und Knoten zu einer Instanz hinzufügen wenn dessen Messwerte die Empfehlungen übersteigen, Kapazität planen

Weitere Informationen dazu, wie Bigtable Daten speichert und verwaltet, finden Sie unter Architektur von Bigtable.

Knoten für replizierte Cluster

Wenn Ihre Instanz mehr als einen Cluster hat, ist ein Failover eine mögliche Option. wenn Sie die maximale Anzahl von Knoten für Autoscaling oder manuell Zuweisen der Knoten.

  • Wenn Sie in einem Ihrer Anwendungsprofil Multi-Cluster-Routing verwenden, automatischen Failover weitere Cluster sind nicht verfügbar.

  • Bei einem manuellen Failover von einem Cluster zu einem anderen oder wenn ein automatischer ein Failover auftritt, sollte der empfangende Cluster im Idealfall über genügend Kapazität die Last tragen. Sie können entweder immer genügend Knoten zur Unterstützung zuweisen Failover, was teuer werden kann, oder mithilfe von Autoscaling bei einem Traffic-Ausfall. Beachten Sie jedoch, dass dies kurze Auswirkungen während der Cluster hochskaliert wird.

  • Wenn in allen App-Profilen Single-Cluster-Routing verwendet wird, kann jeder Cluster eine andere Anzahl von Knoten haben. Passen Sie die Größe jedes Clusters nach Bedarf auf Basis seiner Arbeitslast an.

    Da Bigtable eine separate Kopie Ihrer Daten für jeden Cluster speichert, muss jeder Cluster immer genug Knoten haben, um Ihre Laufwerksnutzung zu unterstützen und Schreibvorgänge über die Cluster hinweg zu replizieren.

    Sie können bei Bedarf immer ein manuelles Failover von einem Cluster auf einen anderen anstoßen. Wenn allerdings ein Cluster sehr viel mehr Knoten als ein anderer hat und ein Failover auf den Cluster mit der geringeren Knotenanzahl erforderlich ist, müssen Sie unter Umständen zuerst Knoten hinzufügen. Es kann nicht garantiert werden, dass bei einem erforderlichen Failover ausreichend zusätzliche Knoten verfügbar sind. Die einzige Möglichkeit zur Vorabreservierung von Knoten besteht darin, den Cluster um Knoten zu erweitern.

Nächste Schritte