Ohjelmistoarkkitehtuurit

Samankaltaiset tiedostot
Ohjelmistoarkkitehtuurit

Oppimistavoitteet. Ohjelmistoarkkitehtuurit. Ohjelmistojen merkityksestä. Ohjelmistoarkkitehtuurit S2015 Antti-Pekka Tuovinen / HY 1.9.

Ohjelmistoarkkitehtuurit

Ohjelmistojen suunnittelu

1.3 Katsaus ohjelmistotuotannon kehittymiseen

Tietojärjestelmän osat

Hieman lisää malleista ja niiden hyödyntämisestä

Ohjelmistoarkkitehtuurit. Kevät

1 Johdanto. TTY Ohjelmistotekniikka. Ohjelmistoarkkitehtuurit Syksy 2008

Ohjelmistoarkkitehtuurit Syksy 2009 TTY Ohjelmistotekniikka 1

ITK130 Ohjelmistojen luonne

1 Johdanto. Ohjelmistoarkkitehtuurit Syksy 2010 TTY Ohjelmistotekniikka 1

Copyright by Haikala. Ohjelmistotuotannon osa-alueet

Ohjelmistotuotanto vs. muut insinööritieteet. (Usein näennäinen) luotettavuus ja edullisuus

Ohjelmistoarkkitehtuurit, syksy

TIETOKANNAN SUUNNITTELU

Ohjelmiston toteutussuunnitelma

Ohjelmistoarkkitehtuurit Syksy 2009 TTY Ohjelmistotekniikka 1

Suunnitteluvaihe prosessissa

Ohjelmistotekniikka - Luento 2

Ohjelmistoarkkitehtuurit. Syksy 2010

Koodimalli Code Model

Ohjelmistojen mallintaminen, mallintaminen ja UML

Ohjelmistotekniikan menetelmät, Ohjelmistotuotannon työkaluista

Osittavat arkkitehtuurityylit. Palveluihin perustuvat arkkitehtuurityylit. Erikoisarkkitehtuurityylit

Ohjelmistotekniikan menetelmät, kesä 2008

UML:n yleiskatsaus. UML:n osat:

Arkkitehtuurien tutkimus Outi Räihä. OHJ-3200 Ohjelmistoarkkitehtuurit. Darwin-projekti. Johdanto

Malliperustainen ohjelmistokehitys - MDE Pasi Lehtimäki

1 Johdanto. TTY Ohjelmistotekniikka. Ohjelmistoarkkitehtuurit Syksy 2007

Tenttikysymykset. + UML-kaavioiden mallintamistehtävät

Ohjelmiston testaus ja laatu. Ohjelmistotekniikka elinkaarimallit

Taltioni teknisen alustan arviointi

Ohjelmistotekniikka - Luento 2 Jouni Lappalainen

Järjestelmäarkkitehtuuri (TK081702) Hajautettu tietokanta. Hajautuksen hyötyjä

Arkkitehtuurin mallintaminen

Järjestelmäarkkitehtuuri (TK081702) Pilvipalvelut. Pilvipalvelut - lähtökohtia

Arkkitehtuurikuvaus. Ratkaisu ohjelmistotuotelinjan monikielisyyden hallintaan Innofactor Oy. Ryhmä 14

Tenttikysymykset. + UML- kaavioiden mallintamistehtävät

Ohjelmistoarkkitehtuurin suunnittelu

1 Johdanto. Pieni motivointikalvo. 1.1 Mikä on ohjelmistoarkkitehtuuri?

Ohjelmistoarkkitehtuurit Kevät käytäntöjä

Ohjelmistojen mallintaminen, arkkitehtuuria ja rajapintoja

Helsingin yliopisto/tktl DO Tietokantojen perusteet, s 2000 Johdanto & yleistä Harri Laine 1. Tietokanta. Tiedosto

Ohjelmistoarkkitehtuurit. Syksy 2008

Tietokannan suunnittelu

Uudelleenkäytön jako kahteen

Ohjelmistoarkkitehtuurit Kevät 2016 Johdantoa

TkK-tutkielmat

Ohjelmistoarkkitehtuurit Syksy 2009 TTY Ohjelmistotekniikka 1

13/20: Kierrätys kannattaa koodaamisessakin

