Partager via


Transformation avec Azure Databricks

S’APPLIQUE À : Azure Data Factory Azure Synapse Analytics

Conseil

Essayez Data Factory dans Microsoft Fabric, une solution d’analyse tout-en-un pour les entreprises. Microsoft Fabric couvre tous les aspects, du déplacement des données à la science des données, en passant par l’analyse en temps réel, l’aide à la décision et la création de rapports. Découvrez comment démarrer un nouvel essai gratuitement !

Dans ce tutoriel, vous allez créer un pipeline de bout en bout contenant des activités Validation, Copie des données et Notebook dans Azure Data Factory.

  • Validation garantit que le jeu de données source est prêt pour la consommation en aval avant que vous ne déclenchiez le travail de copie et d’analytique.

  • Copie des données duplique le jeu de données source dans le stockage récepteur, qui est monté en tant que DBFS dans le notebook Azure Databricks. De cette façon, le jeu de données peut directement être consommé par Spark.

  • Notebook déclenche le notebook Databricks qui transforme le jeu de données. Le jeu de données est aussi ajouté à un dossier traité ou à Azure Synapse Analytics.

Par souci de simplicité, le modèle de ce didacticiel ne crée pas de déclencheur planifié. Vous pouvez en ajouter un si nécessaire.

Diagramme du pipeline

Prérequis

  • Un compte de stockage Blob Azure avec un conteneur appelé sinkdata servant de récepteur.

    Notez le nom du compte de stockage, du conteneur et de la clé d’accès. Vous en aurez besoin plus loin dans le modèle.

  • Un espace de travail Azure Databricks.

Importer un notebook pour Transformation

Pour importer un notebook Transformation dans votre espace de travail Databricks :

  1. Connectez-vous à votre espace de travail Azure Databricks.

  2. Faites un clic droit sur un dossier dans votre espace de travail, puis sélectionnez Importer.

  3. Sélectionnez Importer depuis : URL. Dans la zone de texte, entrez https://adflabstaging1.blob.core.windows.net/share/Transformations.html.

    Sélections pour l’importation d’un notebook

  4. Nous allons maintenant mettre à jour le notebook Transformation avec vos informations de connexion au stockage.

    Dans le notebook importé, accédez à la commande 5 comme indiqué dans l’extrait de code suivant.

    • Remplacez <storage name> et <access key> par vos propres informations de connexion au stockage.
    • Utilisez le compte de stockage muni du conteneur sinkdata.
    # Supply storageName and accessKey values  
    storageName = "<storage name>"  
    accessKey = "<access key>"  
    
    try:  
      dbutils.fs.mount(  
        source = "wasbs://sinkdata\@"+storageName+".blob.core.windows.net/",  
        mount_point = "/mnt/Data Factorydata",  
        extra_configs = {"fs.azure.account.key."+storageName+".blob.core.windows.net": accessKey})  
    
    except Exception as e:  
      # The error message has a long stack track. This code tries to print just the relevant line indicating what failed.
    
    import re
    result = re.findall(r"\^\s\*Caused by:\s*\S+:\s\*(.*)\$", e.message, flags=re.MULTILINE)
    if result:
      print result[-1] \# Print only the relevant error message
    else:  
      print e \# Otherwise print the whole stack trace.  
    
  5. Générez un jeton d’accès Databricks pour permettre à Data Factory d’accéder à Databricks.

    1. Dans votre espace de travail Azure Databricks, sélectionnez votre nom d’utilisateur Azure Databricks dans la barre du haut, puis sélectionnez Paramètres dans la liste déroulante.
    2. Sélectionnez Développeur.
    3. À côté de Jetons d’accès, sélectionnez Gérer.
    4. Sélectionnez Générer un nouveau jeton.
    5. (Facultatif) Entrez un commentaire qui vous aide à identifier ce jeton à l’avenir et modifiez sa durée de vie par défaut (90 jours). Pour créer un jeton sans durée de vie (non recommandé), laissez vide la zone Durée de vie (en jours).
    6. Sélectionnez Générer.
    7. Copiez le jeton affiché dans un emplacement sécurisé, puis sélectionnez Terminé.

Enregistrez le jeton d’accès pour une utilisation ultérieure lors de la création d’un service lié à Databricks. Le jeton d’accès ressemble à dapi32db32cbb4w6eee18b7d87e45exxxxxx.

