18
25.9.2014 1 Arkkitehtuurin mallintaminen Luento 7 25.9.2014 1 581385 Ohjelmistoarkkitehtuurit Oppimistavoitteet Miksi ja milloin ohjelmistoarkkitehtuurista kannattaa laatia malleja? Ohjelmistoarkkitehtuurimallin ohjeellinen rakenne 25.9.2014 581385 Ohjelmistoarkkitehtuurit 2

Arkkitehtuurin mallintaminen - University of Helsinki · – 3D-mallien käyttö rakennusten suunnittelun apuna! 25.9.2014 581385 Ohjelmistoarkkitehtuurit 5 Kommutatiivinen kaavio

  • Upload
    others

  • View
    1

  • Download
    0

Embed Size (px)

Citation preview

Page 1: Arkkitehtuurin mallintaminen - University of Helsinki · – 3D-mallien käyttö rakennusten suunnittelun apuna! 25.9.2014 581385 Ohjelmistoarkkitehtuurit 5 Kommutatiivinen kaavio

25.9.2014

1

Arkkitehtuurin mallintaminen

Luento 7

25.9.2014 1581385 Ohjelmistoarkkitehtuurit

Oppimistavoitteet

• Miksi ja milloin ohjelmistoarkkitehtuuristakannattaa laatia malleja?

• Ohjelmistoarkkitehtuurimallin ohjeellinenrakenne

25.9.2014 581385 Ohjelmistoarkkitehtuurit 2

Page 2: Arkkitehtuurin mallintaminen - University of Helsinki · – 3D-mallien käyttö rakennusten suunnittelun apuna! 25.9.2014 581385 Ohjelmistoarkkitehtuurit 5 Kommutatiivinen kaavio

25.9.2014

2

MIKSI MALLEJA?

25.9.2014 581385 Ohjelmistoarkkitehtuurit 3

Malleista ja niiden käytöstä

• 1Malli =esine, kuva, kuvio, kaava tms., jonka mukaan

tehdään jtak t. josta havainnoidaan jtak. […]Erik.

[…]• b. jtak kuviona, kaaviona tm. havainnollistava esitys.

Molekyylin kolmiulotteinen malli. Atomiytimen malli.Väestön kehitystä kuvaava matemaattinen malli.

[…]

25.9.2014 581385 Ohjelmistoarkkitehtuurit 4

1MOT Sanakirja

Page 3: Arkkitehtuurin mallintaminen - University of Helsinki · – 3D-mallien käyttö rakennusten suunnittelun apuna! 25.9.2014 581385 Ohjelmistoarkkitehtuurit 5 Kommutatiivinen kaavio

25.9.2014

3

Malleista ja niiden käytöstä

• Yksinkertaiset ongelmat voidaan ratkaistasuoraan (ratkaisu on ilmeinen)

• Monimutkaiset reaalimaailman ongelmat vaativatasian kuvaamista abstraktina mallina (jokapelkistää ongelman ytimen) ja sen ratkaisemistaensin mallissa, minkä jälkeen ratkaisu siirretäänreaalimaailman implementaatioksi– Esimerkiksi matemaattisten mallien käyttö

rakenteiden lujuuslaskennassa jne.– 3D-mallien käyttö rakennusten suunnittelun apuna !

25.9.2014 581385 Ohjelmistoarkkitehtuurit 5

Kommutatiivinen kaavio

25.9.2014 581385 Ohjelmistoarkkitehtuurit 6

Reaalimaailmanongelma

Abstraktiongelma

Abstraktiratkaisu

Reaalimaailmanratkaisu

Page 4: Arkkitehtuurin mallintaminen - University of Helsinki · – 3D-mallien käyttö rakennusten suunnittelun apuna! 25.9.2014 581385 Ohjelmistoarkkitehtuurit 5 Kommutatiivinen kaavio

25.9.2014

4

Mallien käyttö

• Ongelman laajuus ja monimutkaisuus vaatiiabstrahointia– On nähtävä metsä puilta– Yksittäistä luokkaa, moduulia tai suunnittelumallin

ilmentymää laajempien kokonaisuuksienhahmottaminen ja niiden roolin ymmärtäminen

