Avoin lähdekoodi

Avoin lähdekoodi (engl. open source) tarkoittaa ohjelmistojen tuottamis- ja kehitysmenetelmiä, jotka tarjoavat käyttäjälle mahdollisuuden tutustua ohjelman lähdekoodiin ja muokata sitä omien tarpeidensa mukaisesti. Avoimen lähdekoodin periaatteisiin kuuluu myös vapaus käyttää ohjelmaa mihin tahansa tarkoitukseen ja kopioida ja levittää sekä alkuperäistä että muokattua versiota.

Paitsi ohjelmistojen kehitysmenetelmiin avoimella lähdekoodilla voidaan viitata myös niiden avulla tuotettuihin ohjelmistoihin sekä kehittäjäyhteisöön. Käytännössä avoin lähdekoodi tarkoittaa pitkälti samaa asiaa kuin vapaat ohjelmistot, joista puhuttaessa halutaan usein painottaa ohjelmistokehityksen eettisiä ulottuvuuksia. Avoimesta lähdekoodista puhuttaessa huomio saattaa pikemminkin kiinnittyä vapaudesta ja avoimuudesta seuraaviin käytännön hyötyihin. Vapaiden ohjelmistojen ja avoimen lähdekoodin vastakohtana voidaan pitää omisteisia ohjelmistoja ja suljettua lähdekoodia.

Tunnetuimpia avoimen lähdekoodin tuotteita ovat Firefox-selain, LibreOffice-toimisto-ohjelmisto ja Linux-käyttöjärjestelmä, joka pääosin muodostuu Linux-ytimestä ja GNU-hankkeen ohjelmistoista. Myös älypuhelimissa yleinen Android-käyttöjärjestelmä on avointa lähdekoodia[1].

Historia

1960- ja 1970-luvuilla ohjelmointia tehtiin akateemisissa ympäristöissä ja yritysten laboratorioissa, jotka jakoivat ja muokkasivat ohjelmistoja vapaasti.[2] 1980-luvulla ohjelmointi siirtyi omisteisiin ohjelmistoihin ja Richard Stallman kirjoitti vapaan ohjelmiston ideologiasta sekä ohjelmistojen tekijänoikeuksista.[2] Vuonna 1998 tapahtui merkittävä muutos kun Bruce Perens ja Eric Raymond ilmaisivat epäilyksenä etteivät yritykset ole vakuuttuneita Stallmanin näkemyksistä: tämä johti avoimen lähdekoodin liikkeeseen.[2]

Avoin lähdekoodi viittasi aluksi avoimen lähdekoodin ohjelmistoihin, mutta avoimesta lähdekoodista on tullut liike, joka ulottuu ohjelmistotuotannon ulkopuolelle.[3] Termin avoin lähdekoodi on esittänyt Christine Peterson.[4][3] Termi kehitettiin vaihtoehdoksi, koska termi "vapaa ohjelmisto" vaati aina selityksen sen tarkoittavan oikeuksia eikä hintaa ja oli tarve selkeämmälle termille.[4] Raymond otti termin käyttöön, Perens perusti Opensource.org:in sekä Tim O'Reilly sopi käyttävänsä sitä useissa projekteissa.[4] Termiä käytettiin Netscape Navigatorin lähdekoodin julkaisussa ja O'Reilly & Associatesilla: 7. huhtikuuta 1998 järjestettiin ensimmäinen Open Source Summit -kokoontuminen.[4][5]

Määritelmä

Pelkkä mahdollisuus päästä tutustumaan lähdekoodiin ei vielä tee ohjelmistosta avoimen lähdekoodin edustajaa, vaan oikeudellisesta näkökulmasta avoimeen lähdekoodiin liittyy lisenssi, jolla ohjelman tekijä tarjoaa teoksensa yhteisön käytettäväksi ja muokattavaksi. Lisenssi voi kuitenkin asettaa ehdoksi, että ohjelmaan tehtävät muutoksetkin on julkaistava samalla lisenssillä, jotta myös alkuperäinen tekijä pääsisi hyötymään muiden tekemistä parannuksista. Tekijänoikeudet säilyvät koodin kirjoittajilla, jolleivät nämä erikseen niistä luovu.

Avoimen lähdekoodin tunnuspiirteet on täsmällisesti määritellyt Open Source Initiative (OSI) -järjestö, joka pyrkii edistämään avoimen lähdekoodin ohjelmistojen käyttöä:[6]

  1. Ohjelman täytyy olla vapaasti levitettävissä ja välitettävissä.
  2. Lähdekoodin täytyy tulla ohjelman mukana tai olla vapaasti saatavissa.
  3. Myös johdettujen teosten luominen ja levitys pitää sallia.
  4. Lisenssi voi rajoittaa muokatun lähdekoodin levittämistä vain siinä tapauksessa, että lisenssi sallii erillisten korjaustiedostojen ja niiden lähdekoodin levittämisen. Voidaan myös vaatia, ettei johdettua teosta levitetä samalla nimellä tai versionumerolla kuin lähtöteosta.
  5. Yksilöitä tai ihmisryhmiä ei saa asettaa eriarvoiseen asemaan.
  6. Käyttötarkoituksia ei saa rajoittaa.
  7. Kaikilla ohjelman käsiinsä saaneilla on samat oikeudet.
  8. Lisenssi ei saa olla riippuvainen laajemmasta ohjelmistokokonaisuudesta, jonka osana ohjelmaa levitetään, vaan ohjelmaan liittyvät oikeudet säilyvät, vaikka se irrotettaisiin kokonaisuudesta.
  9. Lisenssi ei voi asettaa ehtoja muille ohjelmille. Ohjelmaa saa levittää myös yhdessä sellaisten ohjelmien kanssa, joiden lähdekoodi ei ole avointa.
  10. Lisenssin sisällön pitää olla riippumaton teknisestä toteutuksesta. Oikeuksiin ei saa liittää varaumia jakelutavan tai käyttöliittymän varjolla.

Näiden kriteerien mukaan esimerkiksi seuraavilla lisensseillä julkaistuja ohjelmistoja voidaan pitää avoimen lähdekoodin edustajina: GNU General Public License (GPL) ja GNU Lesser General Public Licence (LGPL), BSD-lisenssit, Mozilla Public License (MPL), Apache-lisenssit, IBM Public License, Intel Open Source License, Apple Public Source License, Nokia Open Source License sekä Sun Microsystemsin Sun Industry Standards Source License ja Sun Public License. Eri lisenssityyppejä käsitellään julkisen hallinnon suosituksessa JHS 169 Avoimen lähdekoodin ohjelmien käyttö julkisessa hallinnossa.[7]

Avoin lähdekoodi vai vapaa ohjelmisto?

Eric Raymondin essee The Cathedral and the Bazaar huomioi avoimen lähdekoodin merkityksen ohjelmiston kehitysmenetelmään vuonna 1997.[8] Richard Stallmanin mukaan termit vapaa ohjelmisto ja avoin lähdekoodi kuvaavat lähes samoja asioita, mutta eri arvoihin perustuvia näkemyksiä: avoin lähdekoodi on kehitysmenetelmä kun taas vapaa ohjelmisto on sosiaalinen liike.[8]

Termi avoin lähdekoodi kehitettiin helmikuussa 1998 vastauksena Netscapen päätökseen julkaista verkkoselaimensa lähdekoodit vapaalla lisenssillä. Osa vapaiden ohjelmistojen liikkeen edustajista halusi ottaa etäisyyttä liikkeen ideologiseen taustaan ja muotoilla toimintamallinsa pragmaattisemmin termein, jotka sopisivat myös yrityselämän käyttöön paremmin kuin englanninkielinen sana free, joka voi tarkoittaa paitsi vapaata myös ilmaista. Linux-ytimen alkuperäinen kehittäjä Linus Torvalds asettui heti tukemaan uutta nimitystä ja sen edustamaa näkökulmaa.[9]

Uuden termin omaksumista harkitsi aluksi myös vapaan ohjelmiston määritelmän kehittänyt GNU-hankkeen ja Free Software Foundationin johtaja Richard Stallman, joka päätyi kuitenkin torjumaan sen. Stallman on arvostellut avoimen lähdekoodin liikettä liiasta pragmaattisuudesta ja vapaiden ja ”puolivapaiden” ohjelmien rajan hämärtämisestä. Stallman rinnastaa ohjelmistojen vapauden sananvapauteen, joka on itseisarvo, ja sanoo, että jos avointa lähdekoodia perustellaan vain käytännön hyödyillä, avoimuudesta on helppo luopua silloin, kun se edellyttää ylimääräiseltä tuntuvaa vaivannäköä.

Vaikka termistössä ja ajattelutavoissa on siis vivahde-eroja, avoimen lähdekoodin ja vapaiden ohjelmistojen liikkeiden väliset ristiriidat eivät ole olleet yhteensovittamattomia. Käytännössä kaikki vapaat ohjelmistot ovat myös avoimen lähdekoodin ohjelmistoja ja avoimen lähdekoodin ohjelmistot vapaita. Englanniksi vapaista ja avoimen lähdekoodin ohjelmistoista käytetäänkin usein yhdistettyä akronyymiä FOSS (free and open source software) tai FLOSS (free/libre and open source software). Suomeksi voidaan vastaavasti joskus käyttää akronyymiä VALO.

Avoimen ja suljetun lähdekoodin ero

Avoimeen lähdekoodiin pääsee kuka tahansa tutustumaan, ja halutessaan käyttäjä voi korjata ohjelman virheitä ja lisätä uusia ominaisuuksia – tai pestata jonkun muun tekemään sen puolestaan, jos ei itse osaa tai ehdi. Tästä seuraa, että korjaukset tehdään yleensä nopeasti: parhaissa tapauksissa muutos on saatavilla muutamassa tunnissa, mikä on tärkeää esimerkiksi tietoturva­haavoittuvuuksia korjattaessa.

Omisteisen ohjelmiston käyttäjä ei yleensä pääse näkemään lähdekoodia. Mikäli ohjelmassa on puutteita, käyttäjä joutuu raportoimaan niistä ohjelman tekijälle tai vain sopeutumaan tilanteeseen yrittäen vähimmäistää haitat. Jos lähdekoodi on avoin, voi käyttäjä itse muokata koodia tai palkata kenet tahansa tekemään siihen haluamansa muutokset.

Avoimen lähdekoodin kehitystä tekevät sekä yritykset että vapaaehtoiset henkilöt. Yritykset osallistuvat avoimen lähdekoodin kehitystyöhön, koska tulisi kalliimmaksi kehittää vastaavanlainen kokonaan uusi tuote tai ostaa jonkin omisteisen tuotteen lisenssi.

Avointa lähdekoodia kehitetään jatkuvasti ja sitä ei pidetä sanan perinteisessä mielessä valmiina tuotteena vaan jatkuvana prosessina.

Suosio

Avoimen lähdekoodin suosion syy ei ole ohjelmiston ilmaisuus. Avoimen lähdekoodin todellinen voima on yhteistyössä. Avoimen lähdekoodin projektin parissa työskentelee lukuisia ihmisiä, jotka kykenevät tekemään siitä entistä paremman, kun taas suljettua lähdekoodia kehittää vain yksi henkilö tai yksi yritys. Avoimeen lähdekoodiin perustuvaa yhteistyötä on ollut jo vuosikymmenten ajan. Tekniikan alan suuryritykset Google ja Facebook ovat tehneet suuria kontribuutioita avoimen lähdekoodin maailmaan avaamalla osan ydintuotteistaan.[10]

Avoimen lähdekoodin eduiksi mainitaan kynnyksen madaltaminen ohjelman kokeiluun: muun muassa Xen levisi laajalti ilman omaa markkinointia.[11] Ohjelman käyttö on ydinasia ja ilman käyttäjiä ohjelma ei materialisoidu.[11] Perinteiseen malliin verrattuna, joka riippui markkinointilupauksista ja yksittäisistä esittelyversioista, avoimen lähdekoodin ohjelmissa käyttäjä tietää täsmälleen mitä saa eikä luota pelkkiin lupauksiin: lähdekoodin voi nähdä yksi tai 100 henkilöä ja kehittäjät eivät voi tehdä lepsusti.[11]

Kehittäjäyhteisö

Avoimen lähdekoodin ohjelmien kehitys perustuu julkiseen kehitysympäristöön. Ympäristöön kuuluu tyypillisesti versionhallinnalla varustettu lähdekoodin talletuspaikka (palvelin). Kehitysympäristöön kuuluu myös keskustelualueita ja virheenilmoitusjärjestelmä (johon voi kirjata myös toiveita).

Kehitysyhteisöön voi kuulua kotoistusryhmiä, jotka kääntävät ohjelman eri kielille. Kotoistukseen kuuluu ohjelman kansainvälistäminen (internationalisointi) ja sitten kotoistus (lokalisointi). Kotoistukseen liittyvät tietokoneohjelman käyttämän kielen lisäksi idiomit, tekstin vierityssuunta, päivämäärän esitysmuoto, valuutta, desimaalierotin ja värit. Kotoistus kattaa myös käyttöoppaat ja lisenssit.

Kehittäjäyhteisöön voi kuulua laaturyhmä, joka huolehtii ohjelman laadusta. Ulkonäöllisiin seikkoihin kiinnittää huomion siihen keskittyvä ryhmä.

Avoimen lähdekoodin kehitysyhteisöihin voi liittyä kuka tahansa. Jäsenet voivat kertoa mielipiteensä uusista ominaisuuksista, testata ohjelmistojen toimivuutta, tarkistaa lähdekoodia, korjata virheitä ja kirjoittaa uutta lähdekoodia. Kilpailu kehittäjien välillä on kovaa. Etuna on se, että koodia kehitetään kunnianhimoisesti. Kovan kilpailun haittavaikutuksia ovat yhteisön sisäiset erimielisyydet teknisistä yksityiskohdista, termeistä, toteutuksesta, projektien organisoinnista ja tavoitteista. Kiistoista tunnetuin koskee termejä avoin lähdekoodi vai vapaa ohjelmisto.

Avoimen lähdekoodin kehittäjäyhteisöjen sanotaan olevan puoliksi organisoituneita joukkoja avustajia, jotka tyypillisesti toimivat ohjelmistoon liittyvissä projekteissa.[12] Yhteisössä olevilla henkilöillä on jaettuja intressejä tehdä jotain, joka voidaan jakaa yhteisön sisällä tai sen ulkopuolella.[12] Avoimen lähdekoodin projekti ovat lähes aina hajautettujen yhteisöjen tuotosta.[12]

Avoimen lähdekoodin projekteissa on jonkinlainen rakenne ja projektin hallinta voi olla dokumentoitu projektin verkkosivuilla tai projektin dokumentaatiossa.[13] Projekteissa voi olla henkilöitä tietyissä rooleissa, jotka ovat usein samankaltaisia eri projekteissa.[13] Rooleja voivat olla johtajat (jotka tekevät lopullisen päätöksen ominaisuuksista, julkaisuista ja niin edelleen), ylläpitäjät, avustajat ja käyttäjät.[13] Osallistuminen voi vaatia tiettyjen ohjenuorien noudattamista ja osallistujan on oltava saatavilla palautteeseen vastaamiseen.[13]

Monilisensointi

Jotkin ohjelmistot, kuten MySQL, ovat saatavilla vapaasti GNU GPL:n alaisena ja lisäksi maksullisena versiona niille, jotka haluavat sisällyttää koodin osaksi omaa suljetun lähdekoodin tuotettaan. Tällöin tulee korostetusti esille, että vapaa ohjelmisto ei ole ilmainen siinä mielessä, että sen saisi omia itselleen, vaan muokattu koodi tulee antaa muiden käyttöön. Näin varmistetaan se, että kehittäjät saavat nauttia muiden työstä ja ohjelmiston kehittäminen jatkuu.

Kaupallisessa käytössä GNU GPL ei vaadi lähdekoodien julkaisua, mikäli muokattua lähdekoodia ei käytetä julkaistussa tuotteessa.[14]

Kehitysmallit

Avoimen lähdekoodin ohjelmistojen kehitysmallien ominaispiirre on joukko toisistaan riippuvia ohjelmakoodin laatua parantavia prosesseja eikä täysin lineaarista etenemistä julkaisuun.[15] Perinteisessä kehitysmallissa on joukko itsenäisiä jaksoja aktiviteetteja, joiden sarja johtaa julkaisuun.[15] Avoimen lähdekoodin kehitysmallissa on ryhmien välistä yhteistyötä, jatkuvan integraation ja jatkuvan testaamisen hyödyntämistä, sekä suurempi loppukäyttäjien mukanaolo.[15] Perinteisen "suuren paljastuksen" mallin sijaan avoimen lähdekoodin malli kannustaa jatkuvaan ja itsenäiseen ominaisuuksien kehittämiseen.[15] Uudet ominaisuudet voidaan integroida nopeammin ja niiden varaan voidaan kehittää aikaisemmin.[15] Varhainen ja usein tapahtuva julkaisu ("Release early, release often") johtaa varhaisempaan koodin katselmointiin hyvissä ajoin ennen julkaisua ja malli kannustaa jatkuvaan katselmointiin, jossa kaikki yhteisön jäsenet voivat kommentoida.[15] Malli myös kannustaa pieniä, asteittaisia muutoksia jotka ovat helpompia ymmärtää ja testata kehittäjien ollessa aktiivisesti mukana.[15] Avoimen lähdekoodin malli korostaa katselmointia koko kehityskaaren läpi.[15]

Useissa avoimen lähdekoodin ohjelmistoprojekteissa käytettyä kehitysprosessia on kuvattu jatkuvan kehityksen mallina (engl. perpetual development).[16]

Kritiikkiä

Avoimen lähdekoodin kehitystä on myös kritisoitu: useat osallistujat tekevät vain muutamia pieniä bugikorjauksia ja suuri osa kehityksestä on edelleen pienen ydinryhmän vastuulla.[17] Ydinryhmän vastuulla on myös bugiraporttien käsittely ja kritiikkiin vastaaminen, joka lisää työmäärää.[17] Jotkin yritykset kuten Facebook ja Google maksavat työntekijöille avoimen lähdekoodin projekteissa työskentelystä täysipäiväisesti, jonka avulla projektit ovat virkeitä.[17] Joitakin huolestuttaa osallistumisesta maksamisen muuttavan miten ja miksi sitä ylipäätään tehdään.[17]

Ohjelmistojen ulkopuolella

Avointa lähdekoodia sanotaan myös sosiaaliseksi liikkeeksi.[18] Tietokoneohjelmistojen ulkopuolella avoimen lähdekoodin konseptia on käytetty luomaan vapaita verkossa olevia tietokantoja ja kaupalliset toimijat täyttävät arvosteluja myytävistä asioista.[18]

Wikipedian perustaja Jimmy Wales kutsuu sitä mieluummin "vapaan kulttuurin liikkeeksi" kuin avoimeksi lähdekoodiksi.[19] Avoimen lähdekoodin projekteissa on tyypillisesti organisaatio tai henkilö johdossa, joka on vastuussa siitä, kun taas Wikipediasta puuttuva keskeinen hallinta erottaa sen avoimen lähdekoodin mallista.[19]

Katso myös

Lähteet

  • Välimäki, Mikko: Avoimen lähdekoodin ohjelmistolisensseistä. Defensor Legis, 2002, 83. vsk, nro 5, s. 851–861. Helsinki: Suomen Asiainajajaliitto. ISSN 0356-262X.

Viitteet

  1. https://source.android.com/
  2. Kevin Daniel André Carillo & Chitu Okoli: The open source movement: A revolution in software development Journal of Computer Information Systems. joulukuu 2008. Viitattu 8.3.2022. (englanniksi)
  3. What is open source? redhat.com. 24.10.2019. Viitattu 8.3.2022. (englanniksi)
  4. Christine Peterson: How I coined the term 'open source' opensource.com. 1.2.2018. Viitattu 8.3.2022. (englanniksi)
  5. Press Release: April 14, 1998 oreilly.com. 14.4.1998. Viitattu 8.3.2022. (englanniksi)
  6. https://opensource.org/docs/osd
  7. JHS 169 Avoimen lähdekoodin ohjelmien käyttö julkisessa hallinnossa 22.2.2009. Julkisen hallinnon tietohallinnon neuvottelukunta (JUHTA). Arkistoitu 21.3.2015. Viitattu 21.3.2015.
  8. Scott K Peterson: What's the difference between open source software and free software? opensource.com. 7.11.2017. Viitattu 30.5.2021. (englanniksi)
  9. History of the OSI (HTML) Open Source Initiative. Viitattu 18.11.2011. (englanniksi)
  10. https://economictimes.indiatimes.com/small-biz/startups/newsbuzz/why-is-open-source-software-so-popular/articleshow/62689785.cms
  11. The Linux Effect of the Enterprise Software Model serverwatch.com. 1.9.2020. Viitattu 25.10.2020. (englanniksi) 
  12. Brian Proffitt: How open source communities work techradar.com. 25.6.2020. Viitattu 8.3.2022. (englanniksi)
  13. Participating in Open Source Communities linuxfoundation.org. Viitattu 8.3.2022. (englanniksi)
  14. Frequently Asked Questions about the GNU Licenses GNU. Viitattu 10.10.2017.
  15. Ibrahim Haddad & Brian Warner: Understanding the Open Source Development Model (PDF) ibrahimatlinux.com. marraskuu 2011. Arkistoitu 28.10.2020. Viitattu 25.10.2020. (englanniksi)
  16. Dror G. Feitelson: Perpetual Development: A Model of the Linux Kernel Life Cycle (PDF) cs.huji.ac.il. 25.10.2011. Viitattu 14.10.2020. (englanniksi) 
  17. Clive Thompson: The Few, the Tired, the Open Source Coders wired.com. 17.11.2020. Viitattu 30.11.2020. (englanniksi) 
  18. open source britannica.com. Viitattu 8.3.2022. (englanniksi)
  19. Daniel Terdiman: Wikipedia's open-source label conundrum cnet.com. 25.5.2006. Viitattu 8.3.2022. (englanniksi)

    Aiheesta muualla

    Kansainvälisiä:

    Suomalaisia:

    This article is issued from Wikipedia. The text is licensed under Creative Commons - Attribution - Sharealike. Additional terms may apply for the media files.