abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 12:33 | Zajímavý projekt

    MALUS je kontroverzní proprietarní nástroj, který svým zákazníkům umožňuje nechat AI, která dle tvrzení provozovatelů nikdy neviděla původní zdrojový kód, analyzovat dokumentaci, API a veřejná rozhraní jakéhokoliv open-source projektu a následně úplně od píky vygenerovat funkčně ekvivalentní software, ovšem pod libovolnou licencí.

    NUKE GAZA! 🎆 | Komentářů: 11
    dnes 03:55 | Bezpečnostní upozornění

    Příspěvek na blogu Ubuntu upozorňuje na několik zranitelností v rozšíření Linuxu o mandatorní řízení přístupu AppArmor. Společně jsou označovány jako CrackArmor. Objevila je společnost Qualys (technické detaily). Neprivilegovaný lokální uživatel se může stát rootem. Chyba existuje od roku 2017. Doporučuje se okamžitá aktualizace. Problém se týká Ubuntu, Debianu nebo SUSE. Red Hat nebo Fedora pro mandatorní řízení přístupu používají SELinux.

    Ladislav Hagara | Komentářů: 2
    včera 17:22 | Nová verze

    Byla vydána nová verze 19 integrovaného vývojového prostředí (IDE) Qt Creator. Podrobný přehled novinek v changelogu.

    Ladislav Hagara | Komentářů: 0
    včera 03:44 | Nová verze

    Bitwig Studio (Wikipedie) bylo vydáno ve verzi 6. Jedná se o proprietární multiplatformní (macOS, Windows, Linux) digitální pracovní stanici pro práci s audiem (DAW).

    Ladislav Hagara | Komentářů: 4
    včera 02:11 | Komunita

    Společnost Igalia představila novou linuxovou distribuci (framework) s názvem Moonforge. Jedná se o distribuci určenou pro vestavěné systémy. Vychází z projektů Yocto a OpenEmbedded.

    Ladislav Hagara | Komentářů: 0
    včera 00:44 | Nová verze

    Google Chrome 146 byl prohlášen za stabilní. Nejnovější stabilní verze 146.0.7680.71 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Opraveno bylo 29 bezpečnostních chyb. Vylepšeny byly také nástroje pro vývojáře.

    Ladislav Hagara | Komentářů: 0
    včera 00:22 | Nová verze

    D7VK byl vydán ve verzi 1.5. Jedná se o fork DXVK implementující překlad volání Direct3D 3 (novinka), 5, 6 a 7 na Vulkan. DXVK zvládá Direct3D 8, 9, 10 a 11.

    Ladislav Hagara | Komentářů: 0
    11.3. 23:22 | Nová verze

    Bylo vydáno Eclipse IDE 2026-03 aneb Eclipse 4.39. Představení novinek tohoto integrovaného vývojového prostředí také na YouTube.

    Ladislav Hagara | Komentářů: 4
    11.3. 10:22 | Upozornění

    Ze systému Slavia pojišťovny uniklo přibližně 150 gigabajtů citlivých dat. Jedná se například o pojistné dokumenty, lékařské záznamy nebo přímou komunikaci s klienty. Za únik může chyba dodavatelské společnosti.

    Ladislav Hagara | Komentářů: 14
    11.3. 10:11 | IT novinky

    Sněmovna propustila do dalšího kola projednávání vládní návrh zákona o digitální ekonomice, který má přinést bezpečnější on-line prostředí. Reaguje na evropské nařízení DSA o digitálních službách a upravuje třeba pravidla pro on-line tržiště nebo sociální sítě a má i víc chránit děti.

    Ladislav Hagara | Komentářů: 36
    Které desktopové prostředí na Linuxu používáte?
     (16%)
     (7%)
     (0%)
     (11%)
     (29%)
     (2%)
     (5%)
     (2%)
     (13%)
     (25%)
    Celkem 1066 hlasů
     Komentářů: 26, poslední včera 08:56
    Rozcestník

    Docker dpkg-buildpackage [note]

    3.11.2015 23:50 | Přečteno: 1105× | dev | Výběrový blog | poslední úprava: 3.11.2015 23:50

    Micro-návod na balení deb balíků z unstable prostředí pomocí dockeru. Jde trochu o zápis *pro sebe*, ale třeba to někomu pomůže...

    Chceme-li vytvořit balík pro konkrétní verzi Debianu, např. wheezy, a chceme-li build provést na čistém systému (či jiné verzi), máme kromě chrootu, pbuilderu, dedikovaného virtuálu atd. možnost právě přes docker.
    Návod cílím na build pro debian wheezy, který máme na serverech.

    Nejprve si stáhneme či připravíme image s požadovaným systémem. Pokud důvěřujeme připravenému obrazu, stačí:

    $ sudo docker pull debian:wheezy
    

    Za dvojtečkou je uveden tag. Neuvedením se stáhne tag latest. Snadno můžeme mít připraveny image pro více různých verzí systému.

    $ sudo docker images
    REPOSITORY          TAG                 IMAGE ID            CREATED             VIRTUAL SIZE
    debian              wheezy              3b5671666ac3        11 days ago         84.89 MB
    

    Image chci doplnit o kompilátor a další utility, které nechci pokaždé nechávat instalovat znovu. Spustím tedy kontejner:

      $ sudo docker run -ti debian:wheezy /bin/bash
      root@1ec31c9983e3:/$
    

    Nainstaluji základ pro build (případně další dle potřeb - cmake, autotools atd.).

      root@1ec31c9983e3:/$ apt-get update
      root@1ec31c9983e3:/$ apt-get install build-essential devscripts debhelper
    

    Vytvoříme entrypoint pro build - jde o jednoduchý skript, který vleze do baleného adresáře, vytvoří z debian/control seznam závislostí, nainstaluje je (chce pořešit jinak, pokud je vyžadován neinteraktivní režim) a poté spustí build.

      root@1ec31c9983e3:/$ mkdir /mnt/package
      root@1ec31c9983e3:/$ cat <<EOF > /root/dpkg-buildpackage.sh
      #!/bin/bash
      cd /mnt/package/"\$PACKAGE_NAME" && mk-build-deps -i && dpkg-buildpackage \$@
      EOF
      root@1ec31c9983e3:/$ chmod +x /root/dpkg-buildpackage.sh
    

    Ukončím práci v kontejneru a zapíšu výsledek do image. Hash je z promptu root@1ec31c9983e3. Protože base systém dále nepotřebuji, nechám přepsat image debian v tagu wheezy, ale je možné zapsat i nový image a původní debian:wheezy si ponechat.

      root@1ec31c9983e3:/$ exit
      $ sudo docker commit -m 'Build and dev utils.' 1ec31c9983e3 debian:wheezy
    

    Poté uvažujme situaci, že chci balit ~/sources/projekt/. Adresář ~/sources/projekt/debian/ tedy obsahuje control, rules apod. Build nechává hotové balíky v nadřazeném adresáři, mountujeme do kontejneru tedy ten. Název baleného adresáře předáme v proměnné PACKAGE_NAME, se kterou počítá skript /root/dpkg-buildpackage.sh.
    Poznámka: Volba -v ~/.gnupg:/root/.gnupg je zbytečná, nechcete-li hotový balík podepisovat.

      $ cd ~/sources
      $ sudo docker run -ti -v $(pwd):/mnt/package -v ~/.gnupg:/root/.gnupg -e PACKAGE_NAME=projekt --entrypoint=/root/dpkg-buildpackage.sh debian:wheezy
    

    Po skončení buildu by na nás měl čekat balík projekt-verze.deb (zjednodušeno).
    Postup tvorby image lze zjednodušit Dockerfilem, viz [1].

    No a zbývá jen promazat ukončené kontejnery - nechci je commitovat, ale zahodit.

      $ sudo docker rm `sudo docker ps -aq --filter 'status=exited'`
    

    Zdroje:
    [1] https://github.com/stevenjack/dpkg-buildpackage

           

    Hodnocení: 100 %

            špatnédobré        

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

    Komentáře

    Vložit další komentář

    pavlix avatar 4.11.2015 08:55 pavlix | skóre: 54 | blog: pavlix
    Rozbalit Rozbalit vše Re: Docker dpkg-buildpackage [note]
    To úplně nevypadá jako hezké integrované řešení.
    Já už tu vlastně ani nejsem. Abclinuxu umřelo.
    4.11.2015 09:19 johniez | skóre: 17 | blog: xyz | Praha
    Rozbalit Rozbalit vše Re: Docker dpkg-buildpackage [note]
    Tak ono s tim Dockerfile je rozjeti celkem v pohode. Jak jsem si rozepsal jednotlive kroky, vypada to kostrbate.

    No a tem prikaz pro build - idealne skript ci alias, jinak je to zrudnost, no :)
    Josef Kufner avatar 4.11.2015 13:06 Josef Kufner | skóre: 70
    Rozbalit Rozbalit vše Re: Docker dpkg-buildpackage [note]
    Můžeš tedy přihodit na konec kompakní výsledek, jak to vypadá v reálném provozu?
    Hello world ! Segmentation fault (core dumped)
    cezz avatar 4.11.2015 16:38 cezz | skóre: 24 | blog: dm6
    Rozbalit Rozbalit vše Re: Docker dpkg-buildpackage [note]
    Ja osobne by som za tym ziadnu eleganciu a integraciu nehladal. Ono je to take riesenie "na kolene", ked potrebujes skompilovat balicek a nechces si za*rat system. (alebo pre inu verziu) Ten link na konci clanku je o dost jednoduchsi a posobi viac elegantne. V zasade je to asi to iste ako pouzit chroot, akurat to moze byt jednoduchsie ak je niekto familiarnejsi s Dockerom.

    Ak kompilujes balicky castejsie ako raz za uhorsky rok, tak je urcite lepsie obzriet sa po niecom inom, ale zas zvycajne ide o trosku vacsiu casovu investiciu.
    Computers are not intelligent. They only think they are.
    4.11.2015 10:30 little-drunk-jesus | skóre: 14
    Rozbalit Rozbalit vše Re: Docker dpkg-buildpackage [note]
    super zapisek, jen v tom Dockerfile je dobre nahradit:

    RUN apt-get update RUN apt-get install build-essential debhelper -y

    za:

    RUN apt-get update && apt-get install build-essential debhelper -y

    Jinak hrozi automaticke vyuziti cache dockeru pro layer a dost zvlastni chovani. Obecne plati, ze v Dockeru je dobre co nejvice prikazu spojit, protoze kazda RUN instrukce vytvari vrstvu a soubory v ni uz nejdou odstranit (image bobtna).

    Bedňa avatar 7.11.2015 22:46 Bedňa | skóre: 34 | blog: Žumpa | Horňany
    Rozbalit Rozbalit vše Re: Docker dpkg-buildpackage [note]
    Fakt Docker a balíčkovanie? Trochu mi to riešenie pripomína jeden init čo robí všetko okrem toho čo by mal :-) Teda nech si každý robí čo chce len nech sa to nedostane main streamu :-D
    KERNEL ULTRAS video channel >>>
    pavlix avatar 8.11.2015 19:46 pavlix | skóre: 54 | blog: pavlix
    Rozbalit Rozbalit vše Re: Docker dpkg-buildpackage [note]
    Přijde ti použití třeba mocku o tolik čistší? :)
    Já už tu vlastně ani nejsem. Abclinuxu umřelo.
    Bedňa avatar 8.11.2015 20:32 Bedňa | skóre: 34 | blog: Žumpa | Horňany
    Rozbalit Rozbalit vše Re: Docker dpkg-buildpackage [note]
    Tak Mock je nápad od RHEL, či?
    KERNEL ULTRAS video channel >>>
    cezz avatar 9.11.2015 16:51 cezz | skóre: 24 | blog: dm6
    Rozbalit Rozbalit vše Re: Docker dpkg-buildpackage [note]
    Vzhladom na to, ze docker je v podstate taky chroot na steroidoch mi to nepripada o moc ine ako pouzit napriklad fakeroot..
    Computers are not intelligent. They only think they are.
    9.11.2015 21:40 johniez | skóre: 17 | blog: xyz | Praha
    Rozbalit Rozbalit vše Re: Docker dpkg-buildpackage [note]
    Jasne. Co se ti na tom nezda? Mas pripravene prostredi, ve kterem se balik vytvori - jednoduche a rychle. Prijde mi to v pohode.

    K cemu bys docker vyuzil?

    Založit nové vláknoNahoru

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.