JHS 179 Kokonaisarkkitehtuurin suunnittelu ja kehittäminen Liite 9. Virtualisointi ja pilvipalvelut teknologia-arkkitehtuurin suunnittelussa

Ohjelmistojen mallintaminen, kesä 2009

Ohjelmistotekniikan menetelmät, kevät 2008

Uutisjärjestelmä. Vaatimusmäärittely. Web-palvelujen kehittäminen. Versio 1.3

Poweria analytiikkaan

Järjestelmäarkkitehtuuri (TK081702) Web Services. Web Services

Sisällys. Ratkaisumallien historia. Ratkaisumalli. Ratkaisumalli [2] Esimerkki: Composite [2] Esimerkki: Composite. Jaakko Vuolasto 25.1.

Ylläpito. Ylläpito. Ylläpidon lajeja Ohjelmistotuotanto, syksy 1998 Ylläpito

Oleelliset vaikeudet OT:ssa 1/2

Tietojärjestelmä tuotantoympäristössä. Sovellusohjelmat Helsingin ammattikorkeakoulu Stadia / Tekniikka ja liikenne Vesa Ollikainen

Agenda. Johdanto Ominaispiirteitä Kokonaisjärjestelmän määrittely Eri alojen edustajien roolit Sulautetut järjestelmät ja sulautettu ohjelmointi

2 Ohjelmistoarkkitehtuurien kuvaus

Toimilohkojen turvallisuus tulevaisuudessa

Uusia tuulia Soneran verkkoratkaisuissa

HELIA 1 (8) Outi Virkki Tietokantasuunnittelu

jotakin käyttötarkoitusta varten laadittu kokoelma toisiinsa liittyviä säilytettäviä tietoja

Yleisiä asioita. Harkat alkavat ensi viikolla Vierailuluentoa. Slackin #luennot-kanava taas käytössä. Ensi viikon perjantaina, Janne Viitala, Sandvik

Työn ositusmalleista. Luennon tavoitteista. Motivointia. Walker Royce, Software Project Management, A Unified Framework

Ylläpito. Ylläpidon lajeja

TOIMINNALLINEN MÄÄRITTELY MS

Tiedonsiirto- ja rajapintastandardit

Tekninen suunnitelma - StatbeatMOBILE

Standardi IEC Ohjelmisto

Ohjelmistoarkkitehtuuri

Yhteinen opintohallinnon järjestelmä

IT-OSAAJA, TIETOJENKÄSITTELYN ERIKOISTUMISOPINNOT

Tämän lisäksi listataan ranskalaisin viivoin järjestelmän tarjoama toiminnallisuus:

Ohjelmistojen mallintaminen. Luento 11, 7.12.

CQRS, -ES, PACS, DICOM, WTF?

Tietokanta (database)

Arkkitehtuurin mallintaminen

Ohjelmistoarkkitehtuurit, syksy

Ohjelmistojen mallinnus (OMa) - Johdatus ohjelmistotuotantoon Harri Laine 1

Käyttäjien tunnistaminen ja käyttöoikeuksien hallinta hajautetussa ympäristössä

AJAX-konsepti AJAX. Asynkronisuus. Nykyisten web-ohjelmien ongelmia. Asynchronous JavaScript And XML

Tapahtuipa Testaajalle...

7. Tuoterunkoarkkitehtuurit

OA:n kanoninen malli III

Järjestelmäarkkitehtuuri (TK081702) Lähtökohta. Integroinnin tavoitteet

Järjestelmäarkkitehtuuri (TK081702)

TeliaSonera Identity and Access Management

Sisäänrakennettu tietosuoja ja ohjelmistokehitys

Suorituskyky ja ohjelmistokehitys Suorituskykymallit

Oppimistavoitteet. Arkkitehtuurin mallintaminen. Malleista ja niiden käytöstä. Malleista ja niiden käytöstä. Kommutatiivinen kaavio 22.9.

Käytännön haasteita ja ratkaisuja integraation toteutuksessa. Jukka Jääheimo Teknologiajohtaja Solita Oy

SEPA - Design Patterns

Tekninen suunnitelma - StatbeatMOBILE

Ohjelmistojen mallinnus, s2008 HY/TKTL, 28/10/2008. Harri Laine 1. Ohjelmisto

