Restez organisé à l'aide des collections
Enregistrez et classez les contenus selon vos préférences.
Exemple : Application App Engine pour le langage Go
Cet exemple présente une application App Engine, écrite en Go, qui fournit une interface Web utilisant Bigtable pour évaluer le nombre de visites de votre compte Google. Elle s'exécute localement dans un conteneur Docker ou dans le cloud dans l'environnement flexible d'App Engine. Le code de cette application se trouve dans le dépôt GitHub GoogleCloudPlatform/golang-samples, dans le répertoire bigtable/usercounter.
Présentation de l'exemple de code
Lorsque l'exemple de code est lancé, il crée un client d'administration pour Bigtable. Il utilise ensuite le client pour rechercher dans l'instance Bigtable spécifiée par l'utilisateur une table nommée user-visit-counter, qui comporte une seule famille de colonnes nommée emails. Si nécessaire, il crée la table et la famille de colonnes :
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()
L'exemple de code crée ensuite un seul client Bigtable qui est utilisé pour toutes les lectures et écritures suivantes :
client,err=bigtable.NewClient(ctx,project,instance)iferr!=nil{log.Fatalf("Unable to create data operations client. %v",err)}
Enfin, l'exemple de code ajoute un gestionnaire HTTP à la racine du serveur App Engine. À chaque requête, le gestionnaire invite l'utilisateur à se connecter si nécessaire. Il assure ensuite le suivi de la visite de l'utilisateur en effectuant une opération Increment sur la ligne correspondant à l'adresse e-mail de l'utilisateur :
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}}
Après avoir incrémenté la ligne, le gestionnaire affiche une page HTML indiquant le nombre total de visites de l'utilisateur actuel.
Sauf indication contraire, le contenu de cette page est régi par une licence Creative Commons Attribution 4.0, et les échantillons de code sont régis par une licence Apache 2.0. Pour en savoir plus, consultez les Règles du site Google Developers. Java est une marque déposée d'Oracle et/ou de ses sociétés affiliées.
Dernière mise à jour le 2025/09/09 (UTC).
[[["Facile à comprendre","easyToUnderstand","thumb-up"],["J'ai pu résoudre mon problème","solvedMyProblem","thumb-up"],["Autre","otherUp","thumb-up"]],[["Difficile à comprendre","hardToUnderstand","thumb-down"],["Informations ou exemple de code incorrects","incorrectInformationOrSampleCode","thumb-down"],["Il n'y a pas l'information/les exemples dont j'ai besoin","missingTheInformationSamplesINeed","thumb-down"],["Problème de traduction","translationIssue","thumb-down"],["Autre","otherDown","thumb-down"]],["Dernière mise à jour le 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."]]