Proiectarea Arhitecturala a Sistemelor Software

Slides:



Advertisements
Similar presentations
Exemple de bune practici în domeniul SCMI Endre-Sandor ERDŐDI, Manager public, Direcţia de politici publice.
Advertisements

Aplicatie pentru intarirea capacitatii manageriale Coriolis Consulting pentru INCD-PM Alexandru Darabont.
Sistemul integrat de raportare WISE WISE-Sistemul Informational pentru apa in Europa  reunirea tuturor informatiilor furnizate catre organismele europene.
2009 Pag Pag. 2 Agenda 1.Obiectivul proiectului 2.Parteneri 3.Autentificare versus identificare 4.Schema generala 5.Probleme de rezolvat / rezolvate.
Batalia sexelor O lume dominata de barbati vs o lume dominata de femei.
ICF Capitol Local Bine ati venit. Ore de Pregatire Continua Sesiunea 1.
Design and Architecture of Complex Software Systems Conf.dr.ing. Ioana Şora
Software Architecture and Design Dr. Aldo Dagnino ABB, Inc. US Corporate Research Center October 23 rd, 2003.
1 Microprocessor-based Systems Course 12 Distributed Systems.
-Modelul Entitate-Legatura (ER)-
Ionuţ Hrubaru: In Memory Databases Ionuţ Hrubaru: Iaşi,
Februarie 2018 ASE Bucuresti
Evolutia Calculatoarelor
Funcţii Excel definite de utilizator (FDU) în VBA
Placa de bază.
Proiectarea si Arhitectura Sistemelor Software Complexe
Instrumente CASE Curs nr. 7.
Posibilităţi de analiză în timp real a parametrilor de calitate a apei cu ajutorul sistemului informatic de management SIVECO Business Analyzer September.
Căutarea şi regăsirea informaţiei.
SOFTWARE Tipuri de software.
Dispozitive de stocare
Arhitectura serviciilor web
Calitati si tactici arhitecturale
Ionuț Dobre SSA Value co-creation from the consumer perspective Steve Baron Gary Warnaby Ionuț Dobre SSA
Căutarea şi regăsirea informaţiei.
Design and Architecture of Complex Software Systems
Paxos Made Simple Autor: Puşcaş Radu George
Proiectarea algoritmilor paraleli
Tipuri de Structuri arhitecturale. Documentarea arhitectrurii
Gestionarea datelor stiintifice
Retele de calculatoare
Reflexia luminii.
Software product management
Generarea modelelor fractale
Introducere in HCI.
CONVERSII INTRE SISTEME DE NUMERATIE
Stiluri si tipare arhitecturale fundamentale
Stiluri si tipare arhitecturale fundamentale
Crearea si gazduirea serviciilor
Tipuri structurate Tipul tablou
C# şi platforma .NET.
Curs 2 1 Sistem de operare-concepte: 2 Apeluri de sistem
Funcții C/C++ continuare
prof. mrd. Negrilescu Nicolae Colegiul National Vlaicu Voda
ANALIZA INFORMAŢIEI.
Apache WEB Server.
Continutul cursului Conceptul de arhitectura software
ADULTUL DE MIJLOC (continuare).
Crearea si gazduirea serviciilor
INTERNET SERVICII INTERNET.
Forms (Formulare).
Îmbunătăţirea serviciilor publice prin intermediul Chartelor de Servicii: Elaborarea şi implementarea Planurilor de Acţiune pentru Îmbunătăţirea Serviciilor.
A great way to create a channel of communication
Functia de documentare
SOAP -Simple Object Access Protocol-
Profilul absolventului
Cuprins Introducere in Arhitectura Software
Despre originalitate și dialog științific
Programarea in limbajul Java 2004 Lecturer: Gavrila Cristian
Realizarea prezentarilor cu Microsoft PowerPoint
Stiluri si tipare arhitecturale fundamentale
Software open source in industria software
Crearea unei aplicatii Windows Forms simple
Student:Dvornic Mihaela Grupa:342 C5
CMMI- Arii de proces: Inginerie si managementului proiectelor
Sistemul de control intern managerial
Stiluri / tipare arhitecturale
Aplicatii Web bazate pe semantica, agenti si servicii
Harti de imagini, Cadre, Stiluri
Despre lamaie.net De ce sunt lamaile acre? Realizatori: Cristina Cazan
Presentation transcript:

Proiectarea Arhitecturala a Sistemelor Software Conf.dr.ing. Ioana Şora www.cs.upt.ro/~ioana/arhit-info/ ioana.sora@cs.upt.ro

Cand este un sistem software “complex” ? Functionalitate complexa Trebuie sa indeplineasca/gaseasca un compromis intre diverse cerinte ne-functionale (“ilities”) de multe ori contradictorii Stakeholders (factorii care iau decizii care influenteaza solutia): numerosi, de naturi foarte diferite, contradictorii

Stakeholders [Bass]-Fig.1.2

Cand este un sistem software “complex” ? Functionalitate complexa Trebuie sa indeplineasca/gaseasca un compromis intre diverse cerinte ne-functionale (“ilities”) de multe ori contradictorii Stakeholders (factorii care iau decizii care influenteaza solutia): numerosi, de naturi foarte diferite, contradictorii Echipa de dezvoltare => Project management Dezvoltarea lui utilizeaza diverse tehnologii/tool-uri/infrastructuri => Adaptarea la factori impusi => Respectarea unor conventii uzuale specifice Complexitatea sistemului implica abordarea initiala la un nivel ridicat de abstractizare => “arhitectura software”

Rolul proiectului arhitecturii software Gasirea solutiei de compromis intre cerintele (contradictorii) ale diferitelor categorii de stakeholders; stabilirea calitatilor dorite (qualities) ale sistemului Proiectul arhitecturii sistemului reprezinta: Abstractizare a sistemului, care omite detalii de implementare, algoritmi si reprezentare a datelor si pune in evidenta comportarea sistemului sub forma interactiunii unor componente de tip black-box. Punct de start (project blueprint) pentru realizarea sistemului Importanta proiectului arhitecturii software: Primul pas din realizarea sistemului, efectuat in directia asigurarii calitatilor dorite ale acestuia Primul artifact care permite analiza viitorului sistem in vederea stabilirii calitatilor acestuia

Ce este si ce nu este arhitectura software? Exemplu: figura de mai jos intentioneaza sa descrie arhitectura unui sistem care simuleaza o problema de acustica subacvatica Se utilizeaza pentru descriere o notatie informala foarte “populara” de tip boxes-and-lines Ce se poate afla din aceasta figura ? Sistemul consta din 4 elemente Toate elementele prezinta relatii reciproce de o natura sau alta, diagrama este complet conectata Trei dintre elemente au probabil ceva mai multe in comun decat al 4-lea Bass – fig.2.1

Ce este si ce nu este arhitectura software? (cont) Ce NU se poate afla din aceasta figura ? Care este natura elementelor ? Care sunt responsabilitatile fiecarui element ? Care este semnificatia conexiunilor ? Care este semnificatia alinierii ? Concluzie: diagrama nu reprezinta o arhitectura software (sau cel putin nu e o reprezentare utila a unei arhitecturi software)

Arhitectura software - definitie “The software architecture is the structure or structures of the system, which comprise software elements, the externally visible properties of those elements and the relationships among them” (Bass et al) Structure(s) – there’s more than one

Arhitectura software – definitia explicata (1) “The software architecture is the structure or structures of the system, which comprise software elements, the externally visible properties of those elements and the relationships among them” (Bass et al) Elemente software: (termenul element arhit. e de preferat celui de componenta arhit.) Arhitectura este o abstractizare a sistemului Arhitectura omite anumite detalii: se exclud acele proprietati ale elementelor care nu afecteaza modul cum elementele pot fi utilizate de alte elemente sau interactiunile intre elemente Proprietati vizibile din exterior: servicii furnizate, caracteristici de performanta, utilizarea resurselor partajate de mai multe elemente, etc.