Scrum is Not Enough. Scrum ei riitä. Ari Tanninen & Marko Taipale. Nääsvillen oliopäivä 2009 Tampereen teknillinen yliopisto 9.12.

Transkriptio:

Ohjelmistoarkkitehtuurit Luento 1 1 Oppimistavoitteet Mitä ohjelmistoarkkitehtuuri on? Mitä hyötyä siitä on? Miten aihetta kurssilla käsitellään? 2 1

ALUKSI 3 Sovellusten määrä USA:ssa eri vuosikymmeninä (arvio)* 6000000 Applications 5000000 4000000 3000000 2000000 Appls. (est.) 1000000 0 1960 1970 1980 1990 2000 2010 2020 * ) Capers Jones, The Technical and Social History of Software Engineering. Addison-Wesley Professional, 2013. 4 2

Sovellusten keskim. koko USA:ssa Function Point -kokomittarilla (arvio)* 1200 1000 800 600 400 Avg. Function Points Logical stmts per FP 200 0 1950 1960 1970 1980 1990 2000 2010 * ) Capers Jones, The Technical and Social History of Software Engineering. Addison-Wesley Professional, 2013. 5 Ohjelmistotekniikan kehityksestä 2010 Websovellusalustat, HTML5, pilvipalvelut, mobiili, Big data Tuoteperhearkkitehtuurit, MDA, väliohjelmistot, 2000 ohjelmistoalustat, aspektit, dynaamiset (skripti-) kielet Lean, ekosysteemit Ketterät menetelmät (agile methods) 1995 1990 1985 1980 1970 CASE-välineet: uudelleenkäyttö, testaus, mittaus Patterns (ratkaisumallit), sovelluskehykset, ohjelmistoarkkitehtuurit, arkkitehtuurityylit, arkkitehtuurien kuvauskielet, UML CASE-välineet: käyttöliittymien piirtäminen CASE-välineet: kaaviotyökalut (oliotekniikat) CASE-välineet: koodingenerointi (5GL) Oliot, uudelleenkäyttö, oliosuunnittelu Tietokone- ja järjestelmäarkkitehtuuri, Relaatiotietokannat (4GL) Suunnittelumenetelmät: tietovirtakaaviot, ER-malli Modulaarisuus, tiedon kätkeminen, (2GL, 3GL) 1950-60 Aliohjelmat (1GL) Liiketoiminta, organisaatio, Unified Process & inkrementaalinen kehitys Graafiset käyttöliittymät, käytettävyys Prosessit: CMM, spiraalimalli & riskien hallinta Prosessit: vesiputous 6 3

Ohjelmistojen merkityksestä 2010-luvun tietoyhteiskunta: lukematon määrä palveluita toteutetaan tietojärjestelminä, joista monet ovat kooltaan ja käyttäjämääriltään maailmanlaajuisia Tietokonelaitteistot kehittyneet huimasti: laskentateho, nopea tiedonsiirto, valtavien tietomäärien hajautettu tallennus ja rinnakkainen käsittely Virtualisoinnin ja pilvestä saatavan laskenta- ja tallennuskapasiteetin ansiosta kokonaisia järjestelmiä voidaan toteuttaa nyt puhtaasti ohjelmistoratkaisuina (ei omia kiinteitä laiteinvestointeja) Laadultaan hyvien ohjelmistojen kustannustehokas toteuttaminen on entistäkin tärkeämpää Tarkoituksenmukaisuus, tehokkuus, luotettavuus, saatavuus, käyttökokemus, muunneltavuus, skaalautuvuus, turvallisuus,. Kilpailu on kovaa ja markkinat avoimet, time-to-market 7 OHJELMISTOARKKITEHTUURI 8 4

Mitä OA on? Määritelmä (Software Engineering Inst. / CMU) The software architecture of a system is the set of structures needed to reason about the system, which comprise software elements, relations among them, and properties of both. Järjestelmän ohjelmistoarkkitehtuuri tarkoittaa rakenteita, joita tarvitaan päätelmien tekemiseksi järjestelmästä ja sen ominaisuuksista. Rakenteet koostuvat ohjelmistoelementeistä, niiden välisistä suhteista, ja näiden molempien piirteistä. 9 mutta mitä se tarkoittaa? Määritelmä ei kerro suoraan mitä rakenteet ovat Ei yksi vaan joukko rakenteita Mikä tahansa tarkoitukseen sopiva kokoelma elementtejä (koodimoduuleja, komponentteja, prosesseja, virtuaalikoneita) ja niiden välisiä suhteita (riippuvuuksia, käyttösuhteita, omistussuhteita) voi muodostaa tarkasteltavan rakenteen Kurssilla opimme, minkälaisia rakenteita yleensä kannattaa tarkastella Riippuu myös sovellusalueesta ja käytetyistä teknologioista 10 5