– Suuren ohjelmiston koodin lukeminen rivi riviltäsen arkkitehtuurin ymmärtämiseksi onkäytännössä mahdotonta

25.9.2014 581385 Ohjelmistoarkkitehtuurit 7

!

Mallien käyttö

• Abstraktiot pelkistävät ongelmia ja tarjoavatmahdollisuuden kehittää työkaluja– Oikein laadittu abstraktio vangitsee reaalimaailman

ongelman oleelliset piirteet, jotka vaikuttavathyväksyttävän ratkaisun muodostamiseen

• ’Turhat’ yksityiskohdat karsitaan pois– Abstraktiin malliin voidaan käyttää erityisiä työkaluja

ongelmien ratkaisemiseksi• Esim moduulien/luokkien uudelleensijoittelu

kirjastoihin/pakkauksiin haitallisiksi havaittujenriippuvuuksien karsimiseksi ja heijastusvaikutustenvähentämiseksi

25.9.2014 581385 Ohjelmistoarkkitehtuurit 8

Page 5: Arkkitehtuurin mallintaminen - University of Helsinki · – 3D-mallien käyttö rakennusten suunnittelun apuna! 25.9.2014 581385 Ohjelmistoarkkitehtuurit 5 Kommutatiivinen kaavio

25.9.2014

5

Mallien käyttö

• Mallit helpottavat päätelmien tekemistäjärjestelmän ominaisuuksista– Malli auttaa päättämään, mitkä yksityiskohdat ja

suunnittelupäätökset ovat tärkeitälaatuominaisuuksien ja niiden toteutumisenarvioinnin kannalta

– Malli voi olla luonnosmainen ja/tai pelkästäänanalysoijan mielessä

25.9.2014 581385 Ohjelmistoarkkitehtuurit 9

Web-palvelimen malliluonnos

25.9.2014 581385 Ohjelmistoarkkitehtuurit 10

Client(s) Server(s) Database(s)

Asiakkaan yksi web-sivun pyyntövoi aiheuttaa monia tietokantahakuja

Asiakkaan kokema viive pyyntöön vastaamisessa =Viestinvälitykseen kuluva aika + palvelimen pyynnön prosessointiaika +(tietokantahakuun kuluva aika x hakujen lukumäärä)

Page 6: Arkkitehtuurin mallintaminen - University of Helsinki · – 3D-mallien käyttö rakennusten suunnittelun apuna! 25.9.2014 581385 Ohjelmistoarkkitehtuurit 5 Kommutatiivinen kaavio

25.9.2014

6

Web-palvelimen malliluonnos• Kun edellisen mallin suoritusajoille annetaan

arviot (esim. 10 + 10 + n x 25ms), niin mallinperusteella on helppo nähdä, ettätietokantakyselyihin kuluva aika dominoiasiakkaan kokemaa viivettä– Normalisoitu, hierarkinen relaatiotietokanta vs.

normalisoimaton ”flat” –tietomalli• -> Tietokantahakujen määrässä on kertaluokan ero

• Malli jättää monia yksityiskohtia huomiotta(cache:t, jonotus*), mutta tällaisenaankin se onhyödyllinen analyysin kannalta

25.9.2014 581385 Ohjelmistoarkkitehtuurit 11

*) samanaikaisten pyyntöjen aiheuttaman jonotuksen ja resurssikilpailun mallintaminenei ole sekään erityisen vaikeaa oikeilla työkaluilla ja matem. mallinnusmenetelmillä

Mallien käyttö• Mallit karsivat ongelman ratkaisussa käsiteltäviä

yksityiskohtia– Malli valikoi ongelman ratkaisemisen kannalta oleelliset asiat ja

jättää muut pois– Malli on aina jossain mielessä epätäydellinen, mutta

reaalimaailman ”täydellinen malli” olisi liian suuri ja hankalakäsiteltäväksi ja käsitettäväksi

• Mallit tehostavat päätelmien ja arviointien tekemistä– Suunnittelija voi keskittyä vain pieneen joukkoon

suunnittelupäätöksiä/yksityiskohtia kerrallaan (=työmuisti jakognitio)

– Käsitteellinen tai konkreettinen malli auttaa suhteuttamaanratkaisun eri yksityiskohtia toisiinsa ja havaitsemaan jaanalysoimaan niiden välisiä riippuvuuksia ja rajoitteita

