Oppimistavoitteet. Ohjelmistoarkkitehtuurit. Ohjelmistojen merkityksestä. Ohjelmistoarkkitehtuurit S2015 Antti-Pekka Tuovinen / HY 1.9.
|
|
- Marja-Leena Keskinen
- 8 vuotta sitten
- Katselukertoja:
Transkriptio
1 Oppimistavoitteet Ohjelmistoarkkitehtuurit Mitä ohjelmistoarkkitehtuuri on? Mitä hyötyä siitä on? Miten aihetta kurssilla käsitellään? Luento Sovellusten määrä USA:ssa eri vuosikymmeninä (arvio)* Applications ALUKSI Appls. (est.) * ) Capers Jones, The Technical and Social History of Software Engineering. Addison-Wesley Professional, Sovellusten keskim. koko USA:ssa Function Point -kokomittarilla (arvio)* Avg. Function Points Logical stmts per FP * ) Capers Jones, The Technical and Social History of Software Engineering. Addison-Wesley Professional, 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 Ohjelmistoarkkitehtuuri on tärkeässä roolissa halutun laadun ja tuottavuuden saavuttamisessa 6 1
2 Ohjelmistotekniikan kehityksestä 2010 Lean, ekosysteemit, startupit, experimentointi Websovellusalustat, HTML5, pilvipalvelut, mobiili, Big data, IoT, Continuous X 2000 Tuoteperhearkkitehtuurit, MDA, väliohjelmistot, Ketterät menetelmät (agile ohjelmistoalustat, aspektit, dynaamiset (skripti-) kielet methods) 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) Aliohjelmat (1GL) Liiketoiminta, organisaatio, Unified Process & inkrementaalinen kehitys Graafiset käyttöliittymät, käytettävyys Prosessit: CMM, spiraalimalli & riskien hallinta Prosessit: vesiputous 7 OHJELMISTOARKKITEHTUURI 8 Määritelmiä Ohjelmistotyyppien kirjo on hyvin suuri Sulautetut ohjelmistot On-line giga-applikaatiot Myös ohjelmistoarkkitehtuurion osoittautunut monitahoiseksi asiaksi, jota voidaan perustellusti tarkastella eri näkökulmista ja eri tavoittein Johtaa hieman erilaisiin määritelmiin ja painotuksiin Kaksi koulukuntaa (1990 s 2010 s) Rakenteita korostava koulukunta Suunnittelupäätösten merkitystä korostava koulukunta 9 Rakenteet <> Suunnittelupäätökset Rakenteet Kattavuus Dokumentaatio Suunnitelmallisuus - Hallinta Suunnittelupäätökset Ominaisuudet Ymmärrys Inkrementaalisuus App Browser Client REST, JSON, HTML5 Http server Application Data store Server Client- Server, 3-Tier Logger Rabbit MQ 10 I - Rakenteita korostava määritelmä Software Engineering Institute / Carnegie Mellon University: 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ä. (Katso myös esimerkiksi ISO/IEC standardin arkkitehtuuurin määritelmä ja IEEEXplore) 11 Mitä rakenteet ovat? Määritelmä jättää tämän avoimeksi Ei yksi vaan joukko rakenteita Mikä tahansa tarkoituksenmukainen kokoelma elementtejä ja niiden välisiä suhteita voi muodostaa rakenteen Kurssilla opimme, minkälaisia rakenteita yleensä kannattaa tarkastella (arkkitehtuurin mallinnus) Rakenteiden valinta riippuu sovelluksesta, sovellusalueesta ja toteutusteknologioista, one size does not fit all 12 2
3 Tyypillisiä elementtejä ja rakenteita Ohjelmistolla on kolme olomuotoa, joissa esiintyy merkittäviä rakenteita Staattinen, dynaaminen, operatiivinen Staattinen olomuoto Ohjelmiston koodi tiedostoissa ja tiedostojärjestelmän kansioissa (moduulit) konfiguraatio- ynnä muut alustus- ja datatiedostot ja resurssit Näiden väliset sisältyvyys ja viittaussuhteet (tiedostoja kooditasolla) Tyypillisiä elementtejä ja rakenteita Dynaaminen olomuoto Ohjelmiston suoritusaikana (tietokoneen muistiin ja käyttöjärjestelmään) luomat aktiiviset ja passiiviset oliot, prosessit ja säikeet, data-entiteetit sekä näiden kommunikaatiorajapinnat ja yhteydet (komponentit ja konnektorit) Olioiden (ja prosessien) väliset data- ja kontrollivuot, muut viestintä- ja yhteistoimintamekanismit Usean olion muodostamat, roolinsa ja toimintansa perusteella selkeästi erottuvat kokonaisuudet (alijärjestelmä, komponentti) Application, Server, Load Balancer, Business Process, Container, Bean Palvelu Olio- ja prosessijoukko Huomaa: ei välttämättä yksi-yhteen vastaavuutta staattisten rakenteiden kanssa Tyypillisiä elementtejä ja rakenteita Operatiivinen olomuoto (sijoittelu, allokaatio) Dynaamisten olioiden ja palveluiden sijoittelu ja suoritus laitteistossa osana tiettyä järjestelmää (Virtuaali-) palvelimet, tallennusvälineet, tietoliikennekanavat Palveluiden ylös- ja alasajo, päivitykset, monitorointi, skaalautuvuuden ja saatavuuden hallinta, pääsynvalvonta, transaktiot Ohjelmiston paketointi, konfigurointi ja piirteiden (features) valinta tiettyä käyttökontekstia (asiakasta) varten Pohdittavaksi Mitä elementtejä ja rakenteita voisi olla Javateknologioilla toteutetussa web-sovelluksessa tai mobiiliapplikaatiossa? Staattinen, dynaaminen, operatiivinen olomuoto Abstraktit rakennekuvaukset Abstraktit rakennekuvaukset Jonkin rakenteen dokumentoitu kuvaus (arkkitehtuurinäkymä, view) on usein abstrakti Tarkasteltavan asian kannalta epäoleelliset yksityiskohdat jätetään pois Jos kyse on suunnitelmasta, ei toteutuksen yksityiskohtia vielä voida tai edes haluta kiinnittää Tarkastelu tapahtuu yleensä järjestelmätasolla, jossa rakenneosat ovat vastuiltaan (toiminnot, tietosisältö) suhteellisen suuria (esim. asiakas palvelin - tietovarasto) Näkymät muodostavat usein hierarkian, jossa alemman tason näkymä tarkentaa jotain osaa ylemmän tason näkymästä App Browser Http server Application Data store Logger
4 Rakenteet ja ohjelmiston ominaisuudet Oleellista on, että rakenteiden perusteella voidaan tehdä päätelmiä jollekin sidosryhmälle tärkeistä ohjelmiston makrotason ominaisuuksista Tarkoituksenmukaisuus, luotettavuus, tehokkuus, helppokäyttöisyys, turvallisuus, muutettavuus, ulkoiset riippuvuudet, skaalautuvuus, Asiakas, loppukäyttäjä, kehittäjä, ylläpitäjä, liiketoiminnan johto, viranomainen, Ohjelmiston halutut ominaisuudet vaikuttavat siis siihen, mitä rakenteita arkkitehtuurissa tarkastellaan Ja kuinka tarkkoja tai yksityiskohtaisia kuvauksia tarvitaan Arkkitehtuuri ei siis ole itsetarkoitus vaan väline 19 II - Suunnittelupäätöksiä korostava määritelmä We propose to view a software architecture as a set of explicit architectural design decisions. In this perspective, the software architecture is the result of the architectural design decisions made over time 1 Ohjelmistoarkkitehtuuri koostuu joukosta selkeitä suunnittelupäätöksiä. Arkkitehtuuri on ajan myötä tehtyjen päätösten tulos. 1. Jansen, A., & Bosch, J. (2005). Software architecture as a set of architectural design decisions. In Software Architecture, WICSA th Working IEEE/IFIP Conference on (pp ). IEEE. 20 Arkkitehtuuritason suunnittelupäätös? All architecture is design, but not all design is architecture. 1 Tunnusmerkkejä Päätös koskee järjestelmätason asioita ja vaikuttaa pääasiassa muiden vaatimusten kuin järjestelmän tarjoamia palveluja tai toimintoja koskevien vaatimusten toteutumiseen Voi osoittautua kalliiksi, jos menee pieleen Tasapainottelee eri suuntiin vetävien voimien välillä Ohjaa ja/tai rajoittaa muita suunnittelupäätöksiä Esimerkki - Rackspace Hosted service provider Log.txt! 1. Grady Booch, Tutkittava järjestelmä V. 1 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 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; operaattorit voivat muokata hakuehtoja 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
5 V. 2 Lokitietojen keskittäminen yhteen tietokantaan S-postipalvelimet lähettävät muutaman minuutin väliajoin lokitietonsa ladattavaksi samaan relaatiotietokantaan tk-palvelimelle 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 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 Ratkaisujen vertailua Huomioita 1 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ä 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 Huomioita 2 Huomioita 3 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 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ä
6 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, tärkeämpien, hyväksi (trade off) Laatuominaisuuksien priorisointi esimerkissä: Skaalautuvuus > Viive > Joustavuus 31 entäs se arkkitehtuuri? Esimerkin järjestelmäversioiden kuvausten yhteydessä mainitut tekniset ratkaisut, eli suunnittelupäätökset, määrittävät järjestelmän arkkitehtuurin 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 32 Tyypillisiä arkkitehtuuripäätöksiä Järjestelmän jakaminen 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, skaalautuvuuteen, saatavuuteen, 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 Järjestelmällinen uudelleenkäyttö, tuoterungon käyttö, komponenttien vaihdettavuus ja siirrettävyys, diagnostiikka, testattavuus Jonkin teknologia-alustan ja sen referenssiarkkitehtuuri(e)n käyttö RAJANVETO ARKKITEHTUURIN JA MUUN SUUNNITTELUN VÄLILLÄ Arkkitehtuuri ja muu suunnittelu (design, detailed design) Suunnittelu (design) päätetään, minkälaisista elementeistä ohjelmiston toteutus koostuu ohjelmistoelementtien vastuut, rajapinnat, riippuvuudet Esim. luokat/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 Arkkitehtuuriratkaisut ja muut suunnittelupäätökset Kaikki suunnittelupäätökset Arkkitehtuuripäätökset
7 Arkkitehtuuri ja muu suunnittelu Kuningas näkee pelin toisin 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 OA:N MÄÄRITELMISTÄ Ohjelmistoarkkitehtuurin määritelmien yhteensovittaminen Molemmat ovat sinänsä järkeviä näkökulmia ja täydentävät toisiaan Rakenteita tarvitaan ohjelmiston monimutkaisuuden yleiseen hallintaan ja suunnittelupäätöksiä perusteluineen (rationale) tarvitaan ratkaisujen syvällistä ymmärtämistä ja arviointia varten Dokumentaatio- ja kontrollikeskeiset prosessit pitävät rakenteiden kattavaa määrittelyä tärkeänä Suunnittelupäätöksiin keskittyvä arkkitehtuurityö tyypillistä ketterille kehitysmenetelmille: vain todella tärkeät asiat dokumentoidaan, rakennekuvauksia voidaan generoida automaattisesti tarvittaessa Ohjelmistoarkkitehtuuri vs. Arkkitehtuuri? Suomen arkkitehtiliiton puheenjohtaja Huippuarkkitehtuuri on taidemuoto, jossa Erkki Rautio Tietoviikon haastattelussa rakennusten käyttäjien tarpeet usein : Ei se herätä suuttumusta, jäävät vähemmälle huomiolle kuin vaan ehkä enemmänkin sääliä, kun itammattilaisilla ei ole omia taiteelliset näkökohdat ammattinimikkeitä. Venustas (!), Firmitas(?), Utilitas (??) OHJELMISTOARKKITEHTUURIN HYÖDYT JA KÄYTTÖ
8 Arkkitehtuurin ilmeneminen Arkkitehtuuri on siis valikoitu joukko ohjelmistoelementtien ja niiden välisten suhteiden muodostamia rakenteita tai joukko näitä koskevia suunnittelupäätöksiä Konkreettisesti nämä rakenteet / päätökset 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) Arkkitehtuurin käyttö Arkkitehtuurin käyttötavat ohjelmistokehityksessä voidaan jakaa karkeasti kahteen kategoriaan Preskriptiivinen eli ohjaava käyttö Deskriptiivinen eli kuvaileva käyttö Ohjaava käyttö 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 typpit/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 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 vaikeaksi ja kalliiksi (joskus jopa mahdottomaksi)! Ohjaava käyttö Kuvaileva 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 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. 1 A single good idea consistently applied is better than several brilliant ideas scattered across a system (Fred Brooks)
9 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, riippuvuussyklien kieltäminen 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 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 KURSSIN SISÄLTÖ 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ä) 53 9
Ohjelmistoarkkitehtuurit
Ohjelmistoarkkitehtuurit Luento 1 1 Oppimistavoitteet Mitä ohjelmistoarkkitehtuuri on? Mitä hyötyä siitä on? Miten aihetta kurssilla käsitellään? 2 1 ALUKSI 3 2010 2000 Ohjelmistotekniikan kehityksestä
Ohjelmistoarkkitehtuurit
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ä
Ohjelmistoarkkitehtuurit
Ohjelmistoarkkitehtuurit Luento 1 1 Oppimistavoitteet Mitä ohjelmistoarkkitehtuuri on? Rakenteita korostava näkökulma Suunnittelupäätöksiä korostava näkökulma Arkkitehtuurin käyttö ja hyödyt Kuinka paljon
Suunnitteluvaihe prosessissa
Suunnittelu Suunnitteluvaihe prosessissa Silta analyysin ja toteutuksen välillä (raja usein hämärä kumpaankin suuntaan) Asteittain tarkentuva Analyysi -Korkea abstraktiotaso -Sovellusläheiset käsitteet
1 Johdanto. TTY Ohjelmistotekniikka. Ohjelmistoarkkitehtuurit Syksy 2008
1 Johdanto 1.1 Mikä on ohjelmistoarkkitehtuuri? 1.2 Katsaus ohjelmistotuotannon kehittymiseen 1.3 Epäonnistuneen ohjelmistoarkkitehtuurin seurauksia 1.4 Ohjelmistoarkkitehtuuri ja ohjelmistokehitysprosessi
Ohjelmistojen suunnittelu
Ohjelmistojen suunnittelu 581259 Ohjelmistotuotanto 154 Ohjelmistojen suunnittelu Software design is a creative activity in which you identify software components and their relationships, based on a customer
Tietojärjestelmän osat
Analyysi Yleistä analyysistä Mitä ohjelmiston on tehtävä? Analyysin ja suunnittelun raja on usein hämärä Ei-tekninen näkökulma asiakkaalle näkyvien pääkomponenttien tasolla Tietojärjestelmän osat Laitteisto
1.3 Katsaus ohjelmistotuotannon kehittymiseen
Yleisiä asioita Oliokirja:http://www.cs.tut.fi/~kk/Ohjelmistoarkkitehtuuri.pdf Tenttipäivä 7.5. Tallennukset, jospas tänään onnistaisi Viikkoharkat löytyvät IDLEstä (TTY), kurssin kotisivuilta/paikallisilta
Osittavat arkkitehtuurityylit. Palveluihin perustuvat arkkitehtuurityylit. Erikoisarkkitehtuurityylit
6. Arkkitehtuurityylit Osittavat arkkitehtuurityylit Kerrosarkkitehtuurit Tietovuoarkkitehtuurit Palveluihin perustuvat arkkitehtuurityylit Asiakas-palvelin arkkitehtuurit Viestinvälitysarkkitehtuurit
Koodimalli Code Model
Koodimalli Code Model Luento 6 10.10.2017 CSM14101 Ohjelmistoarkkitehtuurit 1 Oppimistavoitteet Koodimalli Arkkitehtuurisuunnittelun ja implementaation välinen kuilu ja sen hallitseminen Arkkitehtuuria
Ohjelmistoarkkitehtuurit, syksy 2012 4.9.2010
Ohjelmistotutkimuksen painopisteitä Ohjelmistoarkkitehtuurit Johdanto ja peruskäsitteitä 2000 1995 1990 1985 1980 1970 Tuoteperhearkkitehtuurit, MDA, väliohjelmistot, aspektit CASE-välineet: uudelleenkäyttö,
1 Johdanto. TTY Ohjelmistotekniikka. Ohjelmistoarkkitehtuurit Syksy 2007
1 Johdanto 1.1 Mikä on ohjelmistoarkkitehtuuri? 1.2 Katsaus ohjelmistotuotannon kehittymiseen 1.3 Epäonnistuneen ohjelmistoarkkitehtuurin seurauksia 1.4 Ohjelmistoarkkitehtuuri ja ohjelmistokehitysprosessi
Ohjelmistoarkkitehtuurit Syksy 2009 TTY Ohjelmistotekniikka 1
Ohjelmistoarkkitehtuurit Syksy 2009 Kai Koskimies Ohjelmistoarkkitehtuurit Syksy 2009 TTY Ohjelmistotekniikka 1 Tervetuloa Kuopion yliopisto, Oulun yliopisto (Kajaani), Tampereen yliopisto, Turun yliopisto,
Ohjelmistoarkkitehtuurit, syksy
Ohjelmistoarkkitehtuurit Ohjelmistoarkkitehtuurin kuvaaminen on arkkitehtuuritason suunnitteluratkaisujen kuvaamista Arkkitehtuuritasoisuus Aihe, ongelma tai ohjelmistoelementti on arkkitehtuuritasolla,
Ohjelmistoarkkitehtuurit. Kevät
Ohjelmistoarkkitehtuurit Kevät 2012-2013 Johannes Koskinen http://www.cs.tut.fi/~ohar/ Tervetuloa Oulun yliopisto, Tampereen yliopisto, Turun yliopisto, Tampereen teknillinen yliopisto 2 Kurssin tavoitteet
Ohjelmistojen mallintaminen, arkkitehtuuria ja rajapintoja
582104 Ohjelmistojen mallintaminen, arkkitehtuuria ja rajapintoja 1 Arkkitehtuurisuunnittelu Ohjelmistoarkkitehtuurin määritelmä & arkkitehtuurisuunnittelun lähtökohta ja tavoitteet Kerrosarkkitehtuuri
Copyright by Haikala. Ohjelmistotuotannon osa-alueet
Copyright by Haikala Ohjelmistotuotannon osa-alueet Ohjelmiston elinkaari 1. Esitutkimus, tarvekartoitus, kokonaissuunnittelu, järjestelmäsuunnittelu (feasibility study, requirement study, preliminary
2 Ohjelmistoarkkitehtuurien kuvaus
2 Ohjelmistoarkkitehtuurien kuvaus 2.1 Arkkitehtuurikuvauksen merkityksestä 2.2 Arkkitehtuurin kuvaukseen liittyvät käsitteet 2.3 Arkkitehtuurikuvaukset eri tasoilla 2.4 Arkkitehtuurinäkymät ja kuvaustyypit
1 Johdanto. Ohjelmistoarkkitehtuurit Syksy 2010 TTY Ohjelmistotekniikka 1
1 Johdanto 1.1 Mikä on ohjelmistoarkkitehtuuri? 1.2 Ohjelmistoarkkitehtuuri ja laatuvaatimukset 1.3 Katsaus ohjelmistotuotannon kehittymiseen 1.4 Miksi ohjelmistoarkkitehtuuri on tärkeä 1.5 Ohjelmistoarkkitehtuuri
Ohjelmiston toteutussuunnitelma
Ohjelmiston toteutussuunnitelma Ryhmän nimi: Tekijä: Toimeksiantaja: Toimeksiantajan edustaja: Muutospäivämäärä: Versio: Katselmoitu (pvm.): 1 1 Johdanto Tämä luku antaa yleiskuvan koko suunnitteludokumentista,
Ohjelmistotekniikan menetelmät, Ohjelmistotuotannon työkaluista
582101 - Ohjelmistotekniikan menetelmät, Ohjelmistotuotannon työkaluista 1 Ohjelmistotuotannon työkaluuista Projektinhallintatyökalut (ei käsitellä tällä kurssilla) CASE- ja mallinnustyökalut (esim. Poseidon)
Ohjelmistoarkkitehtuurit. Syksy 2010
Ohjelmistoarkkitehtuurit Syksy 2010 Kai Koskimies Tervetuloa Oulun yliopisto, Tampereen yliopisto, Turun yliopisto, Tampereen teknillinen yliopisto, Vaasan yliopisto Kurssin tavoitteet Arkkitehtuurin roolin
Ohjelmistoarkkitehtuurit. Syksy 2008
Ohjelmistoarkkitehtuurit Syksy 2008 Kai Koskimies 1 Tervetuloa Kuopion yliopisto, Oulun yliopisto, Tampereen yliopisto, Teknillinen korkeakoulu, Turun yliopisto, Vaasan yliopisto, Tampereen teknillinen
Ohjelmistoarkkitehtuurit Syksy 2009 TTY Ohjelmistotekniikka 1
1 Johdanto 1.1 Mikä on ohjelmistoarkkitehtuuri? 1.2 Katsaus ohjelmistotuotannon kehittymiseen 1.3 Ohjelmistoarkkitehtuuri ja ohjelmistokehitysprosessi 1.4 Toteutusalustan arkkitehtuurin rooli 1.5 Yhteenvetoa
TIETOKANNAN SUUNNITTELU
TIETOKANNAN SUUNNITTELU HOVI, HUOTARI, LAHDENMÄKI: TIETOKANTOJEN SUUNNITTELU & INDEKSOINTI DOCENDO (2003, 2005) LUKU 2 JOUNI HUOTARI & ARI HOVI TIETOJEN MALLINNUS TIETOJEN MALLINNUKSESTA TIETOKANTAAN Käsiteanalyysin
Hieman lisää malleista ja niiden hyödyntämisestä
Hieman lisää malleista ja niiden hyödyntämisestä Ohjelmistojen mallintaminen Kesä 2012 (Avoin yliopisto) Toni Ruokolainen, 23.8.2012 Mallit Mallit ovat todellisuuden abstraktioita, jotka on muodostettu
Uudelleenkäytön jako kahteen
Uudelleenkäyttö Yleistä On pyritty pääsemään vakiokomponenttien käyttöön Kuitenkin vakiokomponentit yleistyneet vain rajallisilla osa-alueilla (esim. windows-käyttöliittymä) On arvioitu, että 60-80% ohjelmistosta
Järjestelmäarkkitehtuuri (TK081702) Hajautettu tietokanta. Hajautuksen hyötyjä
Järjestelmäarkkitehtuuri (TK081702) Hajautettu tietokanta Hajautettu tietokanta Jokainen hajautettu tietokanta muodostaa oman kokonaisuutensa Loogisesti yhtenäinen data on hajautettu tietokantoihin (eri
Ohjelmiston testaus ja laatu. Ohjelmistotekniikka elinkaarimallit
Ohjelmiston testaus ja laatu Ohjelmistotekniikka elinkaarimallit Vesiputousmalli - 1 Esitutkimus Määrittely mikä on ongelma, onko valmista ratkaisua, kustannukset, reunaehdot millainen järjestelmä täyttää
ITK130 Ohjelmistojen luonne
ITK130 Ohjelmistojen luonne Luennon sisältö Ohjelmistotekniikka ja vaatimukset Ohjelmistotuote Ei-toiminnallisten vaatimusten luokittelu Sisäiset ja ulkoiset vaatimukset Oikeellisuus Luotettavuus Kestävyys
Ohjelmistojen mallintaminen, mallintaminen ja UML
582104 Ohjelmistojen mallintaminen, mallintaminen ja UML 1 Mallintaminen ja UML Ohjelmistojen mallintamisesta ja kuvaamisesta Oliomallinnus ja UML Käyttötapauskaaviot Luokkakaaviot Sekvenssikaaviot 2 Yleisesti
13/20: Kierrätys kannattaa koodaamisessakin
Ohjelmointi 1 / syksy 2007 13/20: Kierrätys kannattaa koodaamisessakin Paavo Nieminen nieminen@jyu.fi Tietotekniikan laitos Informaatioteknologian tiedekunta Jyväskylän yliopisto Ohjelmointi 1 / syksy
Ohjelmistoarkkitehtuurit Kevät 2016 Johdantoa
Ohjelmistoarkkitehtuurit Kevät 2016 Johdantoa Samuel Lahtinen http://www.cs.tut.fi/~ohar/ 8.1.2014 1 1 Johdanto 1.1 Mikä on ohjelmistoarkkitehtuuri? 1.2 Ohjelmistoarkkitehtuuri ja laatuvaatimukset 1.3
Ohjelmistoarkkitehtuurin suunnittelu
Ohjelmistoarkkitehtuurin suunnittelu Luento 3 10.9.2014 581358 Ohjelmistoarkkitehtuurit 1 Oppimistavoitteet Arkkitehtuuritietämyksen lähteet Yleisiä suunnitteluperiaatteita Kaunis arkkitehtuuri 10.9.2014
Tenttikysymykset. + UML-kaavioiden mallintamistehtävät
Tenttikysymykset 1. Selitä mitä asioita kuuluu tietojärjestelmän käsitteeseen. 2. Selitä kapseloinnin ja tiedon suojauksen periaatteet oliolähestymistavassa ja mitä hyötyä näistä periaatteista on. 3. Selitä
Agenda. Johdanto Ominaispiirteitä Kokonaisjärjestelmän määrittely Eri alojen edustajien roolit Sulautetut järjestelmät ja sulautettu ohjelmointi
1. Luento: Sulautetut Järjestelmät Arto Salminen, arto.salminen@tut.fi Agenda Johdanto Ominaispiirteitä Kokonaisjärjestelmän määrittely Eri alojen edustajien roolit Sulautetut järjestelmät ja sulautettu
TkK-tutkielmat
TkK-tutkielmat 2014-2016 Ohjelmistotuotanto Luokittelu Sivuavat kehitysmenetelmät ohjelmistoliiketoiminta Ohjelmistotekniikka rinnakkaisohjelmointi testaus metriikat Ohjelmistoturvallisuus pedagogiikka
Ohjelmistotuotanto vs. muut insinööritieteet. (Usein näennäinen) luotettavuus ja edullisuus
Yhteenveto Ohjelmistotuotanto vs. muut insinööritieteet Monimutkaisuus Näkymättömyys (Usein näennäinen) luotettavuus ja edullisuus Muunnettavuus Epäjatkuvuus virhetilanteissa Skaalautumattomuus Copyright
Tekninen suunnitelma - StatbeatMOBILE
Tekninen suunnitelma - StatbeatMOBILE Versio Päivämäärä Henkilö Kuvaus 1.0 13.12.2013 Pöyry Alustava rakenne ja sisältö 1.1 22.12.2013 Pöyry Lisätty tekstiä ilmoituksiin, turvallisuuteen ja sisäiseen API:in
Ohjelmistotekniikka - Luento 2
Ohjelmistotekniikka - Luento 2 Luku 2: Prosessimallit - miten spiraalimalliin päädyttiin - spiraalimallista (R)UP malliin - oman ammattitaidon kehittäminen; PSP ja TSP mallit 1 Luento 2: Prosessimallit
Malliperustainen ohjelmistokehitys - MDE Pasi Lehtimäki
Malliperustainen ohjelmistokehitys - MDE 25.9.2007 Pasi Lehtimäki MDE Miksi MDE? Mitä on MDE? MDA, mallit, mallimuunnokset Ohjelmistoja Eclipse, MetaCase Mitä jatkossa? Akronyymiviidakko MDE, MDA, MDD,
Taltioni teknisen alustan arviointi
Taltioni teknisen alustan arviointi Taltioni sidosryhmätilaisuus, 10.1.2012 Jaakko Lähteenmäki, Niilo Saranummi 1/11/2012 2 Selvitystyön kohde Selvitystyö: VTT & Fujitsu Keskeiset vaatimukset Taltioni-palvelulle?
Sisällys. Ratkaisumallien historia. Ratkaisumalli. Ratkaisumalli [2] Esimerkki: Composite [2] Esimerkki: Composite. Jaakko Vuolasto 25.1.
Sisällys Ratkaisumallien historia Jaakko Vuolasto 25.1.2001! Ratkaisumalli! Christopher Alexander! Ohjelmistotuotannosta arkkitehtuuriin! Henkilöhistoriaa! Ensimmäisiä käyttökokemuksia! Yhteenveto 25.1.2001
Uutisjärjestelmä. Vaatimusmäärittely. Web-palvelujen kehittäminen. Versio 1.3
Uutisjärjestelmä Vaatimusmäärittely Versio 1.3 Sisällys 1 Muutoshistoria... 4 2 Viitteet... 4 3 Sanasto... 4 3.1 Lyhenteet... 4 3.2 Määritelmät... 4 4 Johdanto...5 4.1 Järjestelmän yleiskuvaus... 5 4.2
Ohjelmistoarkkitehtuurit Syksy 2009 TTY Ohjelmistotekniikka 1
3. Komponentit ja rajapinnat 3.1 Komponenttien idea: ohjelmistotuotannon rationalisointi 3.2 Mikä on ohjelmistokomponentti? 3.3 Komponentit ohjelmistoyksikköinä 3.4 Rajapinnat 3.6 Komponenttien räätälöinti
Tenttikysymykset. + UML- kaavioiden mallintamistehtävät
Tenttikysymykset 1. Selitä mitä asioita kuuluu tietojärjestelmän käsitteeseen. 2. Selitä kapseloinnin ja tiedon suojauksen periaatteet oliolähestymistavassa ja mitä hyötyä näistä periaatteista on. 3. Selitä
1 Johdanto. Pieni motivointikalvo. 1.1 Mikä on ohjelmistoarkkitehtuuri?
1 Johdanto 1.1 Mikä on ohjelmistoarkkitehtuuri? 1.2 Ohjelmistoarkkitehtuuri ja laatuvaatimukset 1.3 Katsaus ohjelmistotuotannon kehittymiseen 1.4 Miksi ohjelmistoarkkitehtuuri on tärkeä 1.5 Ohjelmistoarkkitehtuuri
Sisäänrakennettu tietosuoja ja ohjelmistokehitys
Sisäänrakennettu tietosuoja ja ohjelmistokehitys Petri Strandén 14. kesäkuuta, 2018 Petri Strandén Manager Cyber Security Services Application Technologies Petri.stranden@kpmg.fi Petri vastaa KPMG:n Technology
Ylläpito. Ylläpito. Ylläpidon lajeja Ohjelmistotuotanto, syksy 1998 Ylläpito
Kaikki ohjelmistoon sen julkistamisen jälkeen kohdistuvat muutostoimenpiteet jopa 70-80% ohjelmiston elinkaarenaikaisista kehityskustannuksista Ylläpidon lajeja korjaava ylläpito (corrective) testausvaiheessa
Arkkitehtuurin mallintaminen
Arkkitehtuurin mallintaminen Luento 6 19.9.2013 581385 Ohjelmistoarkkitehtuurit 1 Oppimistavoitteet Miksi ja milloin ohjelmistoarkkitehtuurista kannattaa laatia malleja? Ohjelmistoarkkitehtuurin kanoninen
Tekninen suunnitelma - StatbeatMOBILE
Tekninen suunnitelma - StatbeatMOBILE Versio Päivämäärä Henkilö Kuvaus 1.0 13.12.2013 Pöyry Alustava rakenne ja sisältö 1.1 22.12.2013 Pöyry Lisätty tekstiä ilmoituksiin, turvallisuuteen ja sisäiseen API:in
Järjestelmäarkkitehtuuri (TK081702) Pilvipalvelut. Pilvipalvelut - lähtökohtia
Järjestelmäarkkitehtuuri (TK081702) Pilvipalvelut Pilvipalvelut Nouseva toteutustekniikka ja trendi Kuluttajat edellä, yritykset perässä Paino sanalla Palvelu Yhtenäisyyksiä vuosikymmenten taakse, sovelletaan
Käyttäjien tunnistaminen ja käyttöoikeuksien hallinta hajautetussa ympäristössä
www.niksula.cs.hut.fi/~jjkankaa// Demosovelluksen tekninen määrittely v. 0.6 Päivitetty 11.12.2000 klo 20:26 Mickey Shroff 2 (12) Dokumentin versiohistoria Versio Päivämäärä Tekijä / muutoksen tekijä Selite
Helsingin yliopisto/tktl DO Tietokantojen perusteet, s 2000 Johdanto & yleistä Harri Laine 1. Tietokanta. Tiedosto
Tietokanta Tiedosto Tietokanta (database) jotakin käyttötarkoitusta varten laadittu kokoelma toisiinsa liittyviä säilytettäviä tietoja Ohjelmointikielissä apumuistiin tallennettuja tietoja käsitellään
TeliaSonera Identity and Access Management
TeliaSonera Identity and Access Management 22.10.2009 EMC Forum Juha Arjoranta 1 TeliaSonera Identity and Access Management Alustus käyttövaltuushallintaan IAM kokonaisratkaisun elementit Nykytilaa ja
Arkkitehtuurien tutkimus Outi Räihä. OHJ-3200 Ohjelmistoarkkitehtuurit. Darwin-projekti. Johdanto
OHJ-3200 Ohjelmistoarkkitehtuurit 1 Arkkitehtuurien tutkimus Outi Räihä 2 Darwin-projekti Darwin-projekti: Akatemian rahoitus 2009-2011 Arkkitehtuurisuunnittelu etsintäongelmana Geneettiset algoritmit
Järjestelmäarkkitehtuuri (TK081702)
Järjestelmäarkkitehtuuri (TK081702) yleistyvät verkkopalveluissa Youtube Google... Avaavat pääsyn verkkopalvelun sisältöön. Rajapintojen tarjoamia tietolähteitä yhdistelemällä luodaan uusia palveluja,
Ohjelmistotekniikan menetelmät, kesä 2008
582101 - Ohjelmistotekniikan menetelmät, kesä 2008 1 Ohjelmistotekniikan menetelmät Methods for Software Engineering Perusopintojen pakollinen opintojakso, 4 op Esitietoina edellytetään oliokäsitteistön
Tietojärjestelmä tuotantoympäristössä. Sovellusohjelmat Helsingin ammattikorkeakoulu Stadia / Tekniikka ja liikenne Vesa Ollikainen
Tietojärjestelmä tuotantoympäristössä Tausta ja tavoitteet Tausta Kurssilla on opiskeltu suunnittelemaan ja toteuttamaan tietokanta, joka on pieni perustuu selkeisiin vaatimuksiin on (yleensä) yhden samanaikaisen
Ylläpito. Ylläpidon lajeja
Ylläpito Kaikki ohjelmistoon sen julkistamisen jälkeen kohdistuvat muutostoimenpiteet jopa 70-80% ohjelmiston elinkaarenaikaisista kehityskustannuksista Ylläpidon lajeja korjaava ylläpito (corrective)
7. Tuoterunkoarkkitehtuurit
7. Tuoterunkoarkkitehtuurit Johdanto Näkökulmat tuoterunkoihin perustuvaan ohjelmistokehitykseen Kerrostyyli tuoterunkoarkkitehtuureille Tuoterunkojen etuja ja ongelmia 1 Uudelleenkäytt yttö opportunistinen:
UML:n yleiskatsaus. UML:n osat:
UML:n yleiskatsaus - voidaan hyödyntää hyvin laajasti. - sopii liiketoimintamallinnukseen, ohjelmistomallinnukseen sen jokaiseen vaiheeseen tai minkä tahansa pysyviä ja muuttuvia ominaisuuksia sisältävän
TOIMINNALLINEN MÄÄRITTELY MS
TOIMINNALLINEN MÄÄRITTELY 11.11.2015 MS YLEISTÄ 1/2 jäsennelty etenee yleiskuvauksesta yksityiskohtiin kieliasultaan selkeä kuvaa myös tulevan järjestelmän ympäristöä tarpeellisella tarkkuudella kuvaa
Ohjelmistojen mallintaminen. Luento 11, 7.12.
Ohjelmistojen mallintaminen Luento 11, 7.12. Viime viikolla... Oliosuunnittelun yleiset periaatteet Single responsibility eli luokilla vain yksi vastuu Program to an interface, not to concrete implementation,
Johdatus rakenteisiin dokumentteihin
-RKGDWXVUDNHQWHLVLLQGRNXPHQWWHLKLQ 5DNHQWHLQHQGRNXPHQWWL= rakenteellinen dokumentti dokumentti, jossa erotetaan toisistaan dokumentin 1)VLVlOW, 2) UDNHQQHja 3) XONRDVX(tai esitystapa) jotakin systemaattista
HELIA 1 (8) Outi Virkki Tietokantasuunnittelu
HELIA 1 (8) Luento 1 Johdatusta tietokannan suunnitteluun... 2 Tietokantasuunnittelu?... 2 Tietokanta?... 2 Tieto?... 2 Tietokantasuunnittelun tavoite, v.1... 2 Luotettavuus?... 3 Tietokantasuunnittelun
Arkkitehtuurikuvaus. Ratkaisu ohjelmistotuotelinjan monikielisyyden hallintaan Innofactor Oy. Ryhmä 14
Arkkitehtuurikuvaus Ratkaisu ohjelmistotuotelinjan monikielisyyden hallintaan Innofactor Oy Ryhmä 14 Muutoshistoria Versio Pvm Päivittäjä Muutos 0.4 1.11.2007 Matti Eerola 0.3 18.10.2007 Matti Eerola 0.2
Ohjelmistotekniikka - Luento 2 Jouni Lappalainen
Ohjelmistotekniikka - Luento 2 Jouni Lappalainen Luku 2: Prosessimallit - miten spiraalimalliin päädyttiin - spiraalimallista (R)UP malliin - oman ammattitaidon kehittäminen; PSP ja TSP mallit 1 Luento
Tämän lisäksi listataan ranskalaisin viivoin järjestelmän tarjoama toiminnallisuus:
Dokumentaatio, osa 1 Tehtävämäärittely Kirjoitetaan lyhyt kuvaus toteutettavasta ohjelmasta. Kuvaus tarkentuu myöhemmin, aluksi dokumentoidaan vain ideat, joiden pohjalta työtä lähdetään tekemään. Kuvaus
Järjestelmäarkkitehtuuri (TK081702) Web Services. Web Services
Järjestelmäarkkitehtuuri (TK081702) Standardoidutu tapa integroida sovelluksia Internetin kautta avointen protokollien ja rajapintojen avulla. tekniikka mahdollista ITjärjestelmien liittämiseen yrityskumppaneiden
Ohjelmistojen mallinnus Ohjelmistoarkkitehtuuri Harri Laine 1
Ohjelmistojen mallinnus Ohjelmistoarkkitehtuuri 2 28.11.2008 Harri Laine 1 Ohjelmistoarkkitehtuuri Rajapinta UML:ssä piirteiden (attribuuttien ja operaatioiden) kokoelma, josta ei voi suoraan luoda ilmentymiä
IT-OSAAJA, TIETOJENKÄSITTELYN ERIKOISTUMISOPINNOT
IT-OSAAJA, TIETOJENKÄSITTELYN ERIKOISTUMISOPINNOT KOULUTUKSEN KOHDERYHMÄ SISÄLTÖ Koulutuksen tavoitteena on antaa opiskelijalle valmiudet uusien tietoteknisten menetelmien ja välineiden hyödyntämiseen.
Tietokannan suunnittelu
Informaatioteknologian instituutti IIO30100 Tietokantojen suunnittelu Tietokannan suunnittelu kirjan Hovi, Huotari, Lahdenmäki: Tietokantojen suunnittelu & indeksointi, Docendo (2003, 2005) luku 2 Jouni
Ohjelmistoarkkitehtuurit Kevät käytäntöjä
Ohjelmistoarkkitehtuurit Kevät 2014 -käytäntöjä Samuel Lahtinen http://www.cs.tut.fi/~ohar/ 8.1.2014 1 Tervetuloa Oulun yliopisto, Tampereen yliopisto, Turun yliopisto, Tampereen teknillinen yliopisto
Ohjelmistoarkkitehtuuri
Ohjelmistoarkkitehtuurien ylläpito Arkkitehtuurityylejä ja laatuvaatimuksia Arkkitehtuurin uudistaminen Arkkitehtuurin uudistamisen malleja Arkkitehtuurin arviointi TTY Ohjelmistotekniikka 1 Ohjelmistoarkkitehtuuri
Tiedonsiirto- ja rajapintastandardit
Tiedonsiirto- ja rajapintastandardit Viitekehys Julkishallinnon perustietovarantojen rajapinnat (PERA) työryhmän tulokset valmiit syksyllä 2011 Määrittelee teknisen arkkitehtuuriratkaisun tietovarantojen
Kurssin hallinta -työväline
Kurssin hallinta -työväline Kurssin hallinta -työvälineellä muokataan kursseja A&Ooppimisympäristöalustalla Kurssi koostuu - ohjelmasta (linkit työkaluihin& muihin resursseihin), - materiaaleista, - keskusteluryhmästä,
LAS- ja ilmakuva-aineistojen käsittely ArcGIS:ssä
Esri Finland LAS- ja ilmakuva-aineistojen käsittely ArcGIS:ssä November 2012 Janne Saarikko Agenda Lidar-aineistot ja ArcGIS 10.1 - Miten LAS-aineistoa voidaan hyödyntää? - Aineistojen hallinta LAS Dataset
Oleelliset vaikeudet OT:ssa 1/2
Oleelliset vaikeudet OT:ssa 1/2 Monimutkaisuus: Mahdoton ymmärtää kaikki ohjelman tilat Uusien toimintojen lisääminen voi olla vaikeaa Ohjelmista helposti vaikeakäyttöisiä Projektiryhmän sisäiset kommunikointivaikeudet
JHS 179 Kokonaisarkkitehtuurin suunnittelu ja kehittäminen Liite 9. Virtualisointi ja pilvipalvelut teknologia-arkkitehtuurin suunnittelussa
JHS 179 Kokonaisarkkitehtuurin suunnittelu ja kehittäminen Liite 9. Virtualisointi ja pilvipalvelut teknologia-arkkitehtuurin suunnittelussa Versio: Palautekierros, 2. palautekierros Julkaistu: Voimassaoloaika:
Ohjelmistoarkkitehtuurit, syksy
Ohjelmistoarkkitehtuurit Tuoteperheet Tuoterunkoarkkitehtuurit Perinteisessä ohjelmistotuotannossa on keskitytty uusien ohjelmistojen laadukkaaseen tuottamiseen Erikoistuneista ainutlaatuisista vaatimuksista
Miten voin selvittää säästömahdollisuuteni ja pääsen hyötymään niistä?
Se edullisempi tietokanta Miten voin selvittää säästömahdollisuuteni ja pääsen hyötymään niistä? Rasmus Johansson rasmus.johansson@microsoft.com Ratkaisumyyntipäällikkö (Sovellusalusta) Microsoft Oy Miten
Standardi IEC Ohjelmisto
Sundcon Oy Standardi IEC 61508 3 Ohjelmisto muutokset Matti Sundquist Sundcon Oy www.sundcon.fi Standardi IEC 61508 3 (1) Standardissa di esitetään vaatimukset niiden tietojen ja menettelytapojen valmisteluun,
Käytännön haasteita ja ratkaisuja integraation toteutuksessa. Jukka Jääheimo Teknologiajohtaja Solita Oy
Käytännön haasteita ja ratkaisuja integraation toteutuksessa Jukka Jääheimo Teknologiajohtaja Solita Oy 13.03.2008 Sisältö 2 Alustus Integraation haasteet Integraatioarkkitehtuuri Hyvän integraatioarkkitehtuurin
SEPA - Design Patterns
SEPA - Design Patterns Kimmo Karlsson, 51066R & Antti Pirinen, 51406N 15. maaliskuuta 2005 1 Sisältö 1. Sisältö 2. Johdanto 3. Käyttöönotto 4. Käyttökokemukset 2 Johdanto Valitsemamme ohjelmistonkehityskäytäntö
Ohjelmistojen mallintaminen, arkkitehtuuria ja rajapintoja
582104 Ohjelmistojen mallintaminen, arkkitehtuuria ja rajapintoja 1 Arkkitehtuurisuunnittelu Ohjelmistoarkkitehtuurin määritelmä & arkkitehtuurisuunnittelun lähtökohta ja tavoitteet Kerrosarkkitehtuuri
Toimilohkojen turvallisuus tulevaisuudessa
Toimilohkojen turvallisuus tulevaisuudessa Turvallisuusseminaari ASAF 30.10-1.11.2006 Mika Strömman Teknillinen korkeakoulu 1 Sisältö Luotettavuuden lisääminen hyvillä tavoilla Toimilohkokirjastot Turvatoimilohkot
Yleisiä asioita. Harkat alkavat ensi viikolla Vierailuluentoa. Slackin #luennot-kanava taas käytössä. Ensi viikon perjantaina, Janne Viitala, Sandvik
Yleisiä asioita Harkat alkavat ensi viikolla Vierailuluentoa Ensi viikon perjantaina, Janne Viitala, Sandvik Slackin #luennot-kanava taas käytössä 1 1 Johdanto 1.1 Mikä on ohjelmistoarkkitehtuuri? 1.2
Ohjelmistojen mallinnus (OMa) - Johdatus ohjelmistotuotantoon Harri Laine 1
Ohjelmistojen mallinnus (OMa) - Johdatus ohjelmistotuotantoon 31.10.2008 Harri Laine 1 Ohjelmisto Tietokoneohjelma (computer program) toimintaohje, jonka mukaan toimien tietokone suorittaa jonkin tietojenkäsittelytehtävän
Arkkitehtuurin mallintaminen
Arkkitehtuurin mallintaminen Luento 7 25.9.2014 581385 Ohjelmistoarkkitehtuurit 1 Oppimistavoitteet Miksi ja milloin ohjelmistoarkkitehtuurista kannattaa laatia malleja? Ohjelmistoarkkitehtuurimallin ohjeellinen
Ohjelmistoarkkitehtuurit 2016. Kevät 2016 -käytäntöjä
Ohjelmistoarkkitehtuurit Kevät 2016 -käytäntöjä Samuel Lahtinen http://www.cs.tut.fi/~ohar/ 13.1.2016 1 Tervetuloa Tampereen teknillinen yliopisto, Oulun yliopisto, Turun yliopisto 13.1.2016 2 Tiedonvälitys
Suorituskyky ja ohjelmistokehitys Suorituskykymallit
Suorituskyky ja ohjelmistokehitys Suorituskykymallit Luento 2 58153003 Ohjelmistojen suorituskyky 1 SUORITUSKYKYISTEN OHJELMISTOJEN KEHITTÄMINEN 58153003 Ohjelmistojen suorituskyky 2 Helsingin Yliopisto
Tietosisällön eheys. Kimmo Janhunen Riskienhallintapäällikkö
Tietosisällön eheys Kimmo Janhunen kimmo.janhunen@om.fi Riskienhallintapäällikkö Oikeusrekisterikeskuski k 26.11.2014 Esityksen sisältö Tiedon merkitys - tiedon eheyden merkitys Määritelmät Lainsäädäntö
Tenttikysymykset. + UML- kaavioiden mallintamistehtävät
Tenttikysymykset 1. Selitä mitä asioita kuuluu tietojärjestelmän käsitteeseen. 2. Selitä kapseloinnin ja tiedon suojauksen periaatteet oliolähestymistavassa ja mitä hyötyä näistä periaatteista on. 3. Selitä
Järjestelmäarkkitehtuuri (TK081702) Lähtökohta. Integroinnin tavoitteet
Järjestelmäarkkitehtuuri (TK081702) Integraation tavoitteita Lähtökohta Web-palvelut Asiakasrekisteri ERP, Tuotannon ohjaus Tuotanto Myynti Intranet Extranet? CRM Johdon tuki Henkilöstö Kirjanpito Palkanlaskenta
10. Tuoterunkoarkkitehtuurit
10. Tuoterunkoarkkitehtuurit Johdanto Näkökulmat tuoterunkoihin perustuvaan ohjelmistokehitykseen: liiketoiminta, organisaatio, prosessi, tekninen Tuoterunkojen etuja ja ongelmia 1 Uudelleenkäytt yttö
Suorituskyvyn varmistaminen sovelluskehityksen eri vaiheissa Paavo Häkkinen, Presales Teamleader Compuware Finland
Suorituskyvyn varmistaminen sovelluskehityksen eri vaiheissa Paavo Häkkinen, Presales Teamleader Compuware Finland Epäonnistuminen ei ole vaikeaa Approximately 40% of mission-critical mainframe projects
Digi-tv vastaanottimella toteutetut interaktiiviset sovellukset
Tekninen määrittely: Editori Digi-tv vastaanottimella toteutetut interaktiiviset sovellukset Sisällysluettelo 1. Johdanto...4 1.1. Tarkoitus ja kattavuus...4 1.2. Tuote ja ympäristö...4 1.3. Määritelmät,
6. Arkkitehtuurityylit
6. Arkkitehtuurityylit Osittavat arkkitehtuurityylit - Kerrosarkkitehtuurit - Tietovuoarkkitehtuurit Palveluihin perustuvat arkkitehtuurityylit - Asiakas-palvelin arkkitehtuurit - Viestinvälitysarkkitehtuurit
Ohjelmistojen mallinnus, s2008 HY/TKTL, 28/10/2008. Harri Laine 1. Ohjelmisto
jen mallinnus, s2008 jen mallinnus (OMa) - Johdatus ohjelmistotuotantoon Tietokoneohjelma (computer program) toimintaohje, jonka mukaan toimien tietokone suorittaa jonkin tietojenkäsittelytehtävän suoritettava