siis mitä? Oleellista on, että rakenteiden perusteella voidaan tehdä päätelmiä jollekin sidosryhmälle tärkeistä ohjelmiston makrotason ominaisuuksista Asiakas, loppukäyttäjä, kehittäjä, ylläpitäjä, liiketoiminnan johto, viranomainen, Tarkoituksenmukaisuus, luotettavuus, tehokkuus, helppokäyttöisyys, turvallisuus, muutettavuus, ulkoiset riippuvuudet, skaalautuvuus, Arkkitehtuuri ei ole itsetarkoitus vaan väline 11 Esimerkki - Rackspace HostedE-mail service provider Log.txt! 12 6

Tutkittava järjestelmä Sähköpostipalvelimien tuottamien lokitietojen tallennus ja käsittely asiakastukea varten Tehtävä (missio) Asiakkaan sähköpostin toimintaa koskevien ongelmien selvittämisen tukeminen sähköpostipalvelimien tuottamien lokitietojen perusteella Tarjottava ajantasaista tietoa riittävän pitkältä ajanjaksolta Kolme järjestelmäversiota, kolme erilaista arkkitehtuuria 13 V. 1 S-postipalvelinten paikalliset lokitiedostot Teknisen tuen pitää pyytää operaattoria ottamaan yhteys asiakkaan postipalvelimeen ja tutkimaan lokitietoja ongelmien selvittämiseksi Rackspace toteutti skriptin, joka automaattisesti ottaa yhteyden joukkoon palvelimia ja suorittaa haun (grep) halutuntyyppisen palvelimen lokista Ongelmia: Palvelinten, asiakkaiden ja tukipyyntöjen määrän kasvaessa yhä useammin suoritettavat haut alkoivat vaikuttaa palvelinten suorituskykyyn Hakujen tekemiseen tarvittiin aina operaattoria, mikä vei jatkuvasti kasvavan osan heidän työajastaan 14 7

V. 2 Lokitietojen keskittäminen yhteen tietokantaan S-postipalvelimet lähettävät muutaman minuutin väliajoin lokitietonsa ladattavaksi samaan relaatiotietokantaan Teknikoilla on suora web-yhteys tietokantapalvelimelle ennalta ohjelmoitujen hakujen suorittamista varten Yksittäisten palvelimien lähettämät päivitykset kootaan yhteen säännöllisesti suoritettavaksi massapäivitykseksi (suoritetaan 10 min. välein) tietokantapalvelimen suorituskyvyn ylläpitämiseksi Ongelmia: Datan ja kyselyiden määrän jatkuvasti kasvaessa tietokantapalvelimen suorituskyky ja kapasiteetti muodostuivat pullonkaulaksi, häiriöt lisääntyivät Haut hidastuivat ja dataa hävisi välillä, vain muutaman päivän edestä lokitietoja kyettiin säilyttämään, varmuuskopioita ei ollut 15 V. 3 Lokitiedostojen rinnakkainen indeksointi hajautetussa tiedostojärjestelmässä S-postipavelimet syöttävät lokitiedostonsa usealle yksinkertaiselle palvelimelle (cluster) hajautettuun tiedostojärjestelmään (Hadoop DFS) Hadoop map-reduce operaatio indeksoi lokitiedostot ja muodostaa kaiken kattavan indeksin 15 min. välein Teknikoilla on web-liittymä hakujen tekemiseen kuten ennenkin Hakujen suoritus indeksistä on nopeaa, uudenlaisen haun ohjelmointi ja suoritus kestää kuitenkin joitain tunteja Täydellinen varmuuskopiointi, lokitietojen säilytys 6 kk:n ajalta 16 8

