Guarantee business interface. stickfish.com
abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz 64bit.eu 64bit.eu abcprace.cz AbcPráce.cz Raydesk Raydesk
Sledujte AbcLinuxu.cz na:
facebook favicon logo  Facebooku twitter favicon logo  Twitteru,   identi.ca favicon logo  Identi.ca,   rss logo  RSS
Rozšířené hledání
×
včera 22:04 | Upozornění
Firma Valve, tvůrce online herní platformy Steam, hledá vývojáře pro portování her z Windows na Linux. Nedávno sice Valve dementovala zvěsti o chystaném linuxovém klientu Steam, ale třeba se blýská na lepší časy.
Robert Krátký | Komentářů: 9
včera 21:50 | Zajímavý software
Tvůrci Open-Xchange, open source groupwarového softwaru, oznámili, že vyvinuli migrační nástroj pro převod dat z Microsoft Outlooku na Open-Xchange. Nástroj podporuje přesun e-mailů, kontaktů, událostí a úkolů na Open-Xchange Server. Mohou jej použít jak individuální uživatelé, kteří používali Outlook jako samostatný poštovní klient, tak ti, kdo ho používali v kombinaci s Exchange Serverem.
Robert Krátký | Komentářů: 0
včera 21:40 | IT novinky
IBM představila dosud nejrychlejší mikroprocesor: 5,2 GHz a stojí tisíce dolarů. Jmenuje se z196 a bude dodáván s mainframy řady Z. z196 obsahuje 1,4 miliard tranzistorů na čipu, který měří 512 čtverečních milimetrů a je vyroben 45nm technologií. Na trh se dostane během září.
Robert Krátký | Komentářů: 5
včera 16:24 | Pozvánky
Konference LinuxAlt se koná o víkendu 6. a 7. listopadu 2010 na půdě FIT VUT v Brně — Králově poli. Pořádá ji společnost Red Hat, FIT VUT a Liberix, o.p.s., a hlavním tématem jsou opět open-source software a otevřené technologie. … více »
Vlastimil Ott | Komentářů: 0
včera 09:57 | IT novinky
Firma Archos oznámila pětici nových tabletů s Androidem 2.2 (Froyo). Zařízení budou od kapesní velikosti (displej 2,8", 3,2" a 4,3") až po iPadovsky velké tablety (displej 7" a 10,1"). Malé verze budou v prodeji již z září, ostatní přijdou během podzimu. Nejmenší a nejlevnější bude stát 99 USD, největší a nejdražší bude za 349 USD.
Robert Krátký | Komentářů: 6
včera 09:49 | Zajímavý článek
Čím se bude odlišovat Mozilla Firefox 4 od verze 3.x? Ubuntu.ka připravil přehled nových funkcí Firefoxu 4 včetně screenshotů srovnávajících příslušné vlastnosti ve verzích 3 a 4.
Robert Krátký | Komentářů: 14
včera 09:43 | Zajímavý software
Ruská firma Unigine připravuje nativní linuxovoou real-time strategickou hru OilRush. Cílem hry bude rozšiřovat, bránit a dobývat vrtné plošiny v moři. Hra používá engine Unigine a renderovat bude pomocí OpenGL 3.x/4.x. K dispozici je docela působivá video ukázka. Informuje Phoronix.
Robert Krátký | Komentářů: 11
včera 09:20 | Zajímavý software
KSplice, kód, který umožňuje patchování jádra za běhu (bez restartu), bude k dispozici pro uživatele Fedory zadarmo (kromě toho existuje placená 'enterprise' verze). Mimo Fedory je bezplatná verze k mání i pro Ubuntu.
Robert Krátký | Komentářů: 6
1.9. 19:47 | Zajímavý software
Firma Fotolab (sběrny Fotolab a FotoStar) vydala své programy pro objednávání tisku digitálních fotografií, fotoknih apod. i ve verzích pro Linux. Ze stránek si můžete stáhnout archiv s perlovským skriptem, který po odsouhlasení EULA dostahuje potřebné aplikační soubory.
Robert Krátký | Komentářů: 21
1.9. 18:47 | Humor
Koncem srpna byl Microsoftu schválen patent na vypínání operačního systému. Patent má výstižný název "Operating system shut down" a ve výtažku se mimo jiné píše: "Uživatelské rozhraní a schéma poskytnuté pro umožnění vypnutí operačního systému". Vypnutí operačního systému prostě není žádná legrace. Patent uvádí pět "vynálezců". … více »
Robert Krátký | Komentářů: 94
Používáte domácí účetnictví?
 (5%)
 (6%)
 (9%)
 (80%)
Celkem 586 hlasů
 Komentářů: 26, poslední 1.9. 19:15
IBM Smartplanet logo Pojďte s námi budovat chytřejší planetu
    Rozcestník
    Doporučujeme

    Jak zprovoznit CGI ve Fedoře s aktivním SE Linuxem

    18.3.2007 18:36 | Přečteno: 536× | Linux | Výběrový blog

    Jako dlouholetý uživatel Fedory jsem věděl, že již nějakou dobu má aktivní rozšíření SELinux. Při pokusu spustit CGI počítadlo přístupů (wwwcount) se to potvrdilo - jádro hlásilo avc: denied { write } for pid... a skript nefungoval. Popíšeme si, co se vlastně stalo, a jak to napravit...

    Lehký začátek - standardní instalace wwwcount

    Jen v kostce uvedu instalaci, abyste si mohli v praxi na něčem vyzkoušet, jak se selinux chová.

    Stáhněte si wwwcount např. z http://www.muquit.com/muquit/software/Count/Count.html a rozbalte jej

    Spusťte make config.h. Uvedu jen odlišnosti od implicitního nastavení

    cgi-bin directory
    /var/www/cgi-bin
    data directory
    /var/local/wwwcount/data
    Log directory
    /var/local/wwwcount/data

    Dále pokračujeme pár make příkazy (pokud se ztratíte, tak spusťte make bez parametrů - zobrazí targety). Příkazy doporučuji spouštět jako běžný (ne-root) uživatel

    make all_libs
    make Count.cgi
    make mkstrip
    make extdgts
    make cfg
    

    V případě make cfg postupujte dle vlastního uvážení (klidně vše jen potvrďte)

    Dejte su na root-a a spusťte

    make install
    

    Také musíme vytvořit adresáře pro data a logy, tj.

    cd /var/local
    mkdir wwwcount
    mkdir wwwcount/data
    mkdir wwwcount/logs
    chgrp apache wwwcount/{data,logs}
    chmod g+rw wwwcount/{data,logs}
    

    Už jen zbývá vyrobit testovací stránku s počítadlem:

    Počítadlo: <img src="/cgi-bin/Count.cgi?df=sample.dat&ft=0">
    

    Pokud máte standardní FC6 s aktivním selinuxem (tj. nebootovali jste se selinux=0), tak by se vám měla zobrazit stránka se "zlomeným" obrázkem, ačkoliv z hlediska klasických Unix práv je vše v pořádku. Příkaz dmesg by měl navíc obsahovat něco jako:

    audit(1174234991.319:4): avc:  denied  { write } for  pid=2837 comm="Count.cgi" name="data" dev=sda7 ino=2587335 scontext=user_u:system_r:httpd_sys_script_t:s0 tcontext=user_u:object_r:var_t:s0 tclass=dir
    audit(1174234991.319:5): avc:  denied  { write } for  pid=2837 comm="Count.cgi" name="logs" dev=sda7 ino=2587337 scontext=user_u:system_r:httpd_sys_script_t:s0 tcontext=user_u:object_r:var_t:s0 tclass=dir
    

    SE Linux v praxi

    Z pohledu administrátora můžeme SE Linux považovat jako dodatečný filtr na volání jádra - to co zobrazil dmesg ve složených závorkách { write } je volání jádra, jehož SE audit neprošel. Další údaje jsou poměrně samovysvětlující až na ty poslední.

    scontext
    subject context - SE kontext pachatele (kdo se o to pokusil)
    tcontext
    target context (?) - cílový kontext objektu, se kterým chtěl daný objekt manipulovat.

    Subject kontext

    Váš kontext si můžete snadno zjistit příkazem id - vypíše jej za standardními POSIXovými informacemi jako např.

    uid=501(henryk) gid=501(henryk) groups=501(henryk) context=user_u:system_r:unconfined_t:s0
    

    Fedora používá tzv. targeted policy, tzn., že pouze explicitně vyjmenované programy podléhají restrikcím SE Linuxu. Jednotlivé údaje jsou, uživatel (*_u), role (*_r), a typ (*_t). unconfined znamená, že SELinux není pro náš proces aktivní (tj. nijak nás ne-audituje ani neomezuje)

    V dalším textu se soustředíme jen na type (*_t), v SE linuxu je to synonymum pro domain (ale nemusí platit v jiných Unixech).

    Obecně si můžete aktuální stav SE linuxu ověřit příkazem sestatus

    Kde se vzal httpd_sys_script_t

    Nejdříve se ujistěte, že máte nainstalovaný balíček selinux-policy - zde jsou totíž klíčové manuál stránky, konkrétně nás zajímá:

    man httpd_selinux
    

    Tam se dozvíme, jaký typ máme nastavit u souborů, či adresářů, aby cgi skripty mohly k nim přistupovat.

    SE type zjistíme parametrem '-Z' příkazu ls, např.

    $ ls -Zd /var/local/wwwcount/logs
    drwxrwxr-x  root apache user_u:object_r:var_t:s0         /var/local/wwwcount/logs
    

    Říká, že náš adresář pro logy je typu var_t, tj. naše cgi by muselo mít potřebná práva tento typ a to pochopitelně nemá. Proto dle manuálové stránky provedeme úpravu

    chcon -R -t httpd_sys_script_rw_t /var/local/wwwcount/{data,logs}
    

    A ověříme výsledek:

    $ls -Zd /var/local/wwwcount/{data,logs}
    
    drwxrwxr-x  root apache user_u:object_r:httpd_sys_script_rw_t:s0 /var/local/wwwcount/data
    drwxrwxr-x  root apache user_u:object_r:httpd_sys_script_rw_t:s0 /var/local/wwwcount/logs
    

    tj. změna proběhla úspěšně

    Zkuste opět reload stránky s počítadlem - nyní už by mělo fungovat správně a bez hlášek od jádra

    Další informace

    Hlavní konfigurace selinuxu je pod /etc/selinux/*. Situaci malinko komplikuje fakt, že existují hned dva způsoby definic.

    1. monolitická - textové soubory pod /etc/selinux / mělo by se editovat příkazem semanage
    2. module - soubory *.pp spravují se příkazem semodule

    Jistě vás zajímá, jak takové definice pravidel vypadají. Kromě zmíněného adresáře /etc/selinux/ doporučuji instalaci balíčku selinux-devel, pak si prohlédnout např. /usr/share/selinux/devel/include/services/apache.if

    Bohužel jsem nenašel moc dokumentace (a to nehovořím o SE Linuxu v české literatuře), prakticky jen:

    Varování: Tento příspěvek je bez záruky! Sám sebe považuji za SEzačátečníka!
           

    Hodnocení: 100 %

            špatnédobré        

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

    Komentáře

    Vložit další komentář

    ISSN 1214-1267   Powered by 64bit.eu   64bit.eu logo
    © 1999-2010 Stickfish, s. r. o. Všechna práva vyhrazena.