25.9.2014 581385 Ohjelmistoarkkitehtuurit 12

Page 7: Arkkitehtuurin mallintaminen - University of Helsinki · – 3D-mallien käyttö rakennusten suunnittelun apuna! 25.9.2014 581385 Ohjelmistoarkkitehtuurit 5 Kommutatiivinen kaavio

25.9.2014

7

Mallien käyttö

• Kysy ensin mitä haluat tietää ja laadi malli vastasitten– Ei malleja mallinnuksen vuoksi– Samasta asiasta voidaan laatia erilaisia malleja eri

käyttötarkoituksiin (suorituskyky, turvallisuus,riippuvuuksien hallinta jne.)

• Arkkitehtuurityössä malleista on hyötyä ja ne ovatusein jopa välttämättömiä, mutta konkreettisiamalleja pitäisi laativa vain todelliseen tarpeeseen,ei varmuuden vuoksi

25.9.2014 581385 Ohjelmistoarkkitehtuurit 13

OHJELMISTOARKKITEHTUURINMALLIT JA NIIDEN RAKENNE

25.9.2014 581385 Ohjelmistoarkkitehtuurit 14

Page 8: Arkkitehtuurin mallintaminen - University of Helsinki · – 3D-mallien käyttö rakennusten suunnittelun apuna! 25.9.2014 581385 Ohjelmistoarkkitehtuurit 5 Kommutatiivinen kaavio

25.9.2014

8

Ohjelmistoarkkitehtuurinmallintaminen

• Fairbanks esittää kanonisen1 rakenteenohjelmistoarkkitehtuurimalleille– Määrittelee minkälaisia asioita

ohjelmistoarkkitehtuurimallin pitäisi yleisestiottaen kuvata

• metamalli tai mallinnusstandardi

– Kattaa koko arkkitehtuuriratkaisun sovellusalueenkäsitteistä kooditasolle ja laitteistosijoitteluun asti

25.9.2014 581385 Ohjelmistoarkkitehtuurit 15

1) Ohjeellinen, esikuvallinen - MOT Kielitoimiston sanakirja

Ohjelmistoarkkitehtuurinmallintaminen

• Kanoninen rakenne antaa myös käsitteellisen kehyksen(conceptual model) ohjelmistoarkkitehtuurille– Kehys tukee OA:n suunnittelua ohjaamalla

suunnittelutyötä tietynlaisten kysymysten ja rakenteidenpohtimiseen

– Ohjaa jakamaan ohjelmistoa koskevien faktojen käsittelynsopivalle abstraktiotasolle

• Ei ole kuitenkaan tarkoitus, että jokaisestaohjelmistoprojektista laaditaan kanonisen rakenteenmukainen kattava kuvaus– Projektit valikoivat todellisen tarpeen mukaan, mitä osia

arkkitehtuurista mallinnetaan kanonisen metamallinsääntöjä noudattaen

25.9.2014 581385 Ohjelmistoarkkitehtuurit 16

Page 9: Arkkitehtuurin mallintaminen - University of Helsinki · – 3D-mallien käyttö rakennusten suunnittelun apuna! 25.9.2014 581385 Ohjelmistoarkkitehtuurit 5 Kommutatiivinen kaavio

25.9.2014

9

Ohjelmistoarkkitehtuurinmallintaminen

• Harhakäsityksiä– Jokaisen projektin pitää dokumentoida

arkkitehtuurinsa: väärin. Arkkitehtuurimalleja jadokumentteja kannattaa laatia vain kun ne auttavatpienentämään (projekti- ja tuote-) riskejä

– Arkkitehtuurin dokumentaation pitää olla ainakattava: väärin. Mallinnuksen pitäisi kohdistuariskipitoisimpiin ratkaisun osa-alueisiin(laatuominaisuuksiin). Laaja dokumentaatiokin saattaajoskus olla tarpeen, esimerkiksi erityisenkommunikointitarpeen tyydyttämiseksi

25.9.2014 581385 Ohjelmistoarkkitehtuurit 17

Ohjelmistoarkkitehtuurinmallintaminen