Arhitectura software – definitia explicata (2) “The software architecture is the structure or structures of the system, which comprise software elements, the externally visible properties of those elements and the relationships among them” (Bass et al) Structuri multiple: Arhitectura poate fi compusa din structuri (vederi structurale) multiple: Structura modulelor - structura statica a sistemului, rezulta in faza de design Structura interactiunilor – structura dinamica din timpul executiei sistemului Structurile allocation/deployment - Descrie modul de mapare a elementelor software pe elemente non-software (hardware, de personal)

Arhitectura software – definitia explicata (3) “The software architecture is the structure or structures of the system, which comprise software elements, the externally visible properties of those elements and the relationships among them” (Bass et al) Structuri multiple: Arhitectura poate fi compusa din structuri (vederi structurale) multiple. Implicatii: Termenii “Elemente” si “Relatii intre elemente” pot avea diferite semnificatii: Elemente pot fi: obiecte, clase, functii, procese, programe, biblioteci, etc. Relatii/Interactiuni intre elemente: subdivizare, sincronizare, apel de functie, etc.

Structurile arhitecturale multiple – Tipuri de vederi structurale (Viewtypes) Module (Design/Functional Structure) Component and Connector (Runtime) Allocation (Deployment, Physical Structure, Team Structure) Cum se descrie fiecare tip de vedere structurala ? La ce serveste fiecare tip de vedere structurala ? Cum selectez vederile relevante ?

The Module Structure: Elements & Relations Elemente: module Unitate de implementare pentru software, care reprezinta o entitate coerenta din punctul de vedere al functionalitatii Relatii: Is-part-of: A is part of B Depends on (Uses or Allowed to use) Is-a: A is a B Proprietatile elementelor: Nume: de obicei contine informatia primara din care se poate “banui” rolul sau. Numele pot fi supuse restrictiilor spatiilor de nume. Responsibilitatile: rolul modulului trebuie descris in mai multe detalii decat simplul nume Vizibilitatea interfetelor: in cazul submodulelor, se decide care dintre interfetele lor sunt sau nu vizibile din afara modulului care le contine Informatii despre implementare: nu reprezinta neaparat informatii arhitecturale dar sunt utile la acest nivel: Maparea module <-> unitati de cod de implementare (fisiere) Test & management information Implemention constraints Clements 50-51

The Module Structure: Concluzii La ce e bun tipul de vedere Module: Construction blueprints Analysis Impact analysis: prezice efectul modificarilor aduse sistemului; se bazeaza in special pe relatiile de dependenta Traceability to functional requirements: cerintele functionale sunt suportate de responsabilitatile modulelor Communication Explain functionality Relationships of system parts La ce NU e bun tipul de vedere Module: Comportamentul sistemului in timpul executiei Runtime qualities: performance, reliability, etc. => pentru analiza lor sunt necesare vederi din tipul Component-and-Connector

Component-and-Connector: Overview Reprezinta entitati care apar in timpul executiei programului Nu reprezinta unitati de implementare Analogie modelare UML: Module Viewtype <-> Class Diagrams Component&Connector ViewType <-> Object (Collaboration) Diagrams Elementele sunt numite componente si conectori Ambele categorii au semantici bine definite Conectorii NU pot fi redusi la o subcategorie de componente

Component-and-Connector: Elements& Relations Elemente: Componente – Unitati de procesare si Unitati de stocare de date Se manifesta in timpul executiei, sub forma de: procese, obiecte, clienti, servere, baze de date, etc. Porturi: “interfata” componentei la executie; puncte de (potentiala) interactiune cu mediul Tipul unei componente: defineste functionalitatea generala a acesteia, numarul si tipul porturilor, proprietatile cerute; de exemplu, o componenta de tip “filter” proceseaza fluxuri (stream) de intrare primite pe porturile de tip “input”, rezultand fluxuri de iesire la porturile “output”. Conectori – mecanisme de interactiune intre componente Se manifesta sub forma de apeluri de procedura, mesaje, evenimente, pipes Interactiunile pot fi si protocoale de comunicatie complexe, necesitand suportul infrastructurii precum middleware, sisteme de operare, etc. Roluri: “interfetele”; de exemplu, un conector pipe poate fi descris avand 2 roluri, “writer” si “reader”. Tipul unui conector: defineste natura interactiunilor, numarul si tipul rolurilor, proprietatile cerute Relatii – attachment: definesc topologia sistemului specifica ce porturi ale componentelor se leaga la anumite roluri ale conectorilor

