66
Ohjelmistoarkkitehtuurit, TTY Vierailuluento Mika Siikarla, 31.1.2012

Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

Embed Size (px)

Citation preview

Page 1: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

Ohjelmistoarkkitehtuurit, TTY

Vierailuluento

Mika Siikarla, 31.1.2012

Page 2: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

Jotain IHAN muuta...

Tamperelainen ohjelmistotalo

Page 3: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko
Page 4: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

Bitwise pähkinänkuoressa

Page 5: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

• Sopivan kokoinen (43 henkeä)

• Kannattavan kasvava, AAA

• Koko tuplaantui laman aikana

• Vuonna 2012 palkattu 12 henkeä

• Hyvässä paikassa (Viinikan ympyrässä)

Page 6: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

Bitwise valittiin Suomen parhaaksi työpaikaksi 2012

Page 7: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

Bitwiserit hoitavat projektit, joihin kukaan muu pysty

• haasteita• mielenkiintoisia pulmia• vaihtelevia tehtäviä• jatkuvaa uuden oppimista• yhdessä tekemistä

onnistumisia sankaritarinoita tyytyväiset asiakkaat

Page 8: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

• Kaikki on helppoa (=lean)

• Ketterät menetelmät

• Markkinoiden parhaat välineet ja työkalut

• Jokaisella mahdollisuus vaikuttaa

• Kaikki mukana asiakasrajapinnassa

• Projektikierto

• Mukana koko elinkaaressa

• Tiimi istuu samassa huoneessa

• Mentori valmentaa

• Illaksi kotiin

Page 9: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

» .NET, C#, C++

» JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, Play 2.0...

» sulautetut järjestelmät, C

» Python, Django

» JavaScript, node.js, CoffeeScript

» HTML5, CSS3, LESS, Jquery

» PHP, Perl, TCL

» Web Services, REST, SOAP, CORBA, Remoting, RMI

» SOA, ESB

» PostgreSQL, Oracle, SQLServer, MySQL, MongoDB, CouchDB, light-tietokannat, ORM-kehykset

» WPF, Qt, Java FX2, Swing, AWT, Windows Forms...

» Linux, Windows, Unix, Solaris, reaaliaikaytimet

» Scrum, Kanban, CI, TDD, BDD

» Git, SVN, Jenkins, Bamboo, JIRA, Trac

Mm. näillä teknologioilla

Page 10: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko
Page 11: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko
Page 12: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko
Page 13: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko
Page 14: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

Bitwise etsii ihmisiä,

joilla on

Page 15: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

• Halu oppia

• Kyky oppia

• Rohkeutta hypätä uuteen

• Maalaisjärkeä

• Ammattiylpeyttä

• Input ja output

• Tiimipelitaitoja

• Pohojalaanen tekemisen meininki

• Rohkeutta olla oma itsensä

Page 16: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

Bitwise houkuttelee opiskelijaa

Page 17: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

Kukaan ei ole guru syntyessään

– meillä voit kasvaa sellaiseksi

Page 18: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

Tarjolla

• Osa-aikaisia töitä

• Kesätöitä

• Lopputyöaiheita

Bonuksena palkallinen päivä viikossa kirjoittamiseen

Page 19: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

Hyvät kaverit vakinaistetaan, poikkeuksetta

Page 20: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

Ryhdy bitwiseriksi!

Lue lisää www.bitwise.fi

Lähetä hakemus [email protected]

Page 21: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

Vastuuvapauslauseke

Page 22: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

MIELIPIDE

Omia henkilökohtaisia mielipiteitäni.

Tietysti ovat ainoita oikeita!

Ehkä joku muukin on joskus ollut samaa mieltä joistakin kohdista.

”These are my principles. If you don’t like them I have others.”

- Groucho Marx (ilmeisesti ei)

Aivot päälle.

RIIPPUU VASTAAJASTA JA KYSYJÄSTÄ(ja ehkä aiheestakin)

Page 23: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

Arkkitehtuuri

Page 24: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

ARKKITEHTUURI

