| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273 |
- @startuml C4_Container_Slurm_HPC_Corrigé_V2
- !include https://raw.githubusercontent.com/plantuml-stdlib/C4-PlantUML/master/C4_Container.puml
- LAYOUT_WITH_LEGEND()
- title Diagramme C4 Niveau 2: Cluster HPC Slurm (Intégration Volumes & Flux)
- ' ------------------------------------------------
- ' PERSONNES ET SYSTÈMES EXTERNES
- ' ------------------------------------------------
- Person(user, "Utilisateur HPC", "Soumet les jobs et accède à l'interface VS Code.")
- System_Boundary(slurm_cluster, "Cluster HPC Slurm (Réseau mpinet)") {
- ' ------------------------------------------------
- ' COMPOSANT LOGIQUE DE PARTAGE
- ' ------------------------------------------------
- Container(shared_storage, "Volumes et Secrets Partagés", "Volumes Docker Swarm / Secrets", "Contient: etc_munge, slurm_jobdir, Secrets SSH/MPI, usrlocalvarmpi-foo.")
- ' ------------------------------------------------
- ' CONTENEURS DE CONTRÔLE SLURM
- ' ------------------------------------------------
-
- Container(slurm_ctld, "slurmctld (Contrôleur Principal)", "C/C++", "Démon de contrôle. Point d'entrée pour la soumission de jobs.")
- Container(slurm_dbd, "slurmdbd (Démon Comptabilité)", "C/C++", "Gère la comptabilité des travaux.")
-
- ' ------------------------------------------------
- ' CONTENEUR DE STOCKAGE
- ' ------------------------------------------------
-
- ContainerDb(mariadb, "mysql (MariaDB)", "MariaDB 10.10", "Base de données de comptabilité.")
-
- ' ------------------------------------------------
- ' CONTENEURS DE CALCUL (Nœuds de Travail)
- ' ------------------------------------------------
-
- Container(c_nodes, "Nœuds de Calcul (c1-c4)", "C/C++", "Démons Slurmd. Exécutent les tâches HPC/MPI.")
- ' ------------------------------------------------
- ' CONTENEUR D'INTERFACE UTILISATEUR
- ' ------------------------------------------------
-
- Container(vscode, "vscode (Code Server)", "Node.js/Go", "IDE Web pour le développement et l'édition de code.", $tags="Go")
- }
- ' ------------------------------------------------
- ' RELATIONS MAJEURES
- ' ------------------------------------------------
- ' 1. Flux Utilisateur (Accès et Soumission)
- Rel(user, vscode, "Accès à l'IDE (Ports 8081:8080)", "HTTPS/HTTP")
- Rel_L(user, slurm_ctld, "Soumission de Jobs (Shell sur slurmctld)", "SSH/CLI (via vscode ou autre)")
- ' 2. Flux de Contrôle SLURM
- Rel(slurm_ctld, slurm_dbd, "Envoi des données de comptabilité", "Port 6819")
- Rel(slurm_dbd, mariadb, "Lecture/Écriture des données de comptabilité", "TCP 3306")
- Rel(slurm_ctld, c_nodes, "Allocation de Ressources / Lancement des Jobs (slurmd)", "Port 6818")
- ' 3. Flux de Données et Sécurité (Munge/Secrets/Jobs)
- Rel(slurm_ctld, shared_storage, "Accès aux fichiers de configuration et secrets (munge, SSH)")
- Rel(c_nodes, shared_storage, "Accès aux binaires/données de job (slurm_jobdir) et secrets")
- ' 4. Flux de Développement/Couplage VS Code
- Rel(vscode, shared_storage, "Lecture/Écriture Code (mpishare) & Secrets SSH", "Montage de Volume")
- Rel(vscode, slurm_ctld, "Accès Shell pour compilation/sbatch", "SSH/CLI")
- ' 5. Flux de Calcul
- Rel(c_nodes, c_nodes, "Communication Inter-Nœuds (MPI)", "Réseau mpinet")
- @enduml
|