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 01:22 | Nová verze Ladislav Hagara | Komentářů: 0
    dnes 00:55 | Zajímavý projekt

    PyXL je koncept procesora, ktorý dokáže priamo spúštat Python kód bez nutnosti prekladu ci Micropythonu. Podľa testov autora je pri 100 MHz približne 30x rýchlejší pri riadeni GPIO nez Micropython na Pyboard taktovanej na 168 MHz.

    vlk | Komentářů: 0
    včera 19:44 | Nová verze

    Grafana (Wikipedie), tj. open source nástroj pro vizualizaci různých metrik a s ní související dotazování, upozorňování a lepší porozumění, byla vydána ve verzi 12.0. Přehled novinek v aktualizované dokumentaci.

    Ladislav Hagara | Komentářů: 0
    včera 17:33 | Nová verze

    Raspberry Pi OS, oficiální operační systém pro Raspberry Pi, byl vydán v nové verzi 2025-05-06. Přehled novinek v příspěvku na blogu Raspberry Pi a poznámkách k vydání. Pravděpodobně se jedná o poslední verzi postavenou na Debianu 12 Bookworm. Následující verze by již měla být postavena na Debianu 13 Trixie.

    Ladislav Hagara | Komentářů: 0
    včera 05:33 | Komunita

    Richard Stallman dnes v Liberci přednáší o svobodném softwaru a svobodě v digitální společnosti. Od 16:30 v aule budovy G na Technické univerzitě v Liberci. V anglickém jazyce s automaticky generovanými českými titulky. Vstup je zdarma i pro širokou veřejnost.

    Ladislav Hagara | Komentářů: 13
    včera 03:55 | Komunita

    sudo-rs, tj. sudo a su přepsáné do programovacího jazyka Rust, nahradí v Ubuntu 25.10 klasické sudo. V plánu je také přechod od klasických coreutils k uutils coreutils napsaných v Rustu.

    Ladislav Hagara | Komentářů: 0
    6.5. 22:11 | Nasazení Linuxu

    Fedora se stala oficiální distribucí WSL (Windows Subsystem for Linux).

    Ladislav Hagara | Komentářů: 2
    6.5. 13:22 | IT novinky

    Společnost IBM představila server IBM LinuxONE Emperor 5 poháněný procesorem IBM Telum II.

    Ladislav Hagara | Komentářů: 1
    6.5. 04:55 | Nová verze

    Byla vydána verze 4.0 multiplatformního integrovaného vývojového prostředí (IDE) pro rychlý vývoj aplikaci (RAD) ve Free Pascalu Lazarus (Wikipedie). Přehled novinek v poznámkách k vydání. Využíván je Free Pascal Compiler (FPC) 3.2.2.

    Ladislav Hagara | Komentářů: 1
    6.5. 00:33 | Komunita

    Podpora Windows 10 končí 14. října 2025. Připravovaná kampaň Konec desítek (End of 10) může uživatelům pomoci s přechodem na Linux.

    Ladislav Hagara | Komentářů: 32
    Jaký filesystém primárně používáte?
     (57%)
     (1%)
     (8%)
     (22%)
     (4%)
     (2%)
     (3%)
     (1%)
     (1%)
     (3%)
    Celkem 549 hlasů
     Komentářů: 25, poslední včera 20:12
    Rozcestník

    Dotaz: Linux - Vlakna

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

    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: 63 | 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: 63 | 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.