Exemplu: structura C&C Clements 102

Informatii aduse de vederea C&C Care sunt elementele care apar in timpul executiei sistemului si interactiunile dintre ele ? Care este dinamica acestui aspect in cursul executiei ? Care sunt principalele surse de date ? Exista parti replicate in sistem ? Care sunt fluxurile de date prin sistem ? Ce protocoale de comunicatie utilizeaza elementele sistemului ? Ce categorii de proprietati ale sistemului pot fi analizate pe baza vederii C&C ? Reliability Performance Resource requirements Functionality Security

Module Viewtype – C&C Viewtype Acelasi modul poate fi executat in mai multe componente Aceeasi componenta poate executa cod din mai multe module [Clements] – fig.3.5

Allocation Structure Deployment: Work assignement: Implementation: Descrie modul de mapare a elementelor software pe elemente hardware Elemente: Componente software, definite in C&C Elemente de mediu: procesoare, elemente de stocare, de retea, etc. Relatii: Allocated-to, arata pe ce elemente de mediu sunt localizate elementele software Migrates-to, copy-migrates-to, execution-migrates-to Utilizare: analiza: performance, availability, security; estimare costuri. Work assignement: Software: module Elemente de mediu: persoana, echipa, subcontractor, etc Relati: Allocated-to Utilizare: project management Implementation: Descrie maparea modulelor pe fisiere Utilizare: Configuration control, integration, build testing

Relatia C&C - Allocation Exemplu: Vedere Combinata: 3-Tiers combina Client-Server cu Deployment [Clements] – fig.6.16

De ce e importanta arhitectura software? Pentru ca reprezinta: Mijloc de comunicare intre stakeholders Primele decizii de proiectare Abstractizare transferabila a unui sistem

Arhitectura ca mijloc de comunicare intre stakeholders Fiecare stakeholder este interesat de anumite caracteristici ale sistemului Rolul proiectantului arhitecturii: gasirea strategiilor de a echilibra caracteristicile diferite si/sau contradictorii Rolul arhitecturii: un limbaj comun in care se exprima, negociaza si rezolva aceste caracteristici Arhitectura e suficient de abstracta ca sa poata descrie la un nivel general inteligibil un sistem complex Arhitectura poat fi analizata din punct de vedere al principalelor caracteristici ale sistemului

Architectura ca decizie de proiectare Defineste unele constrangeri privind implementarea Influenteaza structura organizationala Promoveaza anumite calitati ale sistemului (modifiability, performance, safety, security, etc) Permite predictia calitatilor/proprietatilor sistemului Permite estimarea costurilor si termenelor de realizare

Arhitectura ca model transferabil, reutilizabil Reutilizarea arhitecturii - Software product lines Arhitectura poate fi realizata utilizand componente dezvoltate independent de externi

Arhitectura software Reprezinta: Ce terminologie ? De la ce se pleaca? Mijloc de comunicare intre stakeholders Primele decizii de proiectare Abstractizare transferabila a unui sistem Ce terminologie ? De la ce se pleaca? Terminologie comuna, bune practici, obiceiuri, standarde, solutii de succes cunoscute …. PATTERNS

Reference Architecture Architectural Pattern Software Architecture Concepte Reference Model Reference Architecture Design Pattern Architectural Pattern Software Architecture Architectural Style Framework

Architectural Pattern “An architectural pattern expresses a fundamental structural organization schema for software systems. It provides a set of predefined subsystems, specifies their responsibilities, and includes rules and guidelines for organizing the relationships between them.” [POSA1]/pag.12 Exemple: Model-View-Controller cu variante pentru GUI: Document-View (MFC), Model-View-Presenter sau aplicatii Web: Model-2 Broker

