Portál AbcLinuxu, 2. června 2024 05:41

Balíčkovací systém Arch Linuxu - 1 (formát balíčků)

4. 4. 2007 | Vojtěch Gondžala
Články - Balíčkovací systém Arch Linuxu - 1 (formát balíčků)  

V první díle se podíváme, jak vypadá archovský balíček, jak pacman zjišťuje závislosti, co je to instalační skript, a kde je lokální databáze balíčků.

Úvod

Balíčkovací systém Arch Linuxu používá jako správce balíčků pacmana. Balíčky si stahuje přímo z repositářů umístěných na zrcadlech, podobně jako apt-get. Používání systému se snaží být co nejjednodušší a snadno ovladatelné; to se daří plnit díky řešení závislostí a konfliktů balíčků. Stejně tak i ovládání pacmana je jednoduché.

Arch Linux má několik oficiálních repositářů, ve kterých je většina softwaru potřebného pro plnohodnotný desktop i server. Software je kompilován pro architektury i686 (hlavní architektura, která má nejvíce balíčků), x86-64 a i586 (pro tu je zatím nejméně balíčků).

Oficiální repositáře:

Mimo tyto repositáře, které obsahují přímo binární balíčky, ještě existuje AUR (Arch Linux User-community Repository), jež obsahuje PKGBUILDy pro velké množství softwaru, který není v oficiálních repositářích. O AURu a PKGBUILDech si budeme povídat v některém z dalších dílů.

Formát balíčků

Název archovského balíčku má pevně daný tvar: jméno_softwaru-verze-vydání_balíčku-architektura.pkg.tar.gz. Už samotný název dává tušit, že se jedná o tar.gz archiv. Aby byl takový archiv validním balíčkem, musí mimo jiné obsahovat soubory:

Nepovinný je instalační skript .INSTALL.

.FILELIST

Obsahuje seznam všech souborů v balíčku, což je užitečné například pro zjišťování konfliktu souborů, nebo pokud chceme zjistit, kterému balíčku nějaký soubor patří.

.PKGINFO

Obsahuje všechny informace potřebné k instalaci balíčku. Budeme se věnovat položkám, které jsou obvyklé u pacmana 3.0.0, potažmo u skriptu makepkg, který tento soubor generuje (starší verze nemusely mít všechny položky).

Soubor má jednoduchou strukturu, která je nejlépe vidět na příkladě. Náš balíček bude obsahovat software se jménem helloworld ve verzi 0.4, bude kompilován pro architekturu i686, takže název balíčku je helloworld-0.4-1-i686.pkg.tar.gz

# Generated by makepkg 3.0.0
# Sun Dec 31 10:05:08 CET 2006
pkgname = helloworld
pkgver = 0.4-1
pkgdesc = helloworld: a kernel module and \
          a userspace daemon for controlling an atomic bomb
url = http://www.helloworld.sf.net
builddate = Sun Dec 31 09:05:08 2006
packager = Big Boss  <bigboss@sf.net>
size = 1055364
arch = i686
license = GPL
replaces = helloworld-rc
replaces = helloworld-test
depend = kernel26
conflict = goodbyeworld
conflict = libatomicbomb
provides = libatomicbomb
backup = etc/helloworld.conf

.INSTALL

Tento soubor je instalačním skriptem a není, na rozdíl od ostatních souborů, povinný. Slouží pro spouštění případných po–instalačních procedur. Stejně tak má části, které se spouští po upgradu nebo odinstalování balíčku. Často se také využívá pro výpis informací při instalaci.

Ukážeme si opět jeden krátký příklad:

# arg 1:  the new package version
post_install() {
  echo ">>> ovládání atomových bomb 'heloworld' verze $1"
  post_upgrade $1 0.1
}

# arg 1:  the new package version
# arg 2:  the old package version
post_upgrade() {
  echo ">>> Novinky ve verzi $1"
  if [ "$(vercmp $2 0.2)" -lt 0 ]; then
    echo "    -> kód byl kompletně přepsán, zvýšila se stabilita ;]"
  fi
  if [ "$(vercmp $2 0.3)" -lt 0 ]; then
    echo "    -> podporovány jsou i indické bomby"
  fi
  _do_some_think
}

pre_remove() {
. /etc/rc.d/functions
if ! ck_daemon heloworld; then
  /etc/rc.d/heloworld stop
fi
}

_do_some_think() {
  /bin/true
}

op=$1
shift
$op $*

Do skriptu si můžeme přidávat svoje vlastní funkce. Je vhodné použít prefix "_", všechny funkce by měly končit s návratovým kódem 0. Instalační skript je velmi zranitelnou částí instalačního procesu; může obsahovat potenciálně škodlivý kód, proto instalujte balíčky jen z důvěryhodných zdrojů. A stejně tak si, pokud sestavujete balíček sami, prohlédněte obsah instalačního skriptu.

Proces instalace a odstranění

Při instalaci pacman nejprve zkontroluje závislosti a konflikty, jak na úrovni balíčků, tak i na úrovni souborů, poté rozkopíruje soubory, provede případné zálohy konfigurace a nakonec spustí instalační skript. Informace o balíčku se uloží do databáze. Proces odstranění je opačný.