– Suunnittelun pitäisi aina edellyttää koodausta:väärin. Projektin aikaisessa vaiheessa tehtyratkaisun osittainen toteutus ja prototypointivoivat auttaa tunnistamaan hankalimmatongelmat.

25.9.2014 581385 Ohjelmistoarkkitehtuurit 18

Page 10: Arkkitehtuurin mallintaminen - University of Helsinki · – 3D-mallien käyttö rakennusten suunnittelun apuna! 25.9.2014 581385 Ohjelmistoarkkitehtuurit 5 Kommutatiivinen kaavio

25.9.2014

10

Kanonisen rakenteen perusideat

• Arkkitehtuurimalli (jatkossa a-malli) jakautuukolmeen osamalliin1. Sovellusaluemalli (domain model)2. Suunnittelumalli (design model)3. Koodimalli (code model)

• Sovellusaluemalli on abstraktein ja koodimallikonkreettisin (lähimpänä toteutusta)

– Vastaavuus- ja tarkennussuhteet (designation andrefinement) kytkevät osamallit toisiinsa

25.9.2014 581385 Ohjelmistoarkkitehtuurit 19

Kanoninen rakenteen perusideat

• Osamallit voivat periaatteessa olla hyvinlaajoja, mutta näkymillä (view) voidaansuodattaa ja poimia esiin vain tietynnäkökulman kannalta mielenkiintoisia faktoja– Käytännössä a-mallin fyysinen ilmentymä

(kaaviokokoelma, dokumentti) koostuu aina tietyinperustein valituista näkymistä

– ”Täydellinen” malli voi olla olemassa vainsuunnittelijoiden mielissä

25.9.2014 581385 Ohjelmistoarkkitehtuurit 20

Page 11: Arkkitehtuurin mallintaminen - University of Helsinki · – 3D-mallien käyttö rakennusten suunnittelun apuna! 25.9.2014 581385 Ohjelmistoarkkitehtuurit 5 Kommutatiivinen kaavio

25.9.2014

11

Kanoninen rakenteen perusideat

• Malli jakaa erilaiset faktat toteutettavastaohjelmistosta omiin osamalleihinsa– ”Laskutusjakso on 30 vuorokautta”– ”Ladatut fonttiresurssit pitää aina eksplisiittisesti

vapauttaa”– ”Asiakkaan osoite on talletettu varchar(80) –

tyyppiseen kenttään”

• Auttaa pitämään erityyppiset asiat erilläänhelpottaen niitten ymmärtämistä ja käsittelemistä

25.9.2014 581385 Ohjelmistoarkkitehtuurit 21

Sovellusaluemalli• Ilmaisee reaalimaailman eli ongelma-alueen

tosiasioita, jotka ovat relevantteja toteutettavanohjelmiston kannalta (~ käsitteet jotka esiintyvättoiminnallisissa vaatimuksissa)– Ilmiöt ja oliot– Niiden keskinäiset suhteet– Miten yllämainitut kehittyvät ja muuttuvat ajan

kuluessa• Näihin tosiasioihin on suhtauduttava annettuina;

niitä ei voi muuttaa tai tulkita toisin (esim.viikossa on aina seitsemän päivää)

25.9.2014 581385 Ohjelmistoarkkitehtuurit 22

Page 12: Arkkitehtuurin mallintaminen - University of Helsinki · – 3D-mallien käyttö rakennusten suunnittelun apuna! 25.9.2014 581385 Ohjelmistoarkkitehtuurit 5 Kommutatiivinen kaavio

25.9.2014

12

Suunnittelumalli• Ohjelmistototeutuksen (SUD, System Under Design)

suunnittelu taas on täysin ohjelmistoprojektin käsissä• Suunnittelumalli on osajoukko kaikista ohjelmiston

suunnittelupäätöksistä– Osa päätöksistä jää avoimiksi ja koodimallissa ratkaistaviksi

• Se koostuu rekursiivisesti sisäkkäisistä rajapinta-(boundary) ja sisärakennemalleista– Hierarkia, yksityiskohtaisuuden tasot– Rajapintamalli kuvaa elementin julkisen rajapinnan

muuhun ohjelmistoon– Sisärakennemalli kuvaa elementin yksityisen sisäisen

suunnittelun