Architectural Style “An architectural style defines a family of software systems in terms of their structural organization. An architectural style expresses components and the relationships between them, with the constraints of their application, and the associated composition and design rules for their construction.” [POSA1]/pag.394 Exemplu: stilul Pipes-and-filters Componente: toate au acelasi tip, Filter. componente procesatoare de date, au 1 sau mai multe porturi de intrare si 1 sau mai multe porturi de iesire Relatii dintre 2 componente: conectori Pipe conector binar unidirectional care transmite fluxul de date de la un port de iesire al unui filtru spre un port de intrare al altui filtru Constrangeri si reguli: Un filtru nu trebuie sa cunoasca identitatea filtrelor de la care primeste sau la care transmite date

Relatia Architectural style ↔ Architectural pattern Unii autori [Bass] interpreteaza architectural style = architectural pattern Un stil arhitectural poate fi descris sub forma unui tipar arhitectural [POSA1] Diferente: Stilurile se refera la aspecte macro, legate de structura globala a unei aplicatii. Tiparele pot acoperi o gama larga de aspecte, de la arhitectura -> design -> limbaj Tiparele sunt mai concrete (mai orientate pe probleme concrete) Stilurile nu sunt legate de probleme sau domenii de aplicatie concrete

Design pattern “A design pattern provides a scheme for refining the subsystems of a software system, or the relationships between them. It describes a commonly-recurring structure of communicating components that solves a general design problem within a particular context. [Go4]” [POSA1]/pag.13 Tipare de scara mai mica decat cele arhitecturale Independente de un limbaj de programare (de obicei) independente de o paradigma de programare Aplicarea unor tipare din aceasta categorie nu afecteaza structura fundamentala a unui sistem

Reference Models “A reference model is a division of functionality together with data flow between the pieces. It is a standard decomposition of a known problem into parts that cooperatively solve the problem.” [Bass]/&2.3 Rezulta din experienta indelungata intr-un anumit domeniu de aplicatie Sunt caracteristice domeniilor mature Exemple: Compilatoare: analiza lexicala, analiza sintactica, analiza semantica, optimizare de cod, generare de cod, Retele: Modelul de referinta OSI

Reference Architectures “A reference architecture is a reference model mapped onto software elements (that cooperatively implement the functionality defined in the reference model) and the data flows between them.” [Bass]/&2.3 Reference model defineste o descompunere a functionalitatilor Reference architecture defineste modul de mapare a functionalitatilor pe niste definitii de subsisteme/componente Maparea poate fi 1-1 dar nu neaparat necesar Exemplu: CORBA (Common Object Request Broker Architecture)

Frameworks “A framework is a partially complete software system that is intended to be instantiated. It defines the architecture for a family of systems and provides the basic building blocks to create them.” [POSA1]/pag.396 Defineste locurile unde se pot face insertii/adaptari la instantiere: hot spots / frozen spots Instantierea: prin compunerea si subclasarea claselor furnizate de framework Diferenta framework ↔ reference architecture: un framework este dat sub forma de cod, reference architecture nu Diferenta framework ↔ biblioteca: la dezvoltarea unei aplicatii noi: biblioteca: scrii main body si utilizezi elemente (functii, clase, etc) din biblioteca framework: de obicei framework furnizeaza un main body predefinit, mai trebuie adaugate/concretizate unele elemente (functii, clase) pe care acesta le utilizeaza. “inversion of control”

Continutul cursului Conceptul de arhitectura software Ce este arhitectura software ? Stiluri arhitecturale fundamentale Pipes and filters Layers Blackboard Event-driven Arhitecturi tipice pe domenii/tipuri de aplicatii: Adaptive Reflective Distribuite Client-server, Broker Enterprise Data access Interoperability

Resurse Motivatie la motivatie: Editorii cartilor de specialitate din domeniu manifesta o tendinta in a incerca sa ne trezeasca interesul pentru subiect alegand pentru ilustrarea copertilor imagini metaforice cu tot felul de cladiri si monumente istorice