abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Navštivte Abc obchůdek se samolepkami a přívěsky!
Rozšířené hledání
×
dnes 06:11 | Komerce
Rozrůstající se softwarová společnost v Plzni zabývající se telematikou hledá schopné vývojáře a nadšence se zájmem o OS Linux. Uplatnění zde najdou především vývojáři C++ se znalostí OS Linuxu, dále programátoři v jazyku Java nebo vývojáři se zkušenostmi s Oracle DB a Oracle ADF. Více informací o společnosti. … více »
Reklama | Komentářů: 0
24.5. 22:45 | IT novinky
NASA, která společně s Rackspace stála u zrodu projektu OpenStack, se již nadále nebude podílet na dalším vývoji této "infrastructure-as-a-service" platformy. V NASA totiž došli k závěru, že vzhledem k podpoře OpenStacku ze strany společností jako Red Hat, AT&T a HP lze jejich práci považovat za dokončenou. Posléze se NASA plánuje stáhnout i z vývoje další platformy pro cloud computing jménem Nebula.
Migilenik | Komentářů: 0
24.5. 22:45 | Upozornění
Blíží se svátek IPv6 a s ním i konference IPv6 Day. Na návštěvníky této akce čeká nejen bohatý program, ale také jedna speciální nabídka – v průběhu setkání bude možné získat se slevou 66 procent třetí vydání knihy IPv6 vysokoškolského pedagoga a publicisty Pavla Satrapy, tedy za 105 korun. … více »
Vilem Sladek | Komentářů: 4
24.5. 16:14 | Pozvánky

Přijďte si zasprintovat na Djangu, jiném Python open-source projektu, nebo jen potkat ostatní vývojáře!

… více »
Whit | Komentářů: 0
24.5. 10:20 | Nová verze
Na zrcadlech a torrentech jsou již k dispozici ISO obrazy distribuce Mageia 2. Poznámky k vydání čtěte zde.
Liborek | Komentářů: 14
23.5. 13:47 | Pozvánky

Letos v říjnu se v Praze uskuteční hned několik konferencí. Odehraje se zde nově vzniklá konference LinuxDays. K ní se přidá čtvrtý ročník openSUSE Conference, dvanáctý ročník SUSE Labs conference a aby to nebylo málo, přidá se i první ročník Gentoo miniconf. A to vše ve stejné dny a na stejném místě.

… více »
Miška | Komentářů: 7
23.5. 13:27 | Zajímavý projekt
Printerd je název nového projektu tiskového démona, který bude využívat PolicyKit a D-Bus. Projekt je zatím na úplném začátku, takže nejde o nic vhodného k produkčnímu nasazení. Mimo jiné aktuálně akceptuje jako vstup jen PDF dokumenty.
Luboš Doležel (Doli) | Komentářů: 56
23.5. 13:25 | Zajímavý software
Tři vývojáři ze společnosti Engine Yard přecházejí po dohodě mezi firmami do Red Hatu. Jde o vývojáře zabývající se rozvojem projektu JRuby. To ukazuje, že Red Hat má zájem o podporu alternativních jazyků nad OpenJDK.
Luboš Doležel (Doli) | Komentářů: 1
23.5. 13:20 | Zajímavý software
Fedora přejde na knihovnu libusbx, což je fork původní knihovny libusb. Důvodem pro fork byl zjevný nedostatek času nebo zájmu ze strany správce projektu. libusbx už teď nabízí užitečné funkce navrch.
Luboš Doležel (Doli) | Komentářů: 4
23.5. 10:29 | Nová verze
Vyšlo LLVM 3.1. Vylepšení se dotýkají podpory C++ 11 nebo architektur ARM a MIPS. Dále se můžete těšit z Python bindings nebo nástroje AddressSanitizer pro detekci chyb při práci s pamětí.
Luboš Doležel (Doli) | Komentářů: 0
Pokud by se prohlížeč Opera stal svobodným:
 (9%)
 (32%)
 (1%)
 (58%)
