helloworld:architecture:notion
Différences
Ci-dessous, les différences entre deux révisions de la page.
Les deux révisions précédentesRévision précédenteProchaine révision | Révision précédente | ||
helloworld:architecture:notion [2019/01/07 10:46] – [Définitions] : définition des connecteurs root | helloworld:architecture:notion [2020/05/10 23:46] (Version actuelle) – Suppression de la taille par défaut pour les images root | ||
---|---|---|---|
Ligne 41: | Ligne 41: | ||
=====Composition d'une architecture===== | =====Composition d'une architecture===== | ||
- | ====Définitions==== | + | ====Composant==== |
- | Composant : les composants sont visibles des autres composants exclusivement à travers des interfaces. | + | Les composants sont visibles des autres composants exclusivement à travers des interfaces. |
- | Interface | + | ===Dépendances entre composants=== |
+ | * service | ||
+ | * réalisation | ||
+ | * manifestation : nécessite un artefact pour s'exécuter / s'implémenter. | ||
- | Port : une interface | + | ===Rôles=== |
+ | Il est préférable mais pas obligatoire qu'un composant | ||
+ | * Stocker des données (composant de type Entité), | ||
+ | * Fournir des traitements (composant de type Service), | ||
+ | * Contrôle interne (composent de type Contrôleur) : aucun, exécution possible en concurrence par file d' | ||
+ | * Maintenir un contexte : gérer des informations de sessions, garder un fichier ouvert, système de cache, | ||
+ | * Interface graphique, | ||
+ | * Gestion | ||
+ | * [[helloworld: | ||
+ | * [[helloworld: | ||
- | Connecteur | + | ===Enchaînement=== |
+ | Il y a plusieurs façons d' | ||
+ | * Procédurale : deux lignes de code qui se suivent. Inconvénient : plus difficilement réutilisable dans un autre environnement / projet, | ||
+ | * Événement : A signale à B qu'il a terminé et que B peut commencer ([[helloworld: | ||
+ | * Données : quand A a terminé, il envoie | ||
+ | ====Interface==== | ||
+ | Une interface est attachée à un port de communication du composant. Il existe deux types d' | ||
+ | |||
+ | ====Port==== | ||
+ | Une interface est attachée à un port du composant, noté par un carré. Cela peut être l' | ||
+ | |||
+ | ====Connecteur==== | ||
+ | Les composants interagissent donc sur des ports, par le biais de connecteurs, | ||
* Communication : appel local ou distante, | * Communication : appel local ou distante, | ||
* Coordination : | * Coordination : | ||
Ligne 60: | Ligne 84: | ||
* Facilitation : régulation de charge, appel concurrent | * Facilitation : régulation de charge, appel concurrent | ||
- | Artefact | + | ====Artefact==== |
+ | La manifestation concrète d’un composant est appelée artefact. C’est une instance concrète du composant déployée dans l’environnement d’exécution. Voir [[helloworld: | ||
+ | |||
+ | ====Kruchten : 4+1 vues==== | ||
+ | ^Vue^Description^Diagrammes^ | ||
+ | |Logique|Composants présents et leurs interactions| Paquetages, classes, objets et structures (UML), blocs (SysML)| | ||
+ | |Réalisation|Organisation des composants concrets sur une plateforme.|Composants, | ||
+ | |Processus|Allocations et interactions entre processus, threads ou tâches.|Activités, | ||
+ | |Déploiement|Environnement d' | ||
+ | |Cas d' | ||
+ | |||
+ | {{ : | ||
+ | |||
+ | {{ : | ||
+ | |||
+ | =====Qualité===== | ||
+ | ====Généralités===== | ||
+ | * Interfaces simples, claires, stables et complètes, | ||
+ | * Dépendances faibles entre les constituants, | ||
+ | * Complexité interne masquée par les interfaces, | ||
+ | * Modularité, | ||
+ | * Facilité d’intégration, | ||
+ | * Durée de vie, upgradablité (remplacement d’une technologie par une autre). | ||
+ | |||
+ | ====Couplage==== | ||
+ | Le couplage reprendre le niveau d' | ||
+ | |||
+ | Selon Pressman, 7 niveaux de couplage, classé par niveau de dépendances, | ||
+ | ^Couplage^Description^ | ||
+ | |Sans couplage|Les composants n' | ||
+ | |Par données|Les composants échangent de l' | ||
+ | |Par paquet|Les composants échangent de l' | ||
+ | |Par contrôle|Les composants se passent ou modifient leur contrôle par modification d'un drapeau interne au composant invoqué (verrou).| | ||
+ | |Externe|Les composants échangent de l' | ||
+ | |Commun (global)|Les composants échangent de l' | ||
+ | |Par contenu (interne)|Les composants échangent de l' | ||
+ | |||
+ | ====Cohésion==== | ||
+ | La cohésion est une mesure d' | ||
+ | |||
+ | Selon Pressman, 7 niveaux de cohésion, classé par niveau, le meilleur est le dernier : | ||
+ | ^Cohésion^Description^ | ||
+ | |Arbitraire|Absence de lien logique entre les éléments.| | ||
+ | |Logique|Les fonctions sont de même catégorie ou reliées par un ou plusieurs critères communs.| | ||
+ | |Temporelle|Les fonctions s’exécutent dans une même période de temps.| | ||
+ | |Procédurale|Les fonctions sont appelées selon une séquence bien déterminée (et non arbitrairement au gré de l’appelant).| | ||
+ | |Communicationnelle|Les fonctions ont les mêmes types d’entrées sorties.| | ||
+ | |Séquentielle|Les opérations forment des séquences d’exécution bien identifiées (la sortie de l’une est l’entrée de l’autre).| | ||
+ | |Fonctionnelle|Les fonctions contribuent à une même fonction de plus haut niveau, ou bien relèvent d’une abstraction commune.| | ||
+ | |||
+ | =====Styles===== | ||
+ | Les styles architecturaux et les pattern design sont proches. Les pattern s' | ||
+ | |||
+ | Principaux styles de base: | ||
+ | ===Architectures hiérarchique et orientée objets=== | ||
+ | |||
+ | Arborescence en arbre avec à la racine le main. Chaque descendant sont un sous-module. | ||
+ | |||
+ | {{: | ||
+ | |||
+ | [[https:// | ||
+ | |||
+ | ===Architecture à flot de données (pipe-line)=== | ||
+ | |||
+ | Exemples : [[helloworld: | ||
+ | |||
+ | {{: | ||
+ | |||
+ | [[http:// | ||
+ | |||
+ | ===Architecture avec référentiel de données (repository centric), Architecture Tableau noir (blackboard)=== | ||
+ | |||
+ | Il y a les composants accesseurs de données d’une part, qui implémentent les traitements, | ||
+ | |||
+ | Dans la version de base, les référentiels sont passifs (vocation de stockage). Dans la version tableau noir, les référentiels informent les accesseurs des modifications ([[helloworld: | ||
+ | |||
+ | {{: | ||
+ | |||
+ | [[http:// | ||
+ | |||
+ | ===Architecture à Invocation implicite=== | ||
+ | |||
+ | Voir [[helloworld: | ||
+ | |||
+ | ===Architecture multi-couches=== | ||
+ | |||
+ | Chaque couche a accès uniquement à sa (ou des) couches inférieures. | ||
+ | |||
+ | ===Architecture distribuée, | ||
- | Dépendances : | + | Ici, chaque couche n'a accès qu'au niveau N+1 et N-1. |
- | * de service : pour obtenir un service ou une information, | + | |
- | * de réalisation : implémentation par héritage, | + | |
- | * de manifestation : nécessite un artefact pour s'exécuter / s'implémenter. | + |
helloworld/architecture/notion.1546854387.txt.gz · Dernière modification : de root