Ratkaisujen vertailua minaisuus V. 1 V. 2 V. 3 Toiminnallisuus Skaalautuvuus datan ja hakujen määrä Viive lokitietojen saanti s-palvelimilta Joustavuus uudet haut heikko välttävä hyvä välitön 10 min. 15 min. hyvä hyvä tyydyttävä 17 Huomioita 1 Järjestelmän tekniselle tuelle näkyvät toiminnot ovat käytännössä samat kaikissa versioissa Tukihenkilö sai kaikissa tapauksissa tarvitsemansa (samat) tiedot lokeihin kirjautuneista tapahtumista Järjestelmän toiminnallisuus (mitä järjestelmä tekee) ei siis ohjannut teknisiä ratkaisuja 1. versioonkin olisi voinut toteuttaa web-liittymän hakujen pyytämiseen operaattoreilta 18 9

Huomioita 2 Esimerkkijärjestelmän arkkitehtuuriin vaikuttavat eniten vaaditut laatuominaisuudet (quality attributes, -ilities, non-functional requirements ) Skaalautuvuus, tiedonsaannin viive, joustavuus uusien hakujen määrittelyssä Ylivoimaisesti tärkein järjestelmän ominaisuus on skaalautuvuus datan ja hakujen määrän suhteen Huonosti skaalautuva järjestelmä ei lainkaan kykene täyttämään tehtäväänsä toiminnan laajentuessa 19 Huomioita 3 minaisuus V. 1 V. 2 V. 3 Toiminnallisuus Skaalautuvuus datan ja hakujen määrä Viive lokitietojen saanti s-palvelimilta Joustavuus uudet haut heikko välttävä hyvä välitön 10 min. 15 min. hyvä hyvä tyydyttävä 20 10

Huomioita 3 Skaalautuvuuden parantuessa versiosta toiseen muut ominaisuudet hieman kärsivät Viive kasvaa (lokidatan tilannekuvan ikä) -> 15 min Joustavuus vähenee, koska uusien hakujen lisääminen vaatii enemmän työtä Joistakin vaadituista ominaisuuksista täytyy tinkiä toisten hyväksi (trade off) Laatuominaisuuksien priorisointi esimerkissä: Skaalautuvuus > Viive > Joustavuus 21 entäs se arkkitehtuuri? Esimerkin järjestelmäversioiden kuvausten yhteydessä mainitut tekniset ratkaisut (suunnittelupäätökset) kuuluvat järjestelmän arkkitehtuuriin Ohjelmistoarkkitehtuuriin kuuluvat siis ne ohjelmiston suunnittelupäätökset, jotka merkittävästi vaikuttavat ohjelmiston laadullisten ominaisuuksien saavuttamiseen Suunnittelupäätösten pohjalta voidaan rakentaa järjestelmä, jolla on halutut ominaisuudet Sovellusalue ja kunkin sovelluksen/järjestelmän vaatimukset vaikuttavat siihen, mitkä tekniset seikat milloinkin nousevat arkkitehtuuriasioiksi ja mitä rakenteita on syytä tarkastella (OA:n määritelmä) 22 11

Tyypillisiä arkkitehtuuripäätöksiä Järjestelmän osittaminen osajärjestelmiin (pääkomponentteihin) ja niiden roolien, toimintojen ja keskinäisten riippuvuuksien määrittely Osajärjestelmien jako päätason komponentteihin jne. J:n käsittelemän ja säilyttämän tiedon tallennus- ja saantiratkaisut J:n rajapintojen (käyttöliittymät, ohjelmalliset rajapinnat) tunnistaminen ja erottaminen niiden kautta käytettävien toimintojen sisäisestä toteutuksesta J:n ajoaikaiseen suorituskykyyn, resurssien käyttöön ja turvallisuuteen vaikuttavat ratkaisut Palvelimet, prosessit ja säikeet, tieto- ja tapahtumavirrat, etäyhteydet, valvonta, tunnistaminen, sijoittelu laitteistoon J:n kehitystä ja ylläpitoa tukevat ratkaisut Uudelleenkäyttö, komponenttien vaihdettavuus ja siirrettävyys, diagnostiikka, testattavuus Jonkin teknologia-alustan ja sen referenssiarkkitehtuuri(e)n käyttö 23 Arkkitehtuuri ja muu suunnittelu (design, detailed design) Suunnittelu (design) päätetään, minkälaisista yksiköistä ohjelmisto toteutus koostuu Yksiköiden vastuut, rajapinnat, riippuvuudet Esim. oliot ja niiden roolit ja rajapinnat, metodit ja niiden semantiikka, patternien soveltaminen, keskeiset algoritmit, luokkien paketointi, tietomallit, konfigurointi jne. Miten vedetään raja arkkitehtuurisuunnittelun ja muun suunnittelun (detailed design) välille? Täytyykö raja vetää? Joskus detaljit voivat olla tärkeitä; esimerkiksi komponenttistandardin muotovaatimukset ladattavien komponenttien rajapinnan koodaukselle ja niiden ulkoisten riippuvuuksien määrittelylle Arkkitehtuuriset suunnittelupäätökset Vaikuttavat ohjelmiston keskeisten laatuvaatimusten toteutumiseen Tai muuten vaikuttavat laajasti ohjelmiston osien suunnitteluun 24 12

