Zähler in Bigtable erstellen und aktualisieren
Hier erfahren Sie, wie Sie Zähler in Bigtable mit Aggregaten erstellen und aktualisieren.
Das sind Tabellenzellen, die Werte zur Schreibzeit aggregieren. In dieser Kurzanleitung werden mit der
Google Cloud CLI und der
cbt Befehlszeile
drei Zähler erstellt:
- Ein Zähler, der eine laufende Summe führt
- Ein Zähler, der den Mindestwert aller hinzugefügten Werte erfasst
- Ein Zähler, der den Höchstwert aller hinzugefügten Werte erfasst
Hinweis
-
Melden Sie sich bei Ihrem Google-Konto an.
Wenn Sie noch kein Konto haben, melden Sie sich hier für ein neues Konto an.
-
Installieren Sie die Google Cloud CLI.
-
Wenn Sie einen externen Identitätsanbieter (IdP) verwenden, müssen Sie sich zuerst mit Ihrer föderierten Identität in der gcloud CLI anmelden.
-
Führen Sie den folgenden Befehl aus, um die gcloud CLI zu initialisieren:
gcloud init -
Aktualisieren Sie die gcloud CLI nach der Initialisierung und installieren Sie die erforderlichen Komponenten:
gcloud components update gcloud components install cbt
-
Erstellen Sie ein neues Projekt oder wählen Sie ein vorhandenes Projekt Google Cloud aus.
Erforderliche Rollen zum Auswählen oder Erstellen eines Projekts
- Projekt auswählen: Für die Auswahl eines Projekts ist keine bestimmte IAM-Rolle erforderlich. Sie können ein beliebiges Projekt auswählen, für das Ihnen eine Rolle zugewiesen wurde.
-
Projekt erstellen: Zum Erstellen eines Projekts benötigen Sie die Rolle „Projektersteller“
(
roles/resourcemanager.projectCreator), die dieresourcemanager.projects.createBerechtigung enthält. Rollen zuweisen.
-
Erstellen Sie ein Google Cloud Projekt:
gcloud projects create PROJECT_ID
Ersetzen Sie
PROJECT_IDdurch einen Namen für das Google Cloud Projekt, das Sie erstellen. -
Wählen Sie das Google Cloud Projekt aus, das Sie erstellt haben:
gcloud config set project PROJECT_ID
Ersetzen Sie
PROJECT_IDdurch Ihren Google Cloud Projektnamen.
-
Prüfen Sie, ob für Ihr Google Cloud Projekt die Abrechnung aktiviert ist.
Aktivieren Sie die Cloud Bigtable API und die Cloud Bigtable Admin API:
Erforderliche Rollen zum Aktivieren von APIs
Zum Aktivieren von APIs benötigen Sie die IAM-Rolle „Service Usage-Administrator“ (
roles/serviceusage.serviceUsageAdmin), die die Berechtigungserviceusage.services.enableenthält. Rollen zuweisen.gcloud services enable bigtable.googleapis.com
bigtableadmin.googleapis.com -
Installieren Sie die Google Cloud CLI.
-
Wenn Sie einen externen Identitätsanbieter (IdP) verwenden, müssen Sie sich zuerst mit Ihrer föderierten Identität in der gcloud CLI anmelden.
-
Führen Sie den folgenden Befehl aus, um die gcloud CLI zu initialisieren:
gcloud init -
Aktualisieren Sie die gcloud CLI nach der Initialisierung und installieren Sie die erforderlichen Komponenten:
gcloud components update gcloud components install cbt
-
Erstellen Sie ein neues Projekt oder wählen Sie ein vorhandenes Projekt Google Cloud aus.
Erforderliche Rollen zum Auswählen oder Erstellen eines Projekts
- Projekt auswählen: Für die Auswahl eines Projekts ist keine bestimmte IAM-Rolle erforderlich. Sie können ein beliebiges Projekt auswählen, für das Ihnen eine Rolle zugewiesen wurde.
-
Projekt erstellen: Zum Erstellen eines Projekts benötigen Sie die Rolle „Projektersteller“
(
roles/resourcemanager.projectCreator), die dieresourcemanager.projects.createBerechtigung enthält. Rollen zuweisen.
-
Erstellen Sie ein Google Cloud Projekt:
gcloud projects create PROJECT_ID
Ersetzen Sie
PROJECT_IDdurch einen Namen für das Google Cloud Projekt, das Sie erstellen. -
Wählen Sie das Google Cloud Projekt aus, das Sie erstellt haben:
gcloud config set project PROJECT_ID
Ersetzen Sie
PROJECT_IDdurch Ihren Google Cloud Projektnamen.
-
Prüfen Sie, ob für Ihr Google Cloud Projekt die Abrechnung aktiviert ist.
Aktivieren Sie die Cloud Bigtable API und die Cloud Bigtable Admin API:
Erforderliche Rollen zum Aktivieren von APIs
Zum Aktivieren von APIs benötigen Sie die IAM-Rolle „Service Usage-Administrator“ (
roles/serviceusage.serviceUsageAdmin), die die Berechtigungserviceusage.services.enableenthält. Rollen zuweisen.gcloud services enable bigtable.googleapis.com
bigtableadmin.googleapis.com - Führen Sie die folgenden Befehle aus, um sicherzustellen, dass die gcloud CLI auf dem neuesten Stand ist und die
cbtCLI enthält:gcloud components updategcloud components install cbt
Bigtable-Instanz erstellen
Verwenden Sie den
bigtable instances createBefehl, um eine Instanz zu erstellen.gcloud bigtable instances create counters-quickstart-instance \ --display-name="Counters quickstart instance" \ --cluster-config=id="counters-quickstart-cluster",zone="us-east1-c"
Mit Instanz verbinden
Konfigurieren Sie die
cbtBefehlszeile so, dass Ihr Projekt und Ihre Instanz verwendet werden. Erstellen Sie dazu eine.cbtrcDatei.echo project = PROJECT_ID >> ~/.cbtrc && echo instance = counters-quickstart-instance >> ~/.cbtrcErsetzen Sie PROJECT_ID durch die ID des Projekts, das Sie verwenden.
Prüfen Sie, ob Sie die
.cbtrc-Datei korrekt eingerichtet haben.cat ~/.cbtrcDas Terminal zeigt den Inhalt der
.cbtrc-Datei, der in etwa so aussieht:project = PROJECT_ID instance = counters-quickstart-instance
Jetzt können Sie die
cbtBefehlszeile mit Ihrer Instanz verwenden.
Tabelle mit aggregierten Spaltenfamilien erstellen
Verwenden Sie den
cbt createtableBefehl, um eine Tabelle mit dem Namencounters_quickstart_tablezu erstellen, die drei aggregierte Spaltenfamilien enthält. Konfigurieren Sie für jede Spaltenfamilie einen anderen Aggregationstyp:- Die Spaltenfamilie
max_familyhat den TypMaxmit dem EingabetypInteger. - Die Spaltenfamilie
min_familyhat den TypMinmit dem EingabetypInteger. - Die Spaltenfamilie
sum_familyhat den TypSummit dem EingabetypInteger.
cbt createtable counters_quickstart_table families=sum_family:never:intsum,min_family:never:intmin,max_family:never:intmax- Die Spaltenfamilie
Listen Sie die Spaltenfamilien mit dem
cbt lsBefehl auf.cbt ls counters_quickstart_tableDie Shell zeigt in etwa Folgendes an:
Family Name GC Policy ----------- --------- max_family <never> min_family <never> sum_family <never>
Zähler in der Tabelle erstellen
Verwenden Sie den
cbt addtocellBefehl, um mit dem Zeilenschlüsselrow-key1und dem Zeitstempel0den Anfangswert5in eine neue Spalte in jeder der drei Spaltenfamilien zu schreiben. Bei dieser Operation werden aggregierte Zellen erstellt, die Sie als Zähler verwenden.cbt addtocell counters_quickstart_table row-key1 sum_family:sum_column=5@0 cbt addtocell counters_quickstart_table row-key1 min_family:min_column=5@0 cbt addtocell counters_quickstart_table row-key1 max_family:max_column=5@0
Daten lesen
Wenn Sie die Zählerwerte als Ganzzahlen und nicht als Byte anzeigen möchten, definieren Sie eine
yamlDatei, mit der diecbtBefehlszeile die Ausgabe formatieren kann. Führen Sie den folgenden Befehl aus:echo "families:" > cbtformat.yaml echo " max_family:" >> cbtformat.yaml echo " default_encoding: BigEndian" >> cbtformat.yaml echo " default_type: INT64" >> cbtformat.yaml echo " min_family:" >> cbtformat.yaml echo " default_encoding: BigEndian" >> cbtformat.yaml echo " default_type: INT64" >> cbtformat.yaml echo " sum_family:" >> cbtformat.yaml echo " default_encoding: BigEndian" >> cbtformat.yaml echo " default_type: INT64" >> cbtformat.yamlPrüfen Sie, ob Sie die Datei
cbtformat.yamlkorrekt eingerichtet haben.cat ~/cbtformat.yamlDas Terminal zeigt den Inhalt der Datei
cbtformat.yaml, der in etwa so aussieht:families: max_family: default_encoding: BigEndian default_type: INT64 min_family: default_encoding: BigEndian default_type: INT64 sum_family: default_encoding: BigEndian default_type: INT64Übergeben Sie die
yamlDatei mit demcbt readBefehl und lesen Sie die Daten, die Sie der Tabelle hinzugefügt haben. Die Tabelle enthält jetzt drei Spalten mit jeweils einem anderen Aggregationstyp.cbt read counters_quickstart_table format-file=$HOME/cbtformat.yamlDie Shell zeigt in etwa Folgendes an. Die Werte sind als Ganzzahlen formatiert und die Zeitstempel sind im UTC-Format.
row-key1 max_family:max_column @ 1970/01/01-00:00:00.000000 5 min_family:min_column @ 1970/01/01-00:00:00.000000 5 sum_family:sum_column @ 1970/01/01-00:00:00.000000 5
Zähler aktualisieren
Fügen Sie jeder Spalte in der Tabelle den Wert 3 hinzu. Verwenden Sie dabei dieselben Zeitstempel wie beim Erstellen der Zellen. In jeder Spalte wird der Zellenwert mit dem vorhandenen Wert zusammengeführt, basierend auf dem Aggregationstyp der Zelle.
cbt addtocell counters_quickstart_table row-key1 sum_family:sum_column=3@0 cbt addtocell counters_quickstart_table row-key1 min_family:min_column=3@0 cbt addtocell counters_quickstart_table row-key1 max_family:max_column=3@0Verwenden Sie noch einmal den Befehl
cbt read, um die Daten in der Tabelle zu lesen. Jede Zelle enthält jetzt einen aggregierten Wert.cbt read counters_quickstart_table format-file=$HOME/cbtformat.yamlDie
sum_columnenthält die Summe von 5 und 3 (8),min_columnenthält den Mindestwert der beiden Werte, die darin geschrieben wurden (3), undmax_columnenthält den Höchstwert der beiden Werte, die darin geschrieben wurden (5).row-key1 max_family:max_column @ 1970/01/01-00:00:00.000000 5 min_family:min_column @ 1970/01/01-00:00:00.000000 3 sum_family:sum_column @ 1970/01/01-00:00:00.000000 8Optional: Fragen Sie die Tabelle in der Google Cloud console mit SQL ab.
Öffnen Sie in der Google Cloud console die Seite Bigtable-Instanzen.
Wählen Sie in der Liste
counters-quickstart-instanceaus.Klicken Sie im Navigationsmenü auf Bigtable Studio.
Klicken Sie auf den Tab Editor.
Fügen Sie diese Abfrage in den Editor ein:
SELECT * FROM `counters_quickstart_table`Klicken Sie auf Ausführen. Die Ergebnisse der Abfrage werden in der Tabelle Ergebnisse angezeigt und sehen in etwa so aus:
_key max_family min_family sum_family row-key1 { "max_column": 5 } { "min_column": 5 } { "sum_column": 8 }
Bereinigen
Löschen Sie das Projekt von zusammen mit den Ressourcen, damit Ihrem Google Cloud Konto von die auf dieser Seite verwendeten Ressourcen nicht in Rechnung gestellt werden. Google Cloud
Löschen Sie im Terminal die Tabelle
counters_quickstart_table:cbt deletetable counters_quickstart_tableLöschen Sie die Instanz:
cbt deleteinstance counters-quickstart-instanceLöschen Sie die Datei
.cbtrc:rm ~/.cbtrcLöschen Sie die Formatierungsdatei:
rm ~/cbtformat.yamlOptional: Widerrufen Sie Anmeldedaten von der gcloud CLI:
gcloud auth revoke