Mit Sammlungen den Überblick behalten
Sie können Inhalte basierend auf Ihren Einstellungen speichern und kategorisieren.
Beispiel: Go App Engine-Anwendung
Dieses Beispiel ist eine in Go geschriebene App Engine-Anwendung. Sie stellt eine Weboberfläche zur Verfügung, die Bigtable verwendet, um die Anzahl von Aufrufen über Ihr Google-Konto zu erfassen. Sie läuft lokal in einem Docker-Container oder in der Cloud in der flexiblen Umgebung von App Engine. Der Code für die Anwendung ist im GitHub-Repository GoogleCloudPlatform/golang-samples im Verzeichnis bigtable/usercounter enthalten.
Überblick über das Codebeispiel
Wenn das Codebeispiel ausgeführt wird, erstellt es einen administrativen Client für Bigtable. Anschließend wird mit dem Client die vom Nutzer angegebene Bigtable-Instanz auf eine Tabelle mit dem Namen user-visit-counter mit einer einzelnen Spaltenfamilie mit dem Namen emails geprüft. Wenn nötig, erstellt es die Tabelle und die Spaltenfamilie.
adminClient,err:=bigtable.NewAdminClient(ctx,project,instance)iferr!=nil{log.Fatalf("Unable to create a table admin client. %v",err)}tables,err:=adminClient.Tables(ctx)iferr!=nil{log.Fatalf("Unable to fetch table list. %v",err)}if!sliceContains(tables,tableName){iferr:=adminClient.CreateTable(ctx,tableName);err!=nil{log.Fatalf("Unable to create table: %v. %v",tableName,err)}}tblInfo,err:=adminClient.TableInfo(ctx,tableName)iferr!=nil{log.Fatalf("Unable to read info for table: %v. %v",tableName,err)}if!sliceContains(tblInfo.Families,familyName){iferr:=adminClient.CreateColumnFamily(ctx,tableName,familyName);err!=nil{log.Fatalf("Unable to create column family: %v. %v",familyName,err)}}adminClient.Close()
Das Codebeispiel erstellt dann einen einzelnen Bigtable-Client, der für alle folgenden Lese- und Schreibvorgänge verwendet wird:
client,err=bigtable.NewClient(ctx,project,instance)iferr!=nil{log.Fatalf("Unable to create data operations client. %v",err)}
Schließlich fügt das Codebeispiel zum Stamm des App Engine-Servers einen HTTP-Handler hinzu. Bei jeder Anfrage, leitet der Handler den Nutzer zum Anmelden weiter, falls nötig. Er beobachtet dann die Besuche des Nutzers, da er einen Increment-Vorgang auf die Zeile der E-Mail-Adresse des Nutzers anwendet.
tbl:=client.Open(tableName)rmw:=bigtable.NewReadModifyWrite()rmw.Increment(familyName,u.Email,1)row,err:=tbl.ApplyReadModifyWrite(ctx,u.Email,rmw)iferr!=nil{return&appError{err,"Error applying ReadModifyWrite to row: "+u.Email,http.StatusInternalServerError}}
Nach der Inkrementierung der Zeile zeigt der Handler eine HTML-Seite mit den gesamten Besuchen des aktuellen Nutzers an.
[[["Leicht verständlich","easyToUnderstand","thumb-up"],["Mein Problem wurde gelöst","solvedMyProblem","thumb-up"],["Sonstiges","otherUp","thumb-up"]],[["Schwer verständlich","hardToUnderstand","thumb-down"],["Informationen oder Beispielcode falsch","incorrectInformationOrSampleCode","thumb-down"],["Benötigte Informationen/Beispiele nicht gefunden","missingTheInformationSamplesINeed","thumb-down"],["Problem mit der Übersetzung","translationIssue","thumb-down"],["Sonstiges","otherDown","thumb-down"]],["Zuletzt aktualisiert: 2025-09-09 (UTC)."],[[["\u003cp\u003eThis is a Go-based App Engine application that uses Bigtable to track the number of visits from each user's Google account.\u003c/p\u003e\n"],["\u003cp\u003eThe application can be run locally in a Docker container or in the cloud within App Engine's flexible environment.\u003c/p\u003e\n"],["\u003cp\u003eUpon launch, the code creates a Bigtable administrative client to manage the \u003ccode\u003euser-visit-counter\u003c/code\u003e table and its \u003ccode\u003eemails\u003c/code\u003e column family, creating them if they don't exist.\u003c/p\u003e\n"],["\u003cp\u003eThe application uses a Bigtable client for reads and writes, and it includes an HTTP handler that prompts users to log in and then increments their visit count in Bigtable.\u003c/p\u003e\n"],["\u003cp\u003eThe app does not provide any access control for the user data and should be shutdown after testing.\u003c/p\u003e\n"]]],[],null,["Example: Go App Engine Application\n\nThis example is an [App Engine](/appengine) application, written in Go, that\nprovides a web interface that uses Bigtable to track the number of\nvisits from your Google account. It runs locally in a Docker container or in the\ncloud in App Engine's [flexible environment](/appengine/docs/flexible). The code for\nthis application is in the GitHub repository\n[GoogleCloudPlatform/golang-samples](https://github.com/GoogleCloudPlatform/golang-samples), in the directory\n`bigtable/usercounter`.\n| **Warning:** This application does not provide any access control for your data. Shut down the application when you are done testing.\n\nOverview of the code sample\n\nWhen the code sample is launched, it creates an administrative client for\nBigtable. It then uses the client to check the user-specified\nBigtable instance for a table named `user-visit-counter`, with a\nsingle column family named `emails`. If necessary, it creates the table and\ncolumn family: \n\n adminClient, err := bigtable.NewAdminClient(ctx, project, instance)\n if err != nil {\n \tlog.Fatalf(\"Unable to create a table admin client. %v\", err)\n }\n tables, err := adminClient.Tables(ctx)\n if err != nil {\n \tlog.Fatalf(\"Unable to fetch table list. %v\", err)\n }\n if !sliceContains(tables, tableName) {\n \tif err := adminClient.CreateTable(ctx, tableName); err != nil {\n \t\tlog.Fatalf(\"Unable to create table: %v. %v\", tableName, err)\n \t}\n }\n tblInfo, err := adminClient.TableInfo(ctx, tableName)\n if err != nil {\n \tlog.Fatalf(\"Unable to read info for table: %v. %v\", tableName, err)\n }\n if !sliceContains(tblInfo.Families, familyName) {\n \tif err := adminClient.CreateColumnFamily(ctx, tableName, familyName); err != nil {\n \t\tlog.Fatalf(\"Unable to create column family: %v. %v\", familyName, err)\n \t}\n }\n adminClient.Close()\n\nThe code sample then creates a single Bigtable client that is used\nfor all subsequent reads and writes: \n\n client, err = bigtable.NewClient(ctx, project, instance)\n if err != nil {\n \tlog.Fatalf(\"Unable to create data operations client. %v\", err)\n }\n\nFinally, the code sample adds an HTTP handler to the root of the App Engine\nserver. On each request, the handler prompts the user to log in if necessary. It\nthen tracks the user's visit by performing an `Increment` operation on the row\nfor the user's email address: \n\n tbl := client.Open(tableName)\n rmw := bigtable.NewReadModifyWrite()\n rmw.Increment(familyName, u.Email, 1)\n row, err := tbl.ApplyReadModifyWrite(ctx, u.Email, rmw)\n if err != nil {\n \treturn &appError{err, \"Error applying ReadModifyWrite to row: \" + u.Email, http.StatusInternalServerError}\n }\n\nAfter incrementing the row, the handler displays an HTML page showing the total\nnumber of visits by the current user."]]