Exporter des données sous forme de colonnes Protobuf
Ce document explique comment exporter des données BigQuery sous forme de colonnes Protocol Buffers (Protobuf) en utilisants des UDF (fonctions définies par l'utilisateur) BigQuery.
Quand utiliser les colonnes Protobuf ?
BigQuery propose un certain nombre de fonctions intégrées pour formater les données sélectionnées. Une option consiste à fusionner plusieurs valeurs de colonne en une seule valeur Protobuf, ce qui présente les avantages suivants :
- Sûreté du typage d'objet.
- Amélioration de la compression, du temps de transfert des données et des coûts par rapport à JSON.
- Flexibilité, car la plupart des langages de programmation disposent de bibliothèques permettant de gérer le format Protobuf.
- Coûts réduits lors de la lecture de plusieurs colonnes pour créer un seul objet.
Bien que d'autres types de colonnes puissent également assurer la sûreté du typage, les colonnes Protobuf fournissent un objet entièrement typé, ce qui peut réduire la quantité de travail à effectuer sur la couche d'application ou dans une autre partie du pipeline.
Toutefois, l'exportation de données BigQuery sous forme de colonnes Protobuf est limitée :
- Les colonnes Protobuf ne sont pas bien indexées ni filtrées. La recherche par contenu dans des colonnes Protobuf peut s'avérer moins efficace.
- Le tri des données au format Protobuf peut s'avérer difficile.
Si ces limites s'appliquent à votre workflow d'exportation, vous pouvez envisager d'autres méthodes d'exportation de données BigQuery :
- Utilisez Dataflow pour exporter des données BigQuery aux formats de fichier Avro ou CSV.
- Utilisez des requêtes programmées pour trier vos données BigQuery exportées par date ou heure, et pour planifier des exportations de manière récurrente.
Rôles requis
Pour obtenir les autorisations nécessaires pour exporter des données BigQuery en tant que colonnes Protobuf, demandez à votre administrateur de vous accorder les rôles IAM suivants sur votre projet :
-
Créer une fonction définie par l'utilisateur :
Éditeur de données BigQuery (
roles/bigquery.dataEditor
) -
Exporter des données depuis une table BigQuery :
Lecteur de données BigQuery (
roles/bigquery.dataViewer
) -
Lire et importer des fichiers dans Cloud Storage :
Créateur d'objets de l'espace de stockage (
roles/storage.objectCreator
)
Pour en savoir plus sur l'attribution de rôles, consultez la section Gérer les accès.
Vous pouvez également obtenir les autorisations requises via des rôles personnalisés ou d'autres rôles prédéfinis.
Créer une UDF (fonction définie par l'utilisateur)
La procédure suivante montre comment créer une fonction définie par l'utilisateur qui convertit un type de données BigQuery STRUCT
en une colonne Protobuf :
Dans une ligne de commande, clonez le dépôt
bigquery-utils.git
:$ git clone https://github.com/GoogleCloudPlatform/bigquery-utils.git
Accéder au dossier d'exportation Protobuf
$ cd bigquery-utils/tools/protobuf_export
Ajoutez vos fichiers proto au dossier
./protos
.Installez les packages nécessaires à partir du dépôt GitHub :
$ npm install
Regroupez le package à l'aide de webpack :
$ npx webpack --config webpack.config.js --stats-error-details
Recherchez le fichier
pbwrapper.js
dans votre dossierdist/
et copiez-le dans un bucket Cloud Storage.Créez une fonction définie par l'utilisateur qui crée une colonne Protobuf à partir de vos colonnes BigQuery existantes :
CREATE FUNCTION DATASET_ID.toMyProtoMessage(input STRUCT<field_1 TYPE1, field_2 TYPE2>) RETURNS BYTES LANGUAGE js OPTIONS ( library=["gs://BUCKET_NAME/pbwrapper.js"] ) AS r""" let message = pbwrapper.setup("PROTO_PACKAGE.PROTO_MESSAGE") return pbwrapper.parse(message, input) """;
Remplacez les éléments suivants :
DATASET_ID
: ID de l'ensemble de données dans lequel vous stockez votre fonctionBUCKET_NAME
: nom de votre bucket Cloud StoragePROTO_PACKAGE
: nom de package de votre fichier protoPROTO_MESSAGE
: type de message de votre fichier proto
Pour plus d'informations sur l'utilisation des packages dans le langage proto, consultez la page Packages.
Formater les colonnes sous forme de valeurs Protobuf
Après avoir créé la fonction définie par l'utilisateur, exécutez-la :
SELECT DATASET_ID.toMyProtoMessage(STRUCT(COLUMN_TYPE1, COLUMN_TYPE2)) AS protoResult FROM `DATASET_NAME` LIMIT 100;
Remplacez les éléments suivants :
DATASET_ID
: ID de l'ensemble de données dans lequel vous stockez votre fonctionDATASET_NAME
: nom de votre ensemble de données, par exempledataset_name.table_name
.COLUMN_TYPE1
: nom d'une colonne. Les colonnes peuvent inclure tout type de valeur scalaire ou non scalaire compatible, y comprisARRAY
etSTRUCT
.COLUMN_TYPE2
: nom d'une colonne. Les colonnes peuvent inclure tout type de valeur scalaire ou non scalaire compatible, y comprisARRAY
etSTRUCT
.
Utiliser des valeurs Protobuf
Vos données BigQuery étant exportées au format Protobuf, vous pouvez maintenant utiliser vos données en tant que structure ou objet entièrement typé.
Les exemples de code suivants fournissent plusieurs exemples de traitement ou d'utilisation des données exportées :