Paketinhallintajärjestelmä

Paketinhallintajärjestelmä (engl. packet management system, PMS) pitää kirjaa tietokoneeseen asennetuista pakettitiedostoista, jotka sisältävät tietokoneohjelmia ja muita tiedostoja. Järjestelmän avulla tietokoneen käyttäjä voi hakea pakettivarastoista tiedon uusimmista pakettiversioista ja voi päivittää ohjelmat halutessaan tai automaattisesti.

Paketinhallintajärjestelmään kuuluu tietokoneohjelma, joka tekee pakettien asennus-, poisto- ja päivitystoimia, sekä tietokanta koneella olevien pakettien tiedoista ja versioista. Paketinhallintajärjestelmä automatisoi tietokoneohjelmien asennus-, päivitys- ja poistoprosessin tietokoneen käyttöjärjestelmässä. Järjestelmä osaa pakettien asennuksen ja poiston lisäksi myös muita ylläpitotehtäviä ja järjestelmä voi tehdä myös tiettyjä konfiguraatiotoimintoja automaattisesti asennuksen yhteydessä.

Ohjelmat voivat koostua yksittäisestä paketista tai useista toisistaan riippuvista paketeista.[1] Lisäksi yksittäinen paketti voi sisältää useita toisiinsa liittyviä ohjelmia yhdessä paketissa.[1] Paketeissa voi olla ohjelmatiedostojen lisäksi myös muuta tietoa kuten datatiedostoja, dokumentaatiota ja niin edelleen.[1] Asennuksen yhteydessä paketinhallintajärjestelmän tehtävä on helpottaa käsittelemään toisistaan riippuvien pakettien kokoelmia.[1]

Paketinhallintaohjelma osaa verrata paketinhallinnalla asennettujen pakettien versioita pakettivarastojen versioihin. Jos pakettivarastossa on uudempi versio jostakin asennetusta paketista, se ehdottaa käyttäjälle paketin päivitystä. Käyttäjä on voinut määritellä myös, että päivitys tehdään aina automaattisesti. Paketinhallintaohjelma osaa katsoa pakettien riippuvuussuhteista, vaatiiko paketin uusi versio myös jonkun toisen paketin päivittämistä uudempaan tai kokonaan uuden paketin asennusta. Jos toinenkin paketti vaatii päivittämistä myös se otetaan mukaan päivitykseen.

Käyttöjärjestelmien lisäksi eräät ohjelmistopaketit sisältävät oman paketinhallintansa. Esimerkiksi Ruby käyttää RubyGem-paketteja, Rust sisältää Cargo-paketinhallintaohjelman[2] ja Node.js sisältää npm-ohjelman[3] pakettien asennukseen.

Varhain Unixille tarkoitetut ohjelmat käännettiin itse lähdekoodeista, jota helpottamaan tulivat automaattiset käännöstyökalut (make, autoconf).

Sun Solaris sisälsi paketinhallintaohjelman pkg[4] ainakin 2.x-versioista 1990-luvun alkupuolelta.[5]

Ensimmäisen paketinhallintajärjestelmän Linuxille sanotaan olleen PMS, jonka versio 1.0 julkaistiin vuonna 1994 ja sitä käytettiin Bogus Linuxissa.[6] Paketinhallinnalla pystyi jo varhain päättelemään mitä osia käyttöjärjestelmästä asentaa ja siten säästää tilaa.[7] Package Management System (PMS) oli Rik Faithin kirjoittama ja piti kirjaa asennetuista paketeista, sekä mahdollisti asennettujen pakettien poistamisen.[7]

Ennen paketinhallintajärjestelmiä ohjelmia levitettiin tar-paketteina.[8] Ongelmana oli, ettei jälkikäteen voinut hallita ohjelmistoa: käyttäjä ei voinut tietää ohjelman versiota ja päivittäminen oli vaikeaa koska tiedostot olivat levitettyinä ympäri järjestelmää.[8] Lisäksi jos ohjelma riippui mistä tahansa toisesta ohjelmasta käyttäjän oli itse se käsin asennettava.[8]

Paketinhallintajärjestelmät ratkovat hallintaongelmaa lisäämällä metatietoa itse ohjelman mukaan.[8] Metatieto sisältää yksityiskohtaisen kuvauksen paketissa olevista tiedostoista, versionumeron, paketin kuvauksen, tiedon paketin tekijästä ja kehittäjän haluamaa lisätietoa.[8] Metatieto sisältää myös tiedon myös riippuvuuksista, jotka tarvitaan jotta ohjelma voi toimia, sekä komentokielitiedostoja, jotka tekevät toimintoja kuten luovat hakemistoja, käyttäjätunnuksia tai käynnistävät palveluita.[8]

Paketin asennukseen käytettävä ohjelma purkaa tiedostot paketista oikeisiin paikkoihin ja seuraa asennettuja paketteja.[9] Ohjelma pystyy asentamaan, poistamaan, varmistamaan ja päivittämään paketteja sekä sillä voi kysyä tietoja asennetuista paketeista.[9]

Paketinhallintajärjestelmä organisoi ja yksinkertaistaa ohjelmien asennusta ja hallintaa standardoimalla ja organisoimalla ohjelmistokokoelmien tuotannon ja käytön.[10] Paketinhallintajärjestelmien tuoma rakenne istuu ohjelmien kehitykseen ja uudelleenkäytettävyyteen sekä integroituu IT-hallintaan.[10]

Ian Murdockin mukaan paketinhallinta on suurin yksittäinen edistysaskel, jonka Linux on tuonut ohjelmistoteollisuuteen.[11] Aiemmat käyttöjärjestelmät olivat suuria monoliittisia tuotteita ja sovellukset olivat suuria monoliittisia tuotteita niiden päällä.[11] Murdockin mukaan käyttöjärjestelmien ja sovelluksien raja on hämärtynyt kun sovellukset asennetaan käyttöjärjestelmään integroiduilla työkaluilla ja itse sovellus integroituu käyttöjärjestelmän kanssa saumattomasti.[11]

Tyypillisiä paketinhallinnan toimintoja ovat:

  • Päivitystiedostojen varmistus alkuperäisyyden varmistamiseksi (kryptografisella tiivisteellä).
  • Digitaalisten allekirjoitusten autentikointi pakkauksien alkuperäisyyden varmistukseksi.
  • Pakkausohjelmien lisäys pakattujen tiedostojen hallintaan.
  • Ohjelmien päivitys viimeisimpiin versioihin, tyypillisesti pakettivarastoista.
  • Pakkauksien ryhmittely tietokoneen käyttäjän epätietoisuuden eliminoimiseksi.
  • Riippuvuuksien hallinta, jotta päivitys päivittää kaikki muutkin ohjelmat, joiden päivitystä tämä päivitettävä ohjelma tarvitsee.

Paketinhallintaohjelma voi myös havaita, jos jotkin ohjelmat tai komponentit ovat tulleet tarpeettomiksi kun mikään muu paketti ei viittaa niihin.

Linuxin paketinhallinta

[muokkaa | muokkaa wikitekstiä]
Synaptic, yksi eniten ja laajimmalla käytetty graafinen käyttöliittymä paketinhallinnalle Linux-käyttöjärjestelmissä.

Linuxin eri distribuutioille on olemassa useita paketinhallintaohjelmia.

BSD-jakeluissa käytetty pkgsrc on myös saatavilla Linuxille.

Homebrew on saatavilla sekä macOS:lle että Linuxille.

Flatpak, Snap ja AppImage ovat uudempia menetelmiä, joissa ohjelman tarvitsema ajonaikainen ympäristö on erillään varsinaisesta alustasta (isäntäjärjestelmästä).[12][13]

Microsoft Windowsin paketinhallinta

[muokkaa | muokkaa wikitekstiä]

Windowsissa on päivityksien asentamiseen käytetty Windows Update ja ohjelmien asentamiseen käytetty Windows Installer.

  1. a b c d What is a package manager? debian.org. Viitattu 20.3.2022. (englanniksi)
  2. https://doc.rust-lang.org/cargo/
  3. https://www.w3schools.com/nodejs/nodejs_npm.asp
  4. https://docs.oracle.com/cd/E23824_01/html/E21796/pkg-1.html
  5. https://www.ibiblio.org/pub/packages/solaris/sparc/
  6. The history of *nix package management eerielinux.wordpress.com. Viitattu 15.2.2022. (englanniksi)
  7. a b Caleb Epstein: A review of InfoMagic's December 1994 Release linuxjournal.com. 1.4.1995. Viitattu 15.2.2022. (englanniksi)
  8. a b c d e f A Comparative Study of various Linux Package-Management Systems (PDF) ripublication.com. Viitattu 15.2.2022. (englanniksi)
  9. a b Package Management Security (PDF) ssl.engineering.nyu.edu. Viitattu 15.2.2022. (englanniksi)
  10. a b Package Management Systems computer.org. doi:10.1109/MS.2012.38 Viitattu 15.2.2022. (englanniksi)
  11. a b c How package management changed everything ianmurdock.com. 21.7.2007. Arkistoitu Viitattu 15.2.2022. (englanniksi)
  12. flatpak(1) man.archlinux.org. Viitattu 14.2.2022. (englanniksi)
  13. Jonathan Corbet: The universal application distribution mechanism? lwn.net. 15.6.2016. Viitattu 14.2.2022. (englanniksi)