Celkem 249 hlasů
 Komentářů: 31, poslední včera 22:38
    Rozcestník
    Reklama
    Autoškola testy online Levný benzín

    Rukověť baliče RPM - II (Prostředí)

    25. 5. 2005 | David Nečas | Návody | 10787×

    Jaké jsou využívány adresáře a soubory, jak se v nich vyznat, a jak si připravit pracovní prostředí tak, aby bylo samotné balíčkování co nejpřehlednější.

    Prostředí

    Během balení rpm se různé věci zapisují do různých adresářů nebo se v nich hledají. RPM umožňuje flexibilní nastavení adresářové struktury, pro začátek se však vyplatí seznámit se s tou standardní. Nainstalujeme-li rpm-build, vytvoří se v /usr/src/RPM (na RedHatu /usr/src/redhat, jinde případně i jinde) následující podadresáře:

    • SPECS – sem se instalují spec soubory.
    • SOURCES – sem se instalují zdrojové kódy a patche.
    • BUILD – do tohoto adresáře se zdrojové kódy rozbalují (každý do svého podadresáře) a probíhá v něm vlastní překlad.
    • RPMS – adresář, do nejž se po úspěšné kompilaci nahrají vytvořené binární balíčky. Přesněji do podadresářů odpovídajících jejich achitektuře (i386, …, noarch).
    • SRPMS – sem se případně nahraje vytvořený zdrojový balíček.

    Do /usr/src/RPM však může zapisovat jen root, a jelikož k balení rpm není zapotřebí být rootem, nebudeme balit jako rooti a namísto toho si stejnou adresářovou strukturu vytvoříme někde v domovském adresáři, řekněme v ~/src/rpm. RPM vysvětlíme, že ji má používat, přidáním řádku

    %_topdir /home/yeti/src/rpm

    do souboru ~/.rpmmacros. Kdo nemá uživatelské jméno yeti, nahradí /home/yeti svým domovským adresářem. Do /var/tmp, kam se při balení zapisují a dočasně instalují soubory, sice zapisovat smíme, budeme však chránit životní prostředí a změníme i adresář pro dočasné soubory:

    %_tmppath /home/yeti/tmp

    V souboru ~/.rpmmacros můžeme změnit řadu dalších zajímavých věcí, prozatím se spokojíme s nastavením tvůrce balíku:

    %packager Yeti <yeti@physics.muni.cz>

    Kdo se nejmenuje Yeti, opět změní na svoje jméno, a především adresu.

    Hodnota %_topdir také ovlivňuje, kam se nainstaluje obsah zdrojového rpm. Nyní tedy můžeme spustit (nebude-li uvedeno jinak, bude se náš balíček vždy nazývat lobster).

    rpm -i lobster-1.10-1.src.rpm

    jako obyčejní uživatelé a soubory se objeví
    ~/src/rpm/SOURCES
    ~/src/rpm/SPECS namísto
    /usr/src/SOURCES
    /usr/src/SPECS.

    Myslíme-li to s balením vážně, budeme chtít oddělit systém, na němž pracujeme, od cílového systému, pro nějž kompilujeme – byť by se lišil jen nainstalovaným softwarem. V tom případě cílový systém nainstalujeme do alternativního rootu a budeme při balení a testování používat chroot. rpm a rpmbuild sice mají argument --root, ten ale podle mne funguje jaksi zvláštně. Chrootnout se do alternativního rootu přímo příkazem chroot pracuje spolehlivě – jako obyčejní uživatelé na to ovšem nemáme práva. Distribuce a významní nezávislí baliči (např. Dag) vyvinuli různé nástroje a systémy kompilace oproti čistým instalacím a ověřování balíčků, které má smysl prostudovat, budete-li se pouštět do nějakých větších akcí.

    Kompilace

    Než se pustíme do výroby vlastních balíčků, hodí se umět zkompilovat ty, u nichž už nám někdo všechno přichystal. Argumenty rpmbuildu se mírně liší podle toho, z čeho kompilujeme.

    Zdrojový balíček. Máme-li lobster-1.10-1.src.rpm, binární rpm z něj vytvoříme

    rpmbuild --rebuild lobster-1.10-1.src.rpm

    Spec soubor a zdrojový kód. Ze zdrojových kódů v SOURCES a spec souboru kdekoli (obvykle ho ale budeme mít ve SPECS) zkompilujeme binární balíček

    rpmbuild -bb lobster.spec

    Ke spec souboru musíme vždy uvést cestu, nehledá se v SPECS. S -ba namísto -bb bychom získali binární i zdrojový balíček, s -bs jen zdrojový balíček.

    Tento způsob použijeme nejen při tvorbě vlastních balíčků, ale také když chceme překompilovat balíček například pro jinou distribuci, který vyžaduje úpravy. Zdrojové rpm nainstalujeme, upravíme, co je zapotřebí, a zkompilujeme rpm z „rozložené“ formy.

    Tarová koule. Zabalil-li nám nějaký dobrodinec spec soubor do tarové koule se zdrojovým kódem, můžeme ji přímo přebalit do rpm:

    rpmbuild -tb lobster-1.10.tar.bz2

    Analogicky předchozí možnosti můžeme -tb nahradit -ta či -ts a získat obě rpm či jen zdrojové. Každá volba -bněco, co se má udělat se samotným spec souborem (jsou i další než ty tři uvedené, časem na ně dojde), má své dvojče -tněco pro spec soubor obsažený v tarové kouli.

    Velké schéma věcí

    Grand scheme

    Obrázek shrnuje průběh kompilace a adresáře, jež se účastní výroby RPM balíku ze zdrojového rpm, případně z tarové koule. Adresáře jsou zobrazeny v záhlavích rámečků; rámečky samé ukazují jejich typický obsah. Černé šipky sledují postup kompilace; zelené znázorňují, jak spec soubor řídí jednotlivé její fáze (ty podrobně probereme v další kapitole).

    Výpisy rpmbuildu

    Nelze přehlédnout, že se při kompilaci vypisují do terminálu spousty věcí. Sám rpmbuild vypisuje na standardní výstup informace o jednotlivých fázích kompilace a na konci, resp. těsně před koncem, vypíše, co za balíčky vytvořil:

    Wrote: /home/yeti/src/RPM/SRPMS/lobster-1.10-1.src.rpm
    Wrote: /home/yeti/src/RPM/RPMS/i586/lobster-1.10-1.i586.rpm

    Na standardní chybový výstup se pak vypisují všechny spuštěné příkazy stylem sh -x. Do toho se míchá, co vypisuje na standardní, resp. chybový výstup ./configure, make, make install, etc. – zkrátka pěkný guláš. Zejména z něj nelze snadno vydobýt, jaké balíčky se nám kde objevily (pokud vůbec), což by se ale často hodilo vědět (volba --pipe pomůže jen marginálně). Můžeme si pomoci wrapperem podobným následujícímu, jenž v případě úspěšné kompilace vypíše jen jména balíčků, selže-li však něco, vypíše na chybový výstup celý log:

    #!/bin/bash
    outdir=${TMPDIR:-$HOME/tmp}
    specfile=$(grep -o '\<[a-zA-Z][-_+a-zA-Z0-9]*\.spec\>' <<<"$@" \
               || { echo "No spec file" 1>&2; exit 1; } | tail -n 1)
    log="$outdir/rpmbuild-$specfile-$$.log"
    if rpmbuild "$@" &>"$log"; then
      sed 's/^Wrote: //;t;d' "$log"
      rm "$log"
    else
      cat "$log" 1>&2
      echo Logfile: "$log"
    fi

    Nejčtenější články posledního měsíce

    Komiks xkcd 150: Dospěláci
    Komiks xkcd 1048: Emoce
    Komiks xkcd 131: Větráky

    Nejkomentovanější články posledního měsíce

    GIMP 2.8: V jednom okně a s celou řadou vylepšení
    Komiks xkcd 150: Dospěláci
    Průlomový rozsudek Soudního dvoru Evropské unie ve věci C-406/10, SAS v WPL
      všechny statistiky »

    Seriál Rukověť baliče RPM (dílů: 15)

    Rukověť baliče RPM - I (Úvod) (první díl)
    <—« Rukověť baliče RPM - I (Úvod)
    »—> Rukověť baliče RPM - III (Struktura spec souboru)
    Rukověť baliče RPM 15 - XV (Závěr) (poslední díl)

    Související články

    Rukověť baliče RPM - I (Úvod)
    Rukověť baliče RPM - III (Struktura spec souboru)
    Rukověť baliče RPM - IV (Fáze balení)
    Rukověť baliče RPM - V (Zdrojové soubory)
    Rukověť baliče RPM - VI (Makro %setup)
    Rukověť baliče RPM - VII (Podepisování, verze)
    Rukověť baliče RPM - VIII (Závislosti)
    Rukověť baliče RPM - IX (Sekce %files)
    Rukověť baliče RPM - X (Skriptíky)
    Rukověť baliče RPM - XI (Architektury. systémy, platformy)
    Rukověť baliče RPM - XII (Makra, úvod)
    Rukověť baliče RPM - XIII (Makra, dokončení)
    Rukověť baliče RPM - XIV (Přizpůsobení)
    Rukověť baliče RPM 15 - XV (Závěr)
    Na co se často ptáme: Balíčkovací systémy kromě posledního odstavce o checkinstallu.
    Nebojíme se kompilace - I (Teorie)
    Nebojíme se kompilace - II (GCC, configure, make, checkinstall) kompilace a instalace software, opět kromě části o checkinstallu.
    Balíčkovací systém Mandrake Linuxu RPM na uživatelské úrovni (a pro Mandrake).

    Odkazy a zdroje

    Doporučené čtení

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

    Netcat - Švýcarský armádní nůž pro TCP/IP
    Migrace systému: praxe
    Unixové nástroje – 22 (taskset, ionice, chrt)
    Migrace systému: bootovací proces
    Začínáme s VirtualBoxem: Nastavení virtuálního počítače
           

    Hodnocení: 90 %

            špatnédobré        

    Nástroje: Tisk bez diskuse

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    Komentáře

    Vložit další komentář

    26.5.2005 06:49 nameless
    Rozbalit Rozbalit vše tak něco jako omluva, možná
    Vzhledem k tomu, že jsem se posledně dopustil mírného vulgarismu, rozhodl jsem se, že se donutím přečíst oba články série a celé. Tak ten první opravdu přečíst nesvedu, ale tenhle téměř oproštěný infantilních vtipů už jde, jakž takž. A navíc má tenhle oproti předchozímu dokonce nějakou informační hodnotu. Myslel jsem si, že tímhle seriálem trochu aktualizuju informace získané ze 7 let staré série v Linuxových novinách. Zatím sice nic, ale stále ještě doufám, protože naděje umírá poslední...
    26.5.2005 08:40 tezkatlipoka | skóre: 34
    Rozbalit Rozbalit vše Re: tak něco jako omluva, možná
    to ja si clanek o RPM prectu rad, krom toho SPECialne tenhle dil mel jakousi podprahovou informaci po ktere touzim mit v PC uzivatele jmenem yeti :-)
    Vaše řeč budiž ano, ano, ne, ne. Co je nad to, je od ďábla.
    26.5.2005 17:18 Yossarian | skóre: 21 | blog: tezkorict
    Rozbalit Rozbalit vše Re: tak něco jako omluva, možná
    Ty ho tam ještě nemáš? Resp. ještě se ti tam nenasyslil? Já měl dojem, že už není na světě kompl, kde by už nebyl ;)
    Where the hell's my parachute?
    26.5.2005 11:03 Semo
    Rozbalit Rozbalit vše Kostlivci ve skrini
    Tak som pri hladani informacii o baleni debianich balikov narazil na nieco zaujimave. Ze by hriechy mladosti?

    http://www.root.cz/clanky/debianizace-vlastnich-zdroju/nazory/28640/
    26.5.2005 12:35 Sinny
    Rozbalit Rozbalit vše Re: Kostlivci ve skrini
    :-)
    Jiri 27.5.2005 15:05 Jiri "eR0" Svoboda | skóre: 37 | blog: cat /dev/mind | Prostějov
    Rozbalit Rozbalit vše Re: Kostlivci ve skrini
    Otazka je, jestli je to jen shoda nicku a nebo je to opravdu nas Yeti.
    27.5.2005 18:53 Michal Marek (twofish) | skóre: 55 | blog: { display: blog; } | Praha
    Rozbalit Rozbalit vše Re: Kostlivci ve skrini
    Styl se Yetimu nápadně podobá ;-)
    27.5.2005 08:48 unchallenger | skóre: 69 | blog: unchallenger
    Rozbalit Rozbalit vše Re: tak něco jako omluva, možná
    Autor slibuje, že infantilní vtipy neskončily, jen se mu jich do dalších dílů nezdařilo nacpat tolik co do prvního, který byl kecům vyhrazen. Pokud jde o obsah, tak ani v následujících dvou dílech se toho člověk, jenž už rpm balit umí, patrně mnoho nedozví.
    27.5.2005 12:36 tezkatlipoka | skóre: 34
    Rozbalit Rozbalit vše Re: tak něco jako omluva, možná
    dekujeme Yetimu za jeho zavazek.
    Vaše řeč budiž ano, ano, ne, ne. Co je nad to, je od ďábla.
    27.5.2005 19:12 Rastislav Lentner
    Rozbalit Rozbalit vše Re: tak něco jako omluva, možná
    Ja mu ďakujem za članok. Proti gustu žiaden dišputát.

    Založit nové vláknoNahoru

    ISSN 1214-1267   Powered by Hosting 90 Server hosting
    © 1999-2012 Argonit s. r. o. Všechna práva vyhrazena.