abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 04:33 | IT novinky

    Společnost Espressif (ESP8266, ESP32, …) získala většinový podíl ve společnosti M5Stack, čímž posiluje ekosystém AIoT.

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

    Byla vydána nová stabilní verze 3.5 svobodného multiplatformního softwaru pro editování a nahrávání zvukových souborů Audacity (Wikipedie). Přehled novinek také na YouTube. Nově lze využívat cloud (audio.com). Ke stažení je oficiální AppImage. Zatím starší verze Audacity lze instalovat také z Flathubu a Snapcraftu.

    Ladislav Hagara | Komentářů: 0
    včera 16:44 | Zajímavý článek

    50 let operačního systému CP/M, článek na webu Computer History Museum věnovaný operačnímu systému CP/M. Gary Kildall z Digital Research jej vytvořil v roce 1974.

    Ladislav Hagara | Komentářů: 0
    včera 16:22 | Pozvánky

    Byl zveřejněn program a spuštěna registrace na letošní konferenci Prague PostgreSQL Developer Day, která se koná 4. a 5. června. Na programu jsou 4 workshopy a 8 přednášek na různá témata o PostgreSQL, od konfigurace a zálohování po využití pro AI a vector search. Stejně jako v předchozích letech se konference koná v prostorách FIT ČVUT v Praze.

    TomasVondra | Komentářů: 0
    včera 03:00 | IT novinky

    Po 48 letech Zilog končí s výrobou 8bitového mikroprocesoru Zilog Z80 (Z84C00 Z80). Mikroprocesor byl uveden na trh v červenci 1976. Poslední objednávky jsou přijímány do 14. června [pdf].

    Ladislav Hagara | Komentářů: 6
    včera 02:00 | IT novinky

    Ještě letos vyjde Kingdom Come: Deliverance II (YouTube), pokračování počítačové hry Kingdom Come: Deliverance (Wikipedie, ProtonDB Gold).

    Ladislav Hagara | Komentářů: 3
    21.4. 19:11 | Komunita

    Thunderbird 128, příští major verze naplánovaná na červenec, přijde s nativní podporou Exchange napsanou v Rustu.

    Ladislav Hagara | Komentářů: 19
    21.4. 04:44 | Komunita

    Byly vyhlášeny výsledky letošní volby vedoucího projektu Debian (DPL, Wikipedie). Novým vedoucím je Andreas Tille.

    Ladislav Hagara | Komentářů: 7
    21.4. 00:11 | Nová verze

    Po osmi měsících vývoje byla vydána nová verze 0.12.0 programovacího jazyka Zig (GitHub, Wikipedie). Přispělo 268 vývojářů. Přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 2
    20.4. 23:55 | Pozvánky

    Poslední měsíc byl plný zajímavých akcí, o kterých Vám bastlíři z projektu MacGyver mohou povědět, protože se na ně sami vydali. Kde všude byli, ptáte se? Objevili se na Installfestu, Arduino Day, Hackaday Europe a tajném srazu bastlířů z Twitteru. A z každé akce pro vás mají zajímavé poznatky.

    … více »
    bkralik | Komentářů: 1
    KDE Plasma 6
     (71%)
     (10%)
     (2%)
     (17%)
    Celkem 670 hlasů
     Komentářů: 4, poslední 6.4. 15:51
    Rozcestník

    Dotaz: Linux - Vlakna

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

    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: 62 | 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: 72 | 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: 72 | 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: 72 | 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: 72 | 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: 62 | 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.