Passer au contenu principal

Qu’est-ce que Launch ?

Essayer dans Colab

Avec W&B Launch, faites facilement passer vos runs d’entraînement de votre poste de travail à une ressource de calcul comme Amazon SageMaker, Kubernetes, etc. Une fois W&B Launch configuré, vous pouvez rapidement exécuter des scripts d’entraînement, des suites d’évaluation de modèles, préparer des modèles pour l’inférence en production, et bien plus encore en quelques clics et commandes.

Fonctionnement

Launch repose sur trois composants fondamentaux : les launch jobs, les files d’attente et les agents. Un launch job est un modèle permettant de configurer et d’exécuter des tâches dans votre flux de travail ML. Une fois que vous disposez d’un launch job, vous pouvez l’ajouter à une file d’attente Launch. Une file d’attente Launch est une file d’attente premier entré, premier sorti (FIFO) dans laquelle vous pouvez configurer et soumettre vos jobs à une ressource de calcul cible spécifique, comme Amazon SageMaker ou un cluster Kubernetes. À mesure que des jobs sont ajoutés à la file d’attente, les agents Launch interrogent cette file d’attente et exécutent le job sur le système ciblé par celle-ci.
Schéma d’aperçu de W&B Launch
Selon votre cas d’usage, vous (ou un membre de votre équipe) configurerez la file d’attente Launch en fonction de la ressource de calcul cible choisie (par exemple, Amazon SageMaker) et déploierez un agent Launch sur votre propre infrastructure. Voir la page Termes et concepts pour plus d’informations sur Launch.

Pour bien démarrer

Selon votre cas d’usage, explorez les ressources suivantes pour bien démarrer avec W&B Launch :

Guide pas à pas

Cette page présente les bases du flux de travail W&B Launch.
W&B Launch exécute des charges de travail d’apprentissage automatique dans des conteneurs. Il n’est pas nécessaire de connaître les conteneurs, mais cela peut être utile pour ce guide pas à pas. Voir la documentation Docker pour une introduction aux conteneurs.

Prérequis

Avant de commencer, assurez-vous de satisfaire aux prérequis suivants :
  1. Créez un compte sur https://wandb.ai/site, puis connectez-vous à votre compte W&B.
  2. Ce guide pas à pas nécessite un accès au terminal d’une machine sur laquelle la CLI Docker et le moteur fonctionnent correctement. Voir le guide d’installation de Docker pour plus d’informations.
  3. Installez W&B Python SDK version 0.17.1 ou ultérieure :
    pip install wandb>=0.17.1
    
  4. Dans votre terminal, exécutez wandb login ou définissez la variable d’environnement WANDB_API_KEY pour vous authentifier auprès de W&B.
Dans votre terminal, exécutez :
wandb login

Créer un launch job

Créez un launch job de l’une des trois façons suivantes : avec une image Docker, à partir d’un dépôt Git ou à partir de code source local :
Pour exécuter un conteneur prêt à l’emploi qui enregistre un message dans W&B, ouvrez un terminal et exécutez la commande suivante :
wandb launch --docker-image wandb/job_hello_world:main --project launch-quickstart
La commande précédente télécharge et exécute l’image de conteneur wandb/job_hello_world:main.Launch configure le conteneur pour envoyer au projet launch-quickstart tout ce qui est enregistré avec wandb. Le conteneur enregistre un message dans W&B et affiche un lien vers le run nouvellement créé dans W&B. Cliquez sur le lien pour afficher le run dans l’UI W&B.

Créer une file d’attente

Launch est conçu pour aider les équipes à créer des flux de travail autour de ressources de calcul partagées. Dans les exemples précédents, la commande wandb launch a exécuté un conteneur de manière synchrone sur la machine locale. Les files d’attente Launch et les agents permettent l’exécution asynchrone de jobs sur des ressources partagées, ainsi que des fonctionnalités avancées comme la priorisation et l’optimisation des hyperparamètres. Pour créer une file d’attente simple, suivez ces étapes :
  1. Accédez à wandb.ai/launch et cliquez sur le bouton Créer une file d’attente.
  2. Sélectionnez une Entité à associer à la file d’attente.
  3. Saisissez un Nom de la file d’attente.
  4. Sélectionnez Docker comme Ressource.
  5. Laissez le champ Configuration vide pour le moment.
  6. Cliquez sur Créer une file d’attente :rocket:
Après avoir cliqué sur le bouton, le navigateur vous redirige vers l’onglet Agents de la vue de la file d’attente. La file d’attente reste dans l’état Inactive jusqu’à ce qu’un agent commence à l’interroger.
Création d’une file d’attente Docker
Pour les options avancées de configuration de la file d’attente, voir la page de configuration avancée de la file d’attente.

Connecter un agent à la file d’attente

La vue de la file d’attente affiche un bouton Add an agent dans une bannière rouge en haut de l’écran si la file d’attente n’a aucun agent de sondage. Cliquez sur ce bouton pour afficher et copier la commande permettant d’exécuter un agent. La commande doit ressembler à ceci :
wandb launch-agent --queue <queue-name> --entity <entity-name>
Exécutez la commande dans un terminal pour démarrer l’agent. L’agent interroge la file d’attente spécifiée pour trouver les jobs à exécuter. Une fois le job reçu, l’agent télécharge ou construit, puis exécute une image de conteneur pour le job, comme si la commande wandb launch avait été exécutée localement. Revenez à la page Launch et vérifiez que la file d’attente s’affiche désormais comme Active.

Soumettre un job à la file d’attente

Accédez à votre nouveau projet launch-quickstart dans votre compte W&B, puis ouvrez l’onglet des jobs dans la navigation à gauche de l’écran. La page Jobs affiche une liste de jobs W&B créés à partir de runs exécutés précédemment. Cliquez sur votre launch job pour afficher le code source, les dépendances et tous les runs créés à partir de ce job. Une fois ce guide pas à pas terminé, la liste devrait contenir trois jobs. Choisissez l’un des nouveaux jobs et suivez ces instructions pour le soumettre à la file d’attente :
  1. Cliquez sur le bouton Launch pour soumettre le job à une file d’attente. Le panneau Launch s’affiche.
  2. Sélectionnez la Queue que vous avez créée précédemment, puis cliquez sur Launch.
Cette action soumet le job à la file d’attente. L’agent qui interroge cette file d’attente le récupère et l’exécute. Vous pouvez suivre la progression du job dans l’UI W&B ou en inspectant la sortie de l’agent dans le terminal. La commande wandb launch peut envoyer des jobs directement vers la file d’attente en spécifiant l’argument --queue. Par exemple, pour soumettre à la file d’attente le job de conteneur hello-world, exécutez la commande suivante :
   wandb launch --docker-image wandb/job_hello_world:main --project launch-quickstart --queue <queue-name>