Suunnittelijan näkökulmasta joukko suunnittelua rajoittavia sääntöjä.

Se mitä suunnittelija mielestään saa tehdä.

Se mitä arkkitehdin mielestä suunnittelija saa tehdä.

Subjektiivisia! Ei ole olemassa ”todellista” arkkitehtuuria.

Ei RTFC, ei takaisinmallinnettavissa.

ON (ja vaatii) KOMMUNIKOINTIA(dokumentointi, keskustelu, … ?)

Page 25: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

ARKKITEHTUURI

Teknisessä mielessä koodista voidaan löytää komponentteja ja niiden välisiä suhteita, mutta mitkä ovat säännöt?

Vrt. pelinappulat ja lauta ilman pelin sääntöjä.

Tai pelinappulalta vaikuttavia osia...

ON (ja vaatii) KOMMUNIKOINTIA

Page 26: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

Arkkitehti

Page 27: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko
Page 28: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

ARKKITEHTI

En ole ammatiltani arkkitehti. Minun ammattini on ohjelmistosuunnittelija.

Bitwisellä ei ole töissä ketään, jonka ammatti on arkkitehti.

EI ASU TÄÄLLÄ

Page 29: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

ARKKITEHTI

Hän, joka tekee arkkitehtuurin (osan)...

sillä hetkellä, kun hän tekee {}...

siltä osin kuin hänen tekemisensä liittyy {}.

Rooli, tietyssä suhteessa ja tietyssä kontekstissa.

Kuten kuuntelija, puhuja, veli, opettaja, oppilas, ajaja, ...

ON ARKKITEHTI TOIMIESSAAN ARKKITEHTINA(da Vinci)

Page 30: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

ARKKITEHTI

ArchitectAlsoImplementshttp://orgpatterns.wikispaces.com/ArchitectAlsoImplements

”The Architect [...] should himself or herself write code.”

”[...] it is crucial that the architect have a strong feel for the application needs. It is by understanding recurring application needs that the architect can build long-term robust frameworks. If architects work only on infrastructure […] there will be a disconnect between the infrastructure (framework, middleware) and the application.”

OSS: Eat your own dog food.

TOIMII MYÖS TOTEUTTAJANA

Page 31: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

Vaatimukset → Arkkitehtuuri

Page 32: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

VAATIMUKSET

PERUSTELEVAT ARKKITEHTUURIN

(Erityisesti ei-toiminnalliset) vaatimukset rajoittavat arkkitehtuuria.

Arkkitehtuuripäätösten perustelut vaatimuksista.

Vaatimukset

Arkkitehtuuri

toteuttaa

Page 33: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

VAATIMUKSET

ELÄVÄT(elääkö arkkitehtuuri?)

Vaatimusten muutosten pitäisi näkyä arkkitehtuurin muutoksina.

Ehkä otettu huomioon?

Ehkä vanha kelpaa?

Ehkä kohta palataan takaisin?

Massa: uutta vai parempaa?

Vaatimukset

Arkkitehtuuri

toteuttaa

Vaatimukset

Arkkitehtuuri

toteuttaa

Vaatimukset

Arkkitehtuuri

toteuttaa

Page 34: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

VAATIMUKSET

EIVÄT AINA TIEDOSSA

Jos Kun vaatimuksia ei tunneta kokonaisuudessaan, onko arkkitehtuurille kokonaisuudessaan perusteita?

Esim. suorituskyky, suoritustapa.

Lukitaanko vastaus?

?a??im?k?e?

Ar??it?h??uri

toteuttaa??

Page 35: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

Kurkistus oikeaan maailmaan

Page 36: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

OHJELMISTO

TYHJIÖSSÄ

J

Asiakas

Page 37: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

OHJELMISTO

YMPÄRISTÖSSÄÄN(muiden ohjelmistojen kanssa)

J +

Toimittaja Operaattori

Page 38: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

OHJELMISTO

YMPÄRISTÖSSÄÄN(laitteiden ja muiden ohjelmistojen kanssa)

J +

Toimittaja Operaattori

Page 39: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

OHJELMISTO

YMPÄRISTÖSSÄÄN(prosessien, laitteiden ja muiden ohjelmistojen kanssa)

J +

Toimittaja Operaattori

Page 40: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

OHJELMISTO

YMPÄRISTÖSSÄÄN(integrointien, prosessien, laitteiden ja muiden ohjelmistojen kanssa)

J +

Toimittaja Operaattori

Page 41: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

Ekskursio ympäristöön

Page 42: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

TOIMINTAYMPÄRISTÖ

Ohjelmistoja: ohjaus, turvallisuus, tarkkailu

Koneita: autom., ajettuja, etäohjattuja, autom.+etä

Tilaa: 3D, jaettua, neuvoteltua

Esineitä: siirrettäviä

Esteitä: pysyviä, tilapäisiä

Rajoitteita: kulku, käyttö; loogisia, osittaisia

Infraa: antureita, kytkimiä, verkkoja

Ihmisiä

Suurin osa operaattorin hallinnassa, pieni osa ei...

ON MONIMUOTOINEN

Page 43: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

MITÄ EI VAADITA

Ei (suoranaista) (yksin)vastuuta ihmisten hengestä tai terveydestä.

Ei kovia reaaliaikavaatimuksia.

Suurin osa toiminnallisuudesta ei vaadi resursseihin nähden intensiivistä laskentaa, muistia tai tallennusta.

ON OSA VAATIMUKSIA(ja siksi vaikuttaa arkkitehtuurin prioriteetteihin)

Page 44: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

Backtrack palluroihin

Page 45: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

OperaattoriOperaattoriOperaattoriOperaattori

OHJELMISTO

MONESSA YMPÄRISTÖSSÄ

Toimittaja

Page 46: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

OHJELMISTO

YHDESSÄ YMPÄRISTÖSSÄ(integrointien, prosessien, laitteiden ja muiden ohjelmistojen kanssa)

J +

Toimittaja Operaattori

Page 47: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

OHJELMISTO

TOISESSA YMPÄRISTÖSSÄ(integrointien, prosessien, laitteiden ja muiden ohjelmistojen kanssa)

J +

Toimittaja Operaattori

Page 48: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

? ? ? ?

? ? ? ? ?? ? ?

?

OHJELMISTO

TULEVASSA YMPÄRISTÖSSÄ(integrointien, prosessien, laitteiden ja muiden ohjelmistojen kanssa)

J +

Toimittaja Operaattori

Page 49: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

TOIMINTAYMPÄRISTÖ

Toimitukset eri laajuisia: toimittajan ja operaattorin järjestelmien osuus vaihtelee

Toimitukset eri vaiheissa: määrittely, osatoimitus, lopputoimitus, ylläpito.

Tuotteet eri vaiheissa.

Opitaan ympäristöstä lisää; vaatimukset muuttuvat.

Simulaatio kokeilu aito ympäristö↔ ↔

VAIHTELEE

Page 50: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

MONTA TUOTETTA

Prototyyppi

Kypsä tuote ==> arkkitehtuuri??

Tuoterunko

Suuri kannuste yhtenäistää.

MONTAKO ARKKITEHTUURIA?

Page 51: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

Tekninen ympäristö

Page 52: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

KOMPONENTTIEN UUDELLEENKÄYTTÖ

Ympäristö

J+K

J

J'

Bitwise

~200 kloc C#

Page 53: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

VAATIMUSTEN KYPSYYS

Prototyyppi: vaatimukset ovat arvauksia, arkkitehtuuri on arvaus

Kypsä tuote: vaatimukset (melko hyvin) tiedossa, arkkitehtuuri (melko) vakaa

Tuoterunko: vaatimukset olemassaolevista ja ennakoiduista tuotteista

RAJOITTAA ARKKITEHTUURIN KYPSYYTTÄ

Page 54: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

VAATIMUSTEN KYPSYYS

Prototyyppi:

arvaus (kehitys kokeilu oppiminen)+ OK→ → → →

Syklin nopeus tärkein ei-toiminnallinen vaatimus!

Ymmärrettävyys ja muunneltavuus erittäin tärkeitä.

Muilta osin arkkitehtuuriin panostaminen menee hukkaan.

Kypsä tuote:

Uudelleenkäytön mahdollistamiseksi olisi kiva olla lähellä muiden tuotteiden arkkitehtuuria.

MÄÄRÄÄ ARKKITEHTUURIN KYPSYYTTÄ

Page 55: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

HYVIN TEHTY ARKKITEHTUURI

Ensin ominaisuuden kehityssykli. Kun OK ja ETV tiedossa, tehdään arkkitehtuuri kunnolla, kun päätökset perusteltavissa. Ei hätäillä arkkitehtuurin kanssa.

Arkkitehtuuri laahaa perässä, ei täysin yhtenäinen.

Ryhdin parantaminen perustellusti: roi, hidastavuus, yhtenäistys (J, J*, J+K, ...)...

Kevyet analyysit: takaraivossa todo-list, wtf/min, pelkokerroin, jne.

ON TEHTY HYVIEN TIETOJEN PERUSTEELLA(garbage in, garbage out)

Page 56: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

HYVIN TEHTY ARKKITEHTUURI

Poikkeuksia: muutokset ytimeen, liikaa hidasteita

Viivästetään? Häkätään silti?

Ei lupa luopua arkkitehtuurisuunnittelusta.

Ei vähennetä arkkitehtuurin tärkeyttä – kasvatetaan sitä!

ON TEHTY HYVIEN TIETOJEN PERUSTEELLA(garbage in, garbage out)

Page 57: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

ARKKITEHTUURI

Ei lupa luopua arkkitehtuurisuunnittelusta.

Ei vähennetä arkkitehtuurin tärkeyttä – kasvatetaan sitä!

Poikkeuksia: muutokset ytimeen, liikaa hidasteita

Viivästetään? Häkätään silti?

Poikkeuksia: keskeiset, esim. käynnistys, failover, toipuminen, tiedon pysyvyys, ...

HALLITUSSA KAAOKSESSA(how and why to fake it)

Page 58: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

PELASTA YDIN

Tuoterunko ja yhtenäistys vs. (?) muokattavuus.

Suojele ydintä! Keskeinen sovellusalalogiikka.

Suojele pikkuytimiä!

”Kypsyyskerrokset”: muutoksille alttiit ulompana. Aika kypsyttää.

Abstrahointi, ryhmittely, sovittimet, sillat, samaistus, rajapinnat,

PELASTAT ARKKITEHTUURIN

Page 59: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

Oikeahko esimerkki

Page 60: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

J

J ja M neuvottelevat suoraan resurssin R käytöstä

M L

Page 61: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

Olipa kerran väylä

HÄK HÄK HÄK

MJ

L

BUS

M-kanava

Page 62: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

”Joku muukin voisi käyttää väylää”

Erotetaan väylän ja M:n käsittely

MJ

Lkanava

protokolla

M-proxy

BUS

Uudelleenkäytettävä

Page 63: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

J, M ja N neuvottelevat...

HÄK HÄK HÄK

MJ

Lkanava

protokolla

M-proxy

BUS N

Uudelleenkäytettävä

Page 64: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

”Voisi varmaan olla muitakin kuin J, M, N...”

Välittäjä hoitaa skeduloinnin.(mikä tahansa määrä neuvottelijoita; mille tahansa resurssille)

MJ

Lkanava

protokolla

M-proxy

BUS

välittäjä

N

Uudelleenkäytettävä

Page 65: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

Loppuisipa jo!

Page 66: Ohjelmistoarkkitehtuurit, TTY Vierailuluentoohar/luennot/luennot2012/ohar 2012 - siikarla.pdf · » JavaEE, Spring 3, EJB3, GWT, JSF2, PrimeFaces, JPA2, JTA, JCA, JMS, OSGi, ... Tuoterunko

Kysymyksiä?