Comment utiliser ce modèle

  1. Accédez au modèle Transformation avec Azure Databricks et créez des services liés pour les connexions suivantes.

    Configuration des connexions

    • Connexion aux blobs sources : pour accéder aux données sources.

      Pour cet exemple, vous pouvez utiliser le stockage de blobs public contenant les fichiers sources. Reportez-vous à la capture d’écran suivante pour la configuration. Utilisez l’URL SAS suivante pour vous connecter au stockage source (accès en lecture seule) :

      https://storagewithdata.blob.core.windows.net/data?sv=2018-03-28&si=read%20and%20list&sr=c&sig=PuyyS6%2FKdB2JxcZN0kPlmHSBlD8uIKyzhBWmWzznkBw%3D

      Sélections pour la méthode d’authentification et l’URL SAS

    • Connexion aux blobs de destination : pour stocker les données copiées.

      Dans la fenêtre Nouveau service lié, sélectionnez votre blob de stockage du récepteur.

      Blob de stockage de récepteur comme nouveau service lié

    • Azure Databricks : pour se connecter au cluster Databricks.

      Créez un service lié à Databricks à l’aide de la clé d’accès que vous avez générée précédemment. Vous pouvez choisir de sélectionner un cluster interactif si vous en avez un. Cet exemple utilise l’option Nouveau cluster de travail.

      Sélections pour la connexion au cluster

  2. Sélectionnez Utiliser ce modèle. Vous verrez la création d’un pipeline.

    Créer un pipeline

Présentation et configuration du pipeline

Dans le nouveau pipeline, la plupart des paramètres sont configurés automatiquement avec les valeurs par défaut. Passez en revue les configurations de votre pipeline et apportez les modifications nécessaires.

  1. Dans l’indicateur de disponibilité de l’activité Validation, vérifiez que la valeur Jeu de données source est définie sur SourceAvailabilityDataset que vous avez créée précédemment.

    Valeur du jeu de données source

  2. Dans le transfert fichier à blob de l’activité Copie des données, vérifiez les onglets Source et Récepteur. Modifiez les paramètres si nécessaire.

    • OngletSource Onglet source

    • Onglet récepteur Onglet récepteur

  3. Dans Transformation de l’activité Notebook, passez en revue et mettez à jour les chemins d’accès et les paramètres selon vos besoins.

    Le service lié Databricks doit être prérempli avec la valeur d’une étape précédente, comme indiqué dans : Valeur fournie pour le service lié Databricks

    Pour vérifier les paramètres de Notebook :

    1. Sélectionnez l’onglet Paramètres. Pour Chemin d’accès du notebook, vérifiez que le chemin d’accès par défaut est correct. Vous devrez peut-être parcourir et sélectionner le chemin d’accès approprié du notebook.

      Chemin d’accès du notebook

    2. Développez le sélecteur Paramètres de base et vérifiez que les paramètres correspondent à ce qui est illustré dans la capture d’écran suivante. Ces paramètres sont transmis au notebook Databricks à partir de Data Factory.

      Paramètres de base

  4. Vérifiez que les paramètres du pipeline correspondent à ce qui est illustré dans la capture d’écran suivante : Paramètres du pipeline

  5. Connectez-vous à vos jeux de données.

    Notes

    Dans les jeux de données ci-dessous, le chemin d’accès du fichier a été automatiquement spécifié dans le modèle. Si des modifications sont nécessaires, veillez à spécifier le chemin d’accès pour conteneur et répertoire en cas d’erreur de connexion.

    • SourceAvailabilityDataset : pour vérifier si les données sources sont disponibles.

      Sélections pour le chemin d’accès du fichier et du service lié pour SourceAvailabilityDataset

    • SourceFilesDataset : pour accéder aux données sources.

      Sélections pour le chemin d’accès du fichier et du service lié pour SourceFilesDataset

    • DestinationFilesDataset : pour copier les données dans l’emplacement de destination du récepteur. Utilisez les valeurs suivantes :

      • Service lié - sinkBlob_LS, créé au cours d’une étape précédente.

      • Chemin d’accès du fichier - sinkdata/staged_sink.

        Sélections pour le chemin d’accès du fichier et du service lié pour DestinationFilesDataset

  6. Sélectionnez Déboguer pour exécuter le pipeline. Vous trouverez le lien vers les journaux Databricks permettant d’obtenir des journaux Spark plus détaillés.

    Lien vers les journaux Databricks de la sortie

    Vous pouvez également vérifier le fichier de données à l’aide d’Explorateur Stockage Azure.

    Notes

    Pour la corrélation avec les exécutions de pipeline Data Factory, cet exemple ajoute l’ID d’exécution de pipeline de la fabrique de données au dossier de sortie. Cela permet le suivi des fichiers générés par chaque exécution. Appended pipeline run ID