Crea y actualiza contadores en Bigtable
Aprende a crear y actualizar contadores en Bigtable con agregados, celdas de tablas que agregan valores en el momento de la escritura. En esta guía de inicio rápido, se usan Google Cloud CLI y la CLI de cbt para crear tres contadores:
- Un contador que mantiene una suma acumulada
- Es un contador que registra el mínimo de todos los valores agregados.
- Es un contador que registra el máximo de todos los valores agregados.
Antes de comenzar
-
Sign in to your Google Account.
If you don't already have one, sign up for a new account.
-
Install the Google Cloud CLI.
-
Si usas un proveedor de identidad externo (IdP), primero debes acceder a gcloud CLI con tu identidad federada.
-
Para inicializar gcloud CLI, ejecuta el siguiente comando:
gcloud init -
Después de inicializar gcloud CLI, actualízala y, luego, instala los componentes necesarios:
gcloud components update gcloud components install cbt
-
Create or select a Google Cloud project.
Roles required to select or create a project
- Select a project: Selecting a project doesn't require a specific IAM role—you can select any project that you've been granted a role on.
-
Create a project: To create a project, you need the Project Creator
(
roles/resourcemanager.projectCreator), which contains theresourcemanager.projects.createpermission. Learn how to grant roles.
-
Create a Google Cloud project:
gcloud projects create PROJECT_ID
Replace
PROJECT_IDwith a name for the Google Cloud project you are creating. -
Select the Google Cloud project that you created:
gcloud config set project PROJECT_ID
Replace
PROJECT_IDwith your Google Cloud project name.
-
Verify that billing is enabled for your Google Cloud project.
-
Enable the Cloud Bigtable API and Cloud Bigtable Admin API APIs:
Roles required to enable APIs
To enable APIs, you need the Service Usage Admin IAM role (
roles/serviceusage.serviceUsageAdmin), which contains theserviceusage.services.enablepermission. Learn how to grant roles.gcloud services enable bigtable.googleapis.com
bigtableadmin.googleapis.com -
Install the Google Cloud CLI.
-
Si usas un proveedor de identidad externo (IdP), primero debes acceder a gcloud CLI con tu identidad federada.
-
Para inicializar gcloud CLI, ejecuta el siguiente comando:
gcloud init -
Después de inicializar gcloud CLI, actualízala y, luego, instala los componentes necesarios:
gcloud components update gcloud components install cbt
-
Create or select a Google Cloud project.
Roles required to select or create a project
- Select a project: Selecting a project doesn't require a specific IAM role—you can select any project that you've been granted a role on.
-
Create a project: To create a project, you need the Project Creator
(
roles/resourcemanager.projectCreator), which contains theresourcemanager.projects.createpermission. Learn how to grant roles.
-
Create a Google Cloud project:
gcloud projects create PROJECT_ID
Replace
PROJECT_IDwith a name for the Google Cloud project you are creating. -
Select the Google Cloud project that you created:
gcloud config set project PROJECT_ID
Replace
PROJECT_IDwith your Google Cloud project name.
-
Verify that billing is enabled for your Google Cloud project.
-
Enable the Cloud Bigtable API and Cloud Bigtable Admin API APIs:
Roles required to enable APIs
To enable APIs, you need the Service Usage Admin IAM role (
roles/serviceusage.serviceUsageAdmin), which contains theserviceusage.services.enablepermission. Learn how to grant roles.gcloud services enable bigtable.googleapis.com
bigtableadmin.googleapis.com - Ejecuta los siguientes comandos para asegurarte de que gcloud CLI esté actualizada y que incluya la CLI de
cbt:gcloud components updategcloud components install cbt Usa el comando
bigtable instances createpara crear una instancia.gcloud bigtable instances create counters-quickstart-instance \ --display-name="Counters quickstart instance" \ --cluster-config=id="counters-quickstart-cluster",zone="us-east1-c"Configura la CLI de
cbtpara que use tu instancia y proyecto. Para ello, crea un archivo.cbtrc.echo project = PROJECT_ID >> ~/.cbtrc && echo instance = counters-quickstart-instance >> ~/.cbtrcReemplaza PROJECT_ID por el ID del proyecto que estás usando.
Verifica que hayas configurado correctamente el archivo
.cbtrc.cat ~/.cbtrcLa terminal muestra el contenido del archivo
.cbtrc, que es similar a lo siguiente:project = PROJECT_ID instance = counters-quickstart-instance
Ahora puedes usar la CLI de
cbtcon tu instancia.Usa el comando
cbt createtablepara crear una tabla llamadacounters_quickstart_tableque tenga tres familias de columnas agregadas. Configura cada familia de columnas con un tipo de agregación diferente:- La familia de columnas
max_familyes de tipoMaxcon un tipo de entrada deInteger. - La familia de columnas
min_familyes de tipoMincon un tipo de entrada deInteger. - La familia de columnas
sum_familyes de tipoSumcon un tipo de entrada deInteger.
cbt createtable counters_quickstart_table families=sum_family:never:intsum,min_family:never:intmin,max_family:never:intmax- La familia de columnas
Ejecuta el comando
cbt lspara generar una lista de tus familias de columnas.cbt ls counters_quickstart_tableLa shell muestra un resultado similar al siguiente:
Family Name GC Policy ----------- --------- max_family <never> min_family <never> sum_family <never>Usa el comando
cbt addtocellpara escribir un valor inicial de5en una columna nueva de cada una de las tres familias de columnas, con una clave de fila derow-key1y una marca de tiempo de0. Esta operación crea celdas de agregación, que se usan como contadores.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@0Para ver los valores del contador como números enteros en lugar de bytes, define un archivo
yamlque la CLI decbtpueda usar para dar formato al resultado. Ejecuta lo siguiente: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.yamlVerifica que hayas configurado correctamente el archivo
cbtformat.yaml.cat ~/cbtformat.yamlLa terminal muestra el contenido del archivo
cbtformat.yaml, que es similar a lo siguiente:families: max_family: default_encoding: BigEndian default_type: INT64 min_family: default_encoding: BigEndian default_type: INT64 sum_family: default_encoding: BigEndian default_type: INT64Usa el comando
cbt readpara pasar el archivoyamly leer los datos que agregaste a la tabla. Ahora, la tabla tiene tres columnas, cada una con un tipo de agregación diferente.cbt read counters_quickstart_table format-file=$HOME/cbtformat.yamlLa shell muestra un resultado similar al siguiente. Los valores tienen formato de números enteros y las marcas de tiempo están en formato UTC.
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 5Agrega un valor de 3 a cada columna de la tabla con las mismas marcas de tiempo que usaste cuando creaste las celdas. En cada columna, el valor de la celda se combina con el valor existente según el tipo de agregación de la celda.
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@0Vuelve a usar el comando
cbt readpara leer los datos de la tabla. Cada celda ahora contiene un valor agregado.cbt read counters_quickstart_table format-file=$HOME/cbtformat.yamlsum_columncontiene la suma de 5 y 3 (8),min_columncontiene el mínimo de los dos valores que se escribieron en él (3) ymax_columncontiene el máximo de los dos valores que se escribieron en él (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 8Opcional: Consulta la tabla en la consola de Google Cloud con SQL.
En la consola de Google Cloud , abre la página Instancias de Bigtable.
Selecciona
counters-quickstart-instanceen la lista.En el menú de navegación, haz clic en Bigtable Studio.
Haz clic en la pestaña Editor.
Pega esta consulta en el editor:
SELECT * FROM `counters_quickstart_table`Haz clic en Ejecutar. Los resultados de la consulta se muestran en la tabla Resultados y se ven de la siguiente manera:
_key max_family min_family sum_family row-key1 { "max_column": 5 } { "min_column": 5 } { "sum_column": 8 } En la terminal, borra la tabla
counters_quickstart_table:cbt deletetable counters_quickstart_tableBorra la instancia:
cbt deleteinstance counters-quickstart-instanceBorra el archivo
.cbtrc:rm ~/.cbtrcBorra el archivo de formato:
rm ~/cbtformat.yamlOpcional: Revoca credenciales desde gcloud CLI:
gcloud auth revoke
Crear una instancia de Bigtable.
Conéctate a la instancia
Crea una tabla con familias de columnas de agregación
Crea contadores en la tabla
Cómo leer los datos
Actualiza los contadores
Limpia
Para evitar que se apliquen cargos a tu cuenta de Google Cloud por los recursos que se usaron en esta página, borra el proyecto de Google Cloud que tiene los recursos.