Sandbox Personnalisé
Le sandbox est l'endroit où l'agent effectue ses tâches. Au lieu d'exécuter des commandes directement sur votre ordinateur (ce qui pourrait être risqué), l'agent les exécute à l'intérieur d'un conteneur Docker.
Le sandbox OpenHands par défaut (python-nodejs:python3.12-nodejs22
de nikolaik/python-nodejs) est livré avec certains paquets installés tels que Python et Node.js, mais peut nécessiter l'installation d'autres logiciels par défaut.
Vous avez deux options pour la personnalisation :
- Utiliser une image existante avec les logiciels requis.
- Créer votre propre image Docker personnalisée.
Si vous choisissez la première option, vous pouvez passer la section Créer Votre Image Docker
.
Créer Votre Image Docker
Pour créer une image Docker personnalisée, elle doit être basée sur Debian.
Par exemple, si vous voulez qu'OpenHands ait ruby
installé, créez un Dockerfile
avec le contenu suivant :
FROM debian:latest
# Installer les paquets requis
RUN apt-get update && apt-get install -y ruby
Enregistrez ce fichier dans un dossier. Ensuite, construisez votre image Docker (par exemple, nommée custom-image) en naviguant vers le dossier dans le terminal et en exécutant :
docker build -t custom-image .
Cela produira une nouvelle image appelée custom-image
, qui sera disponible dans Docker.
Notez que dans la configuration décrite dans ce document, OpenHands s'exécutera en tant qu'utilisateur "openhands" à l'intérieur du sandbox et donc tous les paquets installés via le docker file devraient être disponibles pour tous les utilisateurs du système, pas seulement root.
Utiliser le Workflow de Développement
Configuration
Tout d'abord, assurez-vous de pouvoir exécuter OpenHands en suivant les instructions dans Development.md.
Spécifier l'Image de Base du Sandbox
Dans le fichier config.toml
dans le répertoire OpenHands, définissez sandbox_base_container_image
sur l'image que vous souhaitez utiliser. Cela peut être une image que vous avez déjà extraite ou une que vous avez construite :
[core]
...
sandbox_base_container_image="custom-image"
Exécuter
Exécutez OpenHands en exécutant make run
dans le répertoire de niveau supérieur.
Explication Technique
Veuillez vous référer à la section image docker personnalisée de la documentation d'exécution pour plus de détails.
Dépannage / Erreurs
Erreur : useradd: UID 1000 is not unique
Si vous voyez cette erreur dans la sortie de la console, c'est parce qu'OpenHands essaie de créer l'utilisateur openhands dans le sandbox avec un UID de 1000, mais cet UID est déjà utilisé dans l'image (pour une raison quelconque). Pour corriger cela, changez le champ sandbox_user_id dans le fichier config.toml à une valeur différente :
[core]
workspace_base="./workspace"
run_as_openhands=true
sandbox_base_container_image="custom_image"
sandbox_user_id="1001"
Erreurs d'utilisation de port
Si vous voyez une erreur concernant un port déjà utilisé ou indisponible, essayez de supprimer tous les conteneurs Docker en cours d'exécution (exécutez docker ps
et docker rm
sur les conteneurs pertinents) puis réexécutez make run
.
Discuter
Pour d'autres problèmes ou questions, rejoignez le Slack ou le Discord et demandez !