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 20:00 | Nová verze Ladislav Hagara | Komentářů: 0
dnes 19:33 | Pozvánky

Pražská Fedora 27 Release Party, oslava nedávného vydání Fedory 27, se uskuteční 19. prosince od 19:00 v prostorách společnosti Etnetera (Jankovcova 1037/49). Na programu budou přednášky o novinkách, diskuse, neřízený networking atd.

Ladislav Hagara | Komentářů: 0
dnes 18:11 | Nová verze

Byla vydána verze 2.11.0 QEMU (Wikipedie). Přispělo 165 vývojářů. Provedeno bylo více než 2 000 commitů. Přehled úprav a nových vlastností v seznamu změn.

Ladislav Hagara | Komentářů: 0
dnes 17:44 | Komunita

Canonical oznámil dostupnost kryptografických balíčků s certifikací FIPS 140-2 úrovně 1 pro Ubuntu 16.04 LTS pro předplatitele podpory Ubuntu Advantage Advanced. Certifikace FIPS (Federal Information Processing Standards) jsou vyžadovány (nejenom) vládními institucemi USA.

Ladislav Hagara | Komentářů: 1
dnes 16:11 | Zajímavý software

Společnost Avast uvolnila zdrojové kódy svého dekompilátoru RetDec (Retargetable Decompiler) založeného na LLVM. Vyzkoušet lze RetDec jako webovou službu nebo plugin pro interaktivní disassembler IDA. Zdrojové kódy RetDec jsou k dispozici na GitHubu pod open source licencí MIT.

Ladislav Hagara | Komentářů: 2
včera 11:00 | Zajímavý software
Na Good Old Games je v rámci aktuálních zimních slev zdarma k dispozici remasterovaná verze klasické point&click adventury Grim Fandango, a to bez DRM a pro mainstreamové OS včetně GNU/Linuxu. Akce trvá do 14. prosince, 15:00 SEČ.
Fluttershy, yay! | Komentářů: 6
včera 07:22 | Pozvánky

Konference InstallFest 2018 proběhne o víkendu 3. a 4. března 2018 v Praze na Karlově náměstí 13. Spuštěno bylo CFP. Přihlásit přednášku nebo workshop lze do 18. ledna 2018.

Ladislav Hagara | Komentářů: 0
12.12. 20:22 | Nová verze

Před měsícem byla vydána Fedora 27 ve dvou edicích: Workstation pro desktopové a Atomic pro cloudové nasazení. Fedora Server byl "vzhledem k náročnosti přechodu na modularitu" vydán pouze v betaverzi. Finální verze byla naplánována na leden 2018. Plán byl zrušen. Fedora 27 Server byl vydán již dnes. Jedná se ale o "klasický" server. Modularita se odkládá.

Ladislav Hagara | Komentářů: 6
12.12. 10:22 | Zajímavý článek

Lukáš Růžička v článku Kuchařka naší Růži aneb vaříme rychlou polévku z Beameru na MojeFedora.cz ukazuje "jak si rychle vytvořit prezentaci v LaTeXu, aniž bychom se přitom pouštěli do jeho bezedných hlubin".

Ladislav Hagara | Komentářů: 13
12.12. 07:22 | Komunita

Od 26. do 29. října proběhla v Bochumi European Coreboot Conference 2017 (ECC'17). Na programu této konference vývojářů a uživatelů corebootu, tj. svobodné náhrady proprietárních BIOSů, byla řada zajímavých přednášek. Jejich videozáznamy jsou postupně uvolňovány na YouTube.

Ladislav Hagara | Komentářů: 0
Jak se vás potenciálně dotkne trend odstraňování analogového audio konektoru typu 3,5mm jack z „chytrých telefonů“?
 (8%)
 (1%)
 (1%)
 (1%)
 (75%)
 (14%)
Celkem 987 hlasů
 Komentářů: 45, poslední 1.12. 19:00
    Rozcestník

    Dotaz: Linux - Vlakna

    9.6.2009 15:50 Jarda
    Linux - Vlakna
    Přečteno: 665×

    Zdravim,

    Mel bych dotaz na zasilani signalu v linuxu. Jde mi o toto. Pokud napriklad vlakno hojne vyuziva IO operace tak se mu jaksi tezko da poslat signal.

    Napriklad kdyz date do smycky cout << "Neco << endl.

    Jde nejak definovat aby signal byl dorucenej v kazdym pripade ?

     

    Dekuji za odpoved.

     

    Odpovědi

    9.6.2009 16:04 rastos | skóre: 60 | blog: rastos
    Rozbalit Rozbalit vše Re: Linux - Vlakna
    Pokiaľ viem, tak pri vykonaní volania signal() sa nastaví príslušný bit v nejakej maske v štruktúre, v ktorej si jadro udržuje informácie o procese. Bity tejto masky sú skontrolované jadrom v momente, kedy sa jadro rozhodne priradiť CPU tomuto procesu. Aby signál nebol doručený, musel by process bežať a nebyť prerušený ničím iným (ani iným procesom ani jadrom samotným) a ak by bol prerušený, tak nedostať znova CPU - čo mi pripadá značne nepravdepodobné. Skôr by som pátral po tom, aký druh signálu posielaš, či nie je blokovaný, či je obslúžiteľný atď. Alebo je reč o úplne iných druhoch signálov - takých ako posiela pthread_cond_signal()?
    9.6.2009 17:41 Messa | skóre: 39 | blog: Messa
    Rozbalit Rozbalit vše Re: Linux - Vlakna
    I když má vlákno zrovna rozběhnutý nějaký syscall, zasláním signálu je tento syscall přerušen, signál obsloužen a knihovní funkce tento syscall obalující obvykle vrací něco jako EINTR nebo vrátí méně dat, než o kolik byly požádány (viz man stránky). Mám na mysli signály zasílané např. příkazem kill.

    Asi by bylo lepší podroběji popsat situaci, ukázat kód...
    9.6.2009 18:09 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: Linux - Vlakna
    Tohle ale platí jen pro některé syscally, typicky ty, u kterých se dá očekávat, že se na jejich dokončení může dlouho čekat. To, co tazatel popisuje, ale odpovídá read() nebo write(), které mezi ně zrovna patří.
    10.6.2009 14:25 Radek Miček | skóre: 23 | blog: radekm_blog
    Rozbalit Rozbalit vše Re: Linux - Vlakna

    Tomu nerozumím, v manu se např. u read píše:

    If a read() is interrupted by a signal before it reads any data, it shall return -1 with errno set to [EINTR].
    10.6.2009 14:42 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: Linux - Vlakna
    Čemu nerozumíte? Vždyť jsem přece jasně napsal, že read() zrovna patří mezi syscally, které se chovají tak, jak Messa tvrdí. Pouze jsem upozorňoval, že se tak nechovají všechny syscally, jak by se z jeho příspěvku mohlo zdát.
    10.6.2009 16:14 Radek Miček | skóre: 23 | blog: radekm_blog
    Rozbalit Rozbalit vše Re: Linux - Vlakna

    Aha, já to pochopil opačně, omlouvám se.

    10.6.2009 22:08 Ash | skóre: 53
    Rozbalit Rozbalit vše Re: Linux - Vlakna
    No nejste sám, já taky :) Až po cca sedmám přečtení jsem si všiml že tam není

    ale odpovídá read() nebo write(), které mezi ně zrovna nepatří

    ale

    ale odpovídá read() nebo write(), které mezi ně zrovna patří
    13.6.2009 23:59 Ivan
    Rozbalit Rozbalit vše Re: Linux - Vlakna

    Hmm a neni jeste nejak zkomplikovano tim, ze zarizeni v unixu jsou rozdelana na rychla a pomala? Na neco takoveho si matne zvpominam z prednasek z Unixu, ale uz si nedokazu presne vzpomenout cim se ta zarizeni lisi.

     

    oroborus avatar 14.6.2009 13:44 oroborus | skóre: 20 | blog: Bulanci
    Rozbalit Rozbalit vše Re: Linux - Vlakna

    a nie nahodou: "zariadenia v Unixe su rozdelene na znakove a blokove" ?

    9.6.2009 18:06 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: Linux - Vlakna
    Je-li řeč o klasických signálech, tak signál vždy zpracuje některý thread procesu, přičemž to, který to bude, můžete ovlivnit nastavení masek jednotlivým threadům pomocí pthread_sigmask(). Pokud např. nastavíte signál jako blokovaný všem threadům kromě jednoho, pak ho zpracuje právě ten jeden. Druhou možností je použít pthread_kill() a poslat signál přímo konkrétnímu threadu.
    10.6.2009 11:50 Jarda
    Rozbalit Rozbalit vše Re: Linux - Vlakna

    No ukazka kodu je jednoducha.

    Napriklad:

     

    #include <iostream>

     

    using namespace std;

     

    int main()

    {

    while(true)

    {

    coud << "Hello World" << endl;

    }

    }

     

    a zkuste si to zabit pres ctr+c trva to pekne dlouho.

    O co mi jde.  Pisu managera kterej bude obsluhovat vlakna a nastavovat jim urcitej cas, ktery budou mit na vyrizeni sitovyho pozadavku.

    Udelal sem to takto. V hlavni smycce managera ma sleep(1) a tam projde kontainer tech vlaken ktery obsluhuje. Pokud vyprsel cas posle mu signal. Ja ho v tom vlakne muzu odchytnout obslouzit zavrit socket atp.

    Jenze pokud tech vlaken bude v manageru vic a budou se chovat tak jako viz nahore tak ten signal vubec neposlu respektive se neobslouzi.

    Nejaky napad jak to udelat lip ?

     

    Diky 

     

     

     

     

    10.6.2009 11:53 Ivan
    Rozbalit Rozbalit vše Re: Linux - Vlakna

    Hmm nejsem si jistej jestli jsou signaly to pravy reseni pro komunikaci mezi vlakny. Zkus se podivat na knihovnu apr (apache portable library). Ta to sice resi trochu slozite, ale zase to funguje i na woknach.

     

    13.6.2009 01:25 ivan
    Rozbalit Rozbalit vše Re: Linux - Vlakna

    Kouknete se na tohle. apr knihovna to vlastne resi dost neumele. Komunikaci mezi vlakny je mozne vyresit bez signalu, bez syscallu, bez zamku. Cele je to pak mnohem rychlejsi. http://www.gamedev.net/community/forums/topic.asp?topic_id=511635

    Implementace na linuxu je bohuzel dost pracna.

    10.6.2009 12:38 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: Linux - Vlakna
    a zkuste si to zabit pres ctr+c trva to pekne dlouho.

    U mne bez pozorovatelného zpoždění. Ale i v případě, že to máte pomalé, problém vůbec nemusí být (a téměř jistě není) v tom, že by thread nedostával signály.

    10.6.2009 13:11 rastos | skóre: 60 | blog: rastos
    Rozbalit Rozbalit vše Re: Linux - Vlakna
    a zkuste si to zabit pres ctr+c trva to pekne dlouho.
    Tu je ale problém v tom, že dlho beží ten výpis na obrazovku. Skús to presmerovať do súboru - koľko potrvá od stlačenia Ctrl+C po skončenie procesu. Ešte markantnejšie to je keď to pustíš na stroji, na ktorý si prihlásený po sieti.
    10.6.2009 13:19 pht | skóre: 48 | blog: pht
    Rozbalit Rozbalit vše Re: Linux - Vlakna
    Jak bylo řečeno, to zpoždění určite nebude tím že by nějaký signál nedošel. IMHO prostě nestíhá vypisovat terminál ty řetězce. Zkuste přesměrovat výstup Vašeho programu do /dev/null a uvidíte jak to funguje. Zařídit zaslání signálu za 1 sekundu umí i systém samotný (viz funkce alarm a spol.), na to nepotřebujete zvláštní vlákno. Navíc pokud se to čekání týká nějaké odezvy na socketu nebo souborovém deskriptoru, tak postačí obyčejný select nebo poll a obejdete se bez signálů úplně.
    In Ada the typical infinite loop would normally be terminated by detonation.
    10.6.2009 13:21 Messa | skóre: 39 | blog: Messa
    Rozbalit Rozbalit vše Re: Linux - Vlakna
    Pokud se nejedná o práci s diskem, asi by pomohl select/pselect.

    Jinak v tomhle případě to bude spíš pomalým renderováním terminálu :-) (jak již bylo zmíněno)

    Založit nové vláknoNahoru

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

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