Documentation Index
Fetch the complete documentation index at: https://wb-21fd5541-sandboxes-update-banner.mintlify.app/llms.txt
Use this file to discover all available pages before exploring further.
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.
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.
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.
Selon votre cas d’usage, explorez les ressources suivantes pour bien démarrer avec W&B Launch :
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.
Avant de commencer, assurez-vous de satisfaire aux prérequis suivants :
- Créez un compte sur https://wandb.ai/site, puis connectez-vous à votre compte W&B.
- 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.
- Installez W&B Python SDK version
0.17.1 ou ultérieure :
pip install wandb>=0.17.1
- 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.
Se connecter à W&B
Variable d'environnement
Dans votre terminal, exécutez : WANDB_API_KEY=<your-api-key>
Remplacez <your-api-key> par votre clé API W&B.
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. Pour lancer le même job hello-world à partir de son code source dans le dépôt de jobs W&B Launch, exécutez la commande suivante :wandb launch --uri https://github.com/wandb/launch-jobs.git \\
--job-name hello-world-git --project launch-quickstart \\
--build-context jobs/hello_world --dockerfile Dockerfile.wandb \\
--entry-point "python job.py"
La commande effectue les opérations suivantes :
- Clone le dépôt de jobs W&B Launch dans un répertoire temporaire.
- Crée un job nommé hello-world-git dans le projet hello. Ce job suit exactement le code source et la configuration utilisés pour exécuter le code.
- Construit une image de conteneur à partir du répertoire
jobs/hello_world et du Dockerfile.wandb.
- Démarre le conteneur et exécute le script Python
job.py.
La sortie de la console montre la construction de l’image et son exécution. La sortie du conteneur devrait être presque identique à celle de l’exemple précédent. Le code qui n’est pas versionné dans un dépôt Git peut être lancé en spécifiant le chemin d’un répertoire local dans l’argument --uri.Créez un répertoire vide et ajoutez un script Python nommé train.py avec le contenu suivant :import wandb
with wandb.init() as run:
run.log({"hello": "world"})
Ajoutez un fichier requirements.txt avec le contenu suivant :Depuis ce répertoire, exécutez la commande suivante :wandb launch --uri . --job-name hello-world-code --project launch-quickstart --entry-point "python train.py"
La commande effectue les opérations suivantes :
- Enregistre le contenu du répertoire actuel dans W&B en tant qu’artefact de code.
- Crée un job nommé hello-world-code dans le projet launch-quickstart.
- Construit une image de conteneur en copiant
train.py et requirements.txt dans une image de base, puis exécute pip install pour installer les dépendances.
- Démarre le conteneur et exécute
python train.py.
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 :
- Accédez à wandb.ai/launch et cliquez sur le bouton Créer une file d’attente.
- Sélectionnez une Entité à associer à la file d’attente.
- Saisissez un Nom de la file d’attente.
- Sélectionnez Docker comme Ressource.
- Laissez le champ Configuration vide pour le moment.
- 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.
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 :
- Cliquez sur le bouton Launch pour soumettre le job à une file d’attente. Le panneau Launch s’affiche.
- 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>