Databáze balíčků se nachází ve /var/lib/pacman/ a je to adresářová struktura repositář/balíček. Adresář balíček obsahuje soubory s popisem balíčku a seznamem závislostí.

Seznam aktuálně nainstalovaných balíčků se nachází v adresáři /var/lib/pacman/local. Jeho struktura vypadá podobně jako u repositářů, ale každý balíček má navíc v adresáři seznam souborů v balíčku a instalační skript (pokud jej balíček obsahuje).

Protože databáze je řešena tímto způsobem, je vhodné ji mít na zvláštním oddílu disku s výkonným souborovým systémem, výrazně to zrychlí práci.

Příště

Tímto bychom měli položeny nutné základy, příště se pustíme do správy balíčků pomocí pacmana.

Seriál Balíčkovací systém Arch Linuxu (dílů: 4)

První díl: Balíčkovací systém Arch Linuxu - 1 (formát balíčků), poslední díl: Balíčkovací systém Arch Linuxu - 4 (ABS, makeworld).
Následující díl: Balíčkovací systém Arch Linuxu - 2 (pacman, repozitáře)

Související články

Na co se často ptáme: Balíčkovací systémy
Seriál: Gentoo ebuild
Seriál: Rukověť baliče RPM
Balíčkovací systém Gentoo Linuxu - I
Balíčkovací systém Gentoo Linuxu - II
Balíčkovací systém Mandrake Linuxu
Seriál: Nebojíme se kompilace
„Archovský balíčkovač“ Pacman po třetí
Barevný pacman 3 (správce balíčků pro Arch)
Arch Linux

Další články z této rubriky

Úvod do Dockeru (1)
Paralelizace běžných činností v konzoli pomocí GNU Parallel
Unixové nástroje – 26 (triky pro práci v Bashi)
Unixové nástroje – 25 ((s,c)fdisk, gdisk, parted a findmnt)
Linux: systémové volání splice()

Diskuse k tomuto článku

4.4.2007 21:00 gawan
Rozbalit Rozbalit vše komentáre
Odpovědět | Sbalit | Link | Blokovat | Admin
kde sa stratili komentáre? už tu nejaké boli .... a teraz tu nie je nič ... hmm ...
4.4.2007 21:33 Robert Krátký | skóre: 94 | blog: Robertův bloček
Rozbalit Rozbalit vše admin
Havárie databáze - omlouváme se.
5.4.2007 00:08 dvh
Rozbalit Rozbalit vše Re: komentáre
Jo, a ja som vravel ze balickovaci system pacman je napisany v pythone a niekto robil chytreho. Lenze on je v pythone. Su totiz dva balickovacie systemy, oba sa volaju pacman, jeden je v pythone, jeden je v C. A asi nemaju nic spolocne proste len rovnaky nazov.
vogo avatar 5.4.2007 00:31 vogo | skóre: 34 | blog: "Skládat papír"
Rozbalit Rozbalit vše Re: komentáre
pacman který je v archu je napsán v C, jeho tvůrcem je Judd Vinet a banda vývojářů :)
Nejsem paranoidní, ale to ještě neznamená, že po mě nejdou.
Václav 5.4.2007 05:11 Václav "Darm" Novák | skóre: 26 | blog: Darmovy_kecy | Bechyně / Praha
Rozbalit Rozbalit vše Re: komentáre
Však jsem psal že každý myslíme jiného pacmana :)
Cross my heart and hope to fly, stick a cupcake in my eye!
kouzer avatar 4.4.2007 22:00 kouzer | skóre: 11 | Mladá Boleslav
Rozbalit Rozbalit vše Re: Balíčkovací systém Arch Linuxu - 1 (formát balíčků)
Odpovědět | Sbalit | Link | Blokovat | Admin
Tak opět píši pochvaliný komentář a těším se na nové díly.
Linux user #448944.
freshmouse avatar 4.4.2007 22:23 freshmouse | skóre: 42 | blog: Bruno Banány
Rozbalit Rozbalit vše Re: Balíčkovací systém Arch Linuxu - 1 (formát balíčků)
Odpovědět | Sbalit | Link | Blokovat | Admin
Článek se mi líbí.