25.9.2014 581385 Ohjelmistoarkkitehtuurit 23

!

Koodimalli

• Koodimalli on toteutetun ohjelmistonlähdekoodi tai jokin muu toteutuskoodinkanssa ekvivalentti malli– Voidaan tuottaa käänteistekniikalla (reverse-

engineering, code-to-UML)– Siinä missä suunnittelumalli jättää joitain

suunnittelupäätöksiä avoimiksi, koodimalli onriittävän täydellinen suoritettavaksi tietokoneessa

25.9.2014 581385 Ohjelmistoarkkitehtuurit 24

Page 13: Arkkitehtuurin mallintaminen - University of Helsinki · – 3D-mallien käyttö rakennusten suunnittelun apuna! 25.9.2014 581385 Ohjelmistoarkkitehtuurit 5 Kommutatiivinen kaavio

25.9.2014

13

25.9.2014 581385 Ohjelmistoarkkitehtuurit 25

Fairbanks G.: Just Enough Software Architecture, pp. 116

Vastaavuussuhde• Vastaavuussuhde linkittää kahden eri mallin

samanlaiset oliot toisiinsa• Sovellusaluemallin käsitteillä ja ilmiöillä on oltava

vastinparinsa suunnittelumallissa• Vastaavuussuhdetta ei välttämättä määritellä

eksplisiittisesti (listaamalla vastaavuuksia, mapping),mutta se on voitava aina validoida– Vastaavuuden rikkoutuminen johtaa yleensä

ohjelmistovikoihin, jotka näyttäytyvät vääränäkäyttäytymisenä (hyväksyntä-) testauksessa

– Vastaavuus ei välttämättä ole 100% oikein toimivassakaanohjelmistossa, koska suunnittelussa voidaan tarkoituksellatehdä yksinkertaistuksia sovellusalueen tietotyyppeihin

25.9.2014 581385 Ohjelmistoarkkitehtuurit 26

Page 14: Arkkitehtuurin mallintaminen - University of Helsinki · – 3D-mallien käyttö rakennusten suunnittelun apuna! 25.9.2014 581385 Ohjelmistoarkkitehtuurit 5 Kommutatiivinen kaavio

25.9.2014

14

Vastaavuussuhde

25.9.2014 581385 Ohjelmistoarkkitehtuurit 27

Fairbanks G.: Just Enough Software Architecture, pp. 117

Tarkennussuhde

• Tarkennus kytkee toisiinsa saman olion vähänyksityiskohtia sisältävän (low-detail) mallin jayksityiskohtaisen (high-detail) mallin

• Sitä käytetään kytkemään rajapintamallisisärakennemalliin, joka siis kuvaa elementinjulkisen rajapinnan toteutuksen (suunnitteluntasolla)

• Tarkennusta voidaan käyttää myös hierarkisestijakamaan jokin kokonaisuus osiinsa

25.9.2014 581385 Ohjelmistoarkkitehtuurit 28

Page 15: Arkkitehtuurin mallintaminen - University of Helsinki · – 3D-mallien käyttö rakennusten suunnittelun apuna! 25.9.2014 581385 Ohjelmistoarkkitehtuurit 5 Kommutatiivinen kaavio

25.9.2014

15

Tarkennussuhde• Tarkennusta käytetään myös linkittämään

suunnittelumalli koodimalliin• Suunnittelumallin rakenteelliset elementit kuvautuvat

yleensä suoraan koodimallin elementteihin– Moduuli suunnittelussa vastaa pakkausta koodissa– Komponentti suunnittelussa vastaa joukkoa luokkia

koodissa• Mutta on kuitenkin joukko suunnittelumallin

elementtejä, joilla ei ole suoraa vastinetta koodissa– Invariantit, rajoitteet, arkkitehtuurityylit ja ratkaisumallit– Koodissa voi pyrkiä noudattamaan niitä, mutta niitä ei voi

suoraan ilmaista ohjelmointikielen rakentein

25.9.2014 581385 Ohjelmistoarkkitehtuurit 29

Tarkennussuhde

25.9.2014 581385 Ohjelmistoarkkitehtuurit 30

Fairbanks G.: Just Enough Software Architecture, pp. 118

Page 16: Arkkitehtuurin mallintaminen - University of Helsinki · – 3D-mallien käyttö rakennusten suunnittelun apuna! 25.9.2014 581385 Ohjelmistoarkkitehtuurit 5 Kommutatiivinen kaavio

25.9.2014

16

Näkymät

• Sovellusalue-, suunnittelu- ja koodimallit ovattäynnä yksityiskohtia (ainakin käsitteellisessämielessä), joita on hankalaa pitää edesmielessään yhtä aikaa saati dokumentoidaeksplisiittisesti

• Näkymä eli projektio suodattaa mallistaosajoukon yksityiskohtia jotakin tiettyänäkökulmaa (viewpoint) tai tarvetta varten

25.9.2014 581385 Ohjelmistoarkkitehtuurit 31

Näkymät

• Esimerkiksi kaupungin maa-alue ja senrakennukset, tiet ym. muodostavat mallin– Opaskartta auttaa asukasta löytämään tietyn katu-

osoitteen kaupungista– Reittiopas kertoo julkisten liikennevälineiden reitit

kaupungissa– Rakentajat ja kaavoittajat tarvitsevat taas aivan

erilaisia tietoja omiin karttoihinsa

25.9.2014 581385 Ohjelmistoarkkitehtuurit 32

Page 17: Arkkitehtuurin mallintaminen - University of Helsinki · – 3D-mallien käyttö rakennusten suunnittelun apuna! 25.9.2014 581385 Ohjelmistoarkkitehtuurit 5 Kommutatiivinen kaavio

25.9.2014

17

Näkymät

• Eri näkymät samaan ”Master” -malliin eivätsaisi olla keskenään ristiriitaisia– Jos jokin sovellusaluemallin toiminnallinen

skenaario viittaa johonkin oliotyyppiin, tyypinpitäisi olla kuvattuna myös mallin tietomallissa

• ”Master” –mallia ei välttämättä koskaantäydellisenä dokumentoida, joten on tärkeäämuuten huolehtia, että kaikilla projektiinosallistuvilla on sama ”master” –mallimielessään

25.9.2014 581385 Ohjelmistoarkkitehtuurit 33

”Master model”

25.9.2014 581385 Ohjelmistoarkkitehtuurit 34

Fairbanks G.: Just Enough Software Architecture, pp. 119

Page 18: Arkkitehtuurin mallintaminen - University of Helsinki · – 3D-mallien käyttö rakennusten suunnittelun apuna! 25.9.2014 581385 Ohjelmistoarkkitehtuurit 5 Kommutatiivinen kaavio

25.9.2014

18

UML

• UML 2.0 –versioon on lisätty tukeaarkkitehtuurien mallinnukselle

• Kieli on laaja ja sen semantiikka ei ole kovinhyvin määritelty, mutta sille on melko yleinenhyväksyntä ja hyvä, joskin kirjava, työkalutuki

• Kurssilla ja kurssikirjassa käytetään UML 2.0:aamallien visualisointiin

25.9.2014 581385 Ohjelmistoarkkitehtuurit 35

UML -työkalut• Täysveriset UML-työkalut ovat isoja ja raskaskäyttöisiä (ja usein myös

kalliita) ohjelmistoja• Kevyempiä välineitä tämän kurssin tarpeisiin

– UMLet http://www.umlet.com/ - osin tekstipohjainen, osin graafinen,askeettinen mutta suhteellisen toimiva väline, jolla onnistuvat myös UML 2.0:narkkitehtuuritason rakennekaaviot (composite structure diagram)

– PlantUML http://plantuml.sourceforge.net/ - helppokäyttöinentekstipohjainen UML-työkalu, ei tukea UML 2.0:n arkkitehtuuritasonrakennekaavioille (composite structure diagram)

• Verkossa toimivia piirtovälineitä (ominaisuuksiltaan rajoittuneempia)– http://yuml.me/ (luokka- ja käyttötapauskaavioihin)– https://www.websequencediagrams.com/ (sekvenssikaavioihin)

• Laitoksen Linux-koneilta löytyy Umbrello, joka ei kuitenkaan tue UML 2.0:nrakennekaavioita (komponenttikaavioita voi piirtää)

25.9.2014 581385 Ohjelmistoarkkitehtuurit 36