C4l2-configuration-CM4-20251212.txt 3.2 KB

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