Arkkitehtuuriratkaisut ja muut suunnittelupäätökset Kaikki suunnittelupäätökset Arkkitehtuuripäätökset 25 Arkkitehtuuri ja muu suunnittelu Rajaa arkkitehtuurin ja (yksityiskohtien) suunnittelun välille ei ole aina helppo vetää, mutta järjestelmän laatuominaisuuksiin vaikuttavat suunnittelupäätökset ovat yleensä tunnistettavissa Kaikilla ohjelmistoilla siis on arkkitehtuuri On toki parempi, että arkkitehtuuriratkaisut ovat harkittuja kuin sattumalta syntyneitä (vrt. Big Ball of Mud ) Kokeneella ammattilaisella on mielessään tietynlaisten ongelmien hahmoja ja niiden ratkaisutapoja (conceptual model), jotka auttavat häntä tunnistamaan arkkitehtuurin kannalta tärkeät päätökset -> näkee metsän puilta 26 13

Ohjelmistoarkkitehtuuri vs. Arkkitehtuuri? Suomen arkkitehtiliiton puheenjohtaja Erkki Rautio Tietoviikonhaastattelussa 29.4.2012: Ei se herätä suuttumusta, vaan ehkä enemmänkin sääliä, kun itammattilaisilla ei ole omia ammattinimikkeitä. Huippuarkkitehtuuri on taidemuoto, jossa rakennusten käyttäjien tarpeet usein jäävät vähemmälle huomiolle kuin taiteelliset näkökohdat Venustas (!), Firmitas(?), Unistas(??) 27 OHJELMISTOARKKITEHTUURIN HYÖDYT JA KÄYTTÖ 28 14

Arkkitehtuurin ilmeneminen Arkkitehtuuri on siis valikoitu joukko ohjelmistoelementtien ja niiden välisten suhteiden muodostamia rakenteita Konkreettisesti nämä rakenteet voivat ilmetä Ideoina ja periaatteina (kehittäjien mielessä) Konkreettisina rajoitteina (suunnittelulle ja toteutukselle) Dokumentteina (muodollisina tai vapaamuotoisina) Malleina (UML, formaalit mallinnuskielet) Koodina (kirjastot, kehykset, alustat, esimerkit ja prototyypit, lähdekoodin struktuuri ja riippuvuudet, paketointi ja nimentä) ja suoritusaikaisina objekteina Implementaation ilmentämä arkkitehtuuri on tietysti lopullinen totuus (ei välttämättä vastaa dokumentoituja suunnitelmia) 29 Arkkitehtuurin käyttö Arkkitehtuurin käyttötavat ohjelmistokehityksessä voidaan jakaa karkeasti kahteen kategoriaan Preskriptiivinen eli ohjaava käyttö Deskriptiivinen eli kuvaileva käyttö 30 15

Ohjaava käyttö Arkkitehtuuri määrittää järjestelmän perusrakenteen Analogiana eläimen luuranko Arkkitehtuurin lähtökohdaksi voidaan valita tyyli (architectural style) tai patterni (architectural pattern), joka kiinnittää elementtien vastuut/roolit ja niiden välisten liitosten ja yhteyksien ominaisuudet Ei voida sanoa, onko jokin tyyli absoluuttisesti parempi kuin toinen, vaan täytyy arvioida tyylin sopivuutta kehitettävän ohjelmiston tarpeisiin nähden 31 Ohjaava käyttö Arkkitehtuuri vaikuttaa laatuominaisuuksiin Arkkitehtuuri mahdollistaa haluttujen ominaisuuksien saavuttamisen Sopimaton arkkitehtuuri voi myös estää sen Arkkitehtuuri on (enimmäkseen) riippumaton toiminnallisuudesta Saman toiminnallisuuden voi toteuttaa melkein minkälaisella arkkitehtuurilla tahansa Mutta: huonosti valittu arkkitehtuuri voi tehdä toiminnallisuuden toteuttamisen ja laatuvaatimusten saavuttamisen vaikeaksi ja kalliiksi (joskus jopa mahdottomaksi) 32 16

Ohjaava käyttö Arkkitehtuuri ohjaa toteutusta rajoitteiden avulla (guide rails) Esimerkiksi käytettävyyden tai tietoturvallisuuden vuoksi halutaan suoraan kieltää eräät ominaisuuden kannalta huonoksi tiedetyt ratkaisut Rajoitteet auttavat kehittäjiä monin tavoin Kokemuksen siirto tiivistetyssä muodossa asiantuntijoilta, jotka ovat perustelluista syistä asettaneet rajoitteet Käsitteellisen eheyden (conceptual integrity 1 ) vahvistaminen ja kompleksisuuden vähentäminen tarpeetonta luovuutta rajoittamalla Koodin ajonaikaisen käyttäytymisen helpompi ymmärtäminen 1 A single good idea consistently applied is better than several brilliant ideas scattered across a system (Fred Brooks) 33 Kuvaileva käyttö Ohjelmiston ja suunnitteluratkaisujen ymmärtäminen Abstrahointi yksityiskohtia pois suodattamalla Sopivasti valitut rakenteet ja niitä tietystä näkökulmasta esittävät näkymät (view) ovat erinomaisia ymmärryksen lähteitä Uudet kehittäjät, johto, asiakkaat, alihankkijat, jne. Liiketoiminnallisten tavoitteiden toteutumisen seuraaminen Tuoteperheet, COTS-komponenttien käyttö, integrointi ulkoisiin palveluihin, standardointi, lisensointi jne. 34 17

Kuvaileva käyttö Rajoitteiden noudattamisen valvonta Esimerkiksi näkymän muodostaminen rakenneosien (komponenttien, kerrosten) välisistä riippuvuuksista, jolloin voidaan havaita arkkitehtuurin rajoitteiden kieltämät riippuvuudet Esim. kerrosarkkitehtuurissa alemman kerroksen komponentti kutsuu ylemmän kerroksen palvelua muuten kuin palvelun asettaman takaisinkutsurajapinnan kautta Organisaation kehittäminen Vahvasti toisiinsa kytkeytyvien elementtien kehittämisvastuun jako kannattaa miettiä tarkkaan kommunikaatio-ongelmien välttämiseksi Conwayn laki organisaatio ja arkkitehtuuri muistuttavat ennen pitkää toisiaan 35 Muita hyötyjä Riskien hallinta Arkkitehtuurityö kannattaa keskittää tunnistettujen riskien eliminoimiseen tai lieventämiseen Kiinnitetään jatkuvaa huomiota tärkeimpiin teknisiin uhkiin Vaatimusten täsmentäminen Vaadittujen laatuominaisuuksien analysointi ja arkkitehtuurin suunnittelu niiden saavuttamiseksi auttaa huomaamaan ristiriitaisuuksia ja epätäsmällisyyksiä vaatimuksissa ja määrittelyissä Arkkitehtuurin suunnitteluun liittyvä laatuominaisuuksien tasapainottelu (trade off) pakottaa priorisoimaan laatuvaatimukset 36 18

KURSSIN SISÄLTÖ 37 38 19

Pääoppimistavoitteet Tietää mitä ohjelmistoarkkitehtuuri on ja mihin sitä käytetään Tietää ja osaa soveltaa muutamia keskeisiä arkkitehtuurityylejä ja patterneja ohjelmiston arkkitehtuurin suunnitteluun Tietää miksi ja milloin arkkitehtuurimalleja laaditaan ja osaa muodostaa kanonisen rakenteen mukaisia näkymiä arkkitehtuuriin Hallitsee arkkitehtuurin arvioinnin ja ohjelmistokehysten (framework) suunnittelun perusideat (syvennetään harjoitustyössä) 39 20