Jeden z komantářů si pamatuju. Bylo to Ignorovo: "Třeba mi konečně někdo vysvětlí, v čem je ten balíčkovací systém Archu tak zajímavý?" :-)
vogo avatar 4.4.2007 22:29 vogo | skóre: 34 | blog: "Skládat papír"
Rozbalit Rozbalit vše Re: Balíčkovací systém Arch Linuxu - 1 (formát balíčků)
a odpověď byla, že v dalším díle, celou diskuzi mám na emailu ;)
Nejsem paranoidní, ale to ještě neznamená, že po mě nejdou.
4.4.2007 23:56 Leoš Literák | skóre: 74 | blog: LL | Praha
Rozbalit Rozbalit vše Re: Balíčkovací systém Arch Linuxu - 1 (formát balíčků)
Mohl bys ji tedy vlozit jako novy komentar? Kdyz se aspon neco zachranilo ..
Zakladatel tohoto portálu. Twitter, LinkedIn, blog, StackOverflow
vogo avatar 5.4.2007 00:27 vogo | skóre: 34 | blog: "Skládat papír"
Rozbalit Rozbalit vše Re: Balíčkovací systém Arch Linuxu - 1 (formát balíčků)
Odpovědět | Sbalit | Link | Blokovat | Admin
po havárii alespoň nějaká náhrada za diskuzi :), jen mi chybí vlákno o tom v čem je napsán pacman, a o tom, že databáze je brutálně pomalá a měla by být implementována jinak… svoje příspěvky jsem rekonstruoval, ty samozřejmě na emailu nemám
Nejsem paranoidní, ale to ještě neznamená, že po mě nejdou.
freshmouse avatar 5.4.2007 00:34 freshmouse | skóre: 42 | blog: Bruno Banány
Rozbalit Rozbalit vše Re: Balíčkovací systém Arch Linuxu - 1 (formát balíčků)
Teď mě napadlo, že bys mohl sloužit jako zálohovací server...
vogo avatar 5.4.2007 00:37 vogo | skóre: 34 | blog: "Skládat papír"
Rozbalit Rozbalit vše Re: Balíčkovací systém Arch Linuxu - 1 (formát balíčků)
lol :) to asi ne, ale no prostě rofl, vím že to je komentář jak noha, ale nemůžu si pomoct
Nejsem paranoidní, ale to ještě neznamená, že po mě nejdou.
freshmouse avatar 5.4.2007 00:44 freshmouse | skóre: 42 | blog: Bruno Banány
Rozbalit Rozbalit vše Re: Balíčkovací systém Arch Linuxu - 1 (formát balíčků)
No fakt. Všichni obnovují z nějakých "obyčejných" záloh, kdežto ty to kontrol C a kontrol V odněkud z e-mailů a ještě to řadíš do tak prima stromu. Dej si to do životopisu (CV = kontrol C a kontrol V :-)).
5.4.2007 21:50 Robert Krátký | skóre: 94 | blog: Robertův bloček
Rozbalit Rozbalit vše Re: Balíčkovací systém Arch Linuxu - 1 (formát balíčků)
po havárii alespoň nějaká náhrada za diskuzi :)
Teď bychom ještě asi měli ručně hrábnout do databáze a přidat nějaký ten tisíc do počítadla čtenosti, aby to nevypadalo, že článek nikoho nezajímá...:-)

Všichni už si ho totiž přečetli, ale teď to není poznat.
5.4.2007 01:06 Petr Ježek
Rozbalit Rozbalit vše Re: Balíčkovací systém Arch Linuxu - 1 (formát balíčků)
Odpovědět | Sbalit | Link | Blokovat | Admin
Veká pochvala autorovi. Kdybych neměl svou práci a k ní Arch nepoužíval jen jako nástroj, asi bych se do toho vysvětlování výhod balíčků a pacmana v Archu pustil taky. Díky tomu je Arch nezasviněný nechtěným balastem, repozitáře jsou logické, struktura balíčků je jednoduchá, funkční a ideální pro jejich vlastní vytváření pomocí ABS. Doporučuji autorovi zpracovat své poznámky k ABS, protože ABS je způsob, jak překonat relativně nižší počet aplikačních balíčků oproti DEB a RPM distribucím. Připomínám, že se mi pouze jednou stalo, že jsem zauvažoval o použití ABS v případě XFE, ale byl jsem druhý - balíček se záhy objevil v community...
5.4.2007 02:34 Andrej | skóre: 51 | blog: Republic of Mordor
Rozbalit Rozbalit vše Re: Balíčkovací systém Arch Linuxu - 1 (formát balíčků)
Odpovědět | Sbalit | Link | Blokovat | Admin

Žuch, prásk. Ach jo. Takže má ostrá kritika pacmana vzala za své. Nějaká linuxová vyšší moc se mi tu snaží naznačit, abych ho nechal na pokoji.

5.4.2007 02:41 Andrej | skóre: 51 | blog: Republic of Mordor
Rozbalit Rozbalit vše Re: Balíčkovací systém Arch Linuxu - 1 (formát balíčků)

Hloupé je, že jsem tu diskusi sledoval a měl jsem prakticky všechny příspěvky v mailu. Jenže cca hodinu před tím karambolem jsem je smazal. To je prostě setsakra smůla.

Ale diskusi v té době sledoval ještě jeden člověk. Třeba zprávy nesmazal. Třeba je má buď ve schránce nebo aspoň na serveru... Haló! Kdo to byl?

Martin Stiborský avatar 5.4.2007 11:27 Martin Stiborský | skóre: 26 | blog: Stibiho bláboly | Opava
Rozbalit Rozbalit vše Re: Balíčkovací systém Arch Linuxu - 1 (formát balíčků)
To jsem byl nejspíš já, ale bohužel mail už prošel košem :(
Kvík ..
5.4.2007 13:14 Andrej | skóre: 51 | blog: Republic of Mordor
Rozbalit Rozbalit vše Re: Balíčkovací systém Arch Linuxu - 1 (formát balíčků)

Fňuk.

ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.