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:44 | IT novinky

    Evropská komise zahájila tři vyšetřování týkající se cloudových platforem Amazon Web Services (AWS) a Microsoft Azure. Evropská exekutiva, která plní také funkci unijního antimonopolního orgánu, chce mimo jiné určit, zda jsou americké společnosti Microsoft a Amazon v cloudových službách takzvanými gatekeepery, tedy hráči, kteří významně ovlivňují provoz internetu a musí dle nařízení o digitálních trzích (DMA) na společném trhu

    … více »
    Ladislav Hagara | Komentářů: 3
    dnes 12:33 | IT novinky

    Společnost Meta Platforms vyhrála ostře sledovaný spor o akvizici sítě pro sdílení fotografií Instagram a komunikační aplikace WhatsApp. Podle amerického soudu firma jejich převzetím neporušila antimonopolní zákon, protože si tak nemonopolizovala trh sociálních sítí. Žalobu na Metu podala před pěti lety americká Federální obchodní komise (FTC). FTC argumentovala, že Meta, tehdy známá jako Facebook, koupila tyto dvě společnosti v letech 2012 a 2014 proto, aby s nimi nemusela soutěžit.

    Ladislav Hagara | Komentářů: 0
    dnes 05:11 | IT novinky

    Home Assistant včera představil svůj nejnovější oficiální hardware: Home Assistant Connect ZBT-2 pro připojení zařízení na sítích Zigbee nebo Thread.

    Ladislav Hagara | Komentářů: 5
    včera 19:44 | Nová verze

    Byla vydána verze 9.1 open source virtualizační platformy Proxmox VE (Proxmox Virtual Environment, Wikipedie) založené na Debianu. Přehled novinek v poznámkách k vydání a informačním videu.

    Ladislav Hagara | Komentářů: 1
    včera 17:44 | IT novinky

    Byl aktualizován seznam 500 nejvýkonnějších superpočítačů na světě TOP500. Nejvýkonnějším superpočítačem zůstává El Capitan od HPE (Cray) s výkonem 1,809 exaFLOPS. Druhý Frontier má výkon 1,353 exaFLOPS. Třetí Aurora má výkon 1,012 exaFLOPS. Nejvýkonnější superpočítač v Evropě JUPITER Booster s výkonem 1,000 exaFLOPS je na čtvrtém místě. Nejvýkonnější český superpočítač C24 klesl na 192. místo. Karolina, GPU partition klesla na 224. místo a Karolina, CPU partition na 450. místo. Další přehledy a statistiky na stránkách projektu.

    Ladislav Hagara | Komentářů: 15
    včera 17:22 | IT novinky

    Microsoft představil Azure Cobalt 200, tj. svůj vlastní SoC (System-on-Chip) postavený na ARM a optimalizovaný pro cloud.

    Ladislav Hagara | Komentářů: 0
    včera 12:00 | IT novinky

    Co způsobilo včerejší nejhorší výpadek Cloudflare od roku 2019? Nebyl to kybernetický útok. Vše začalo změnou oprávnění v jednom z databázových systémů a pokračovalo vygenerováním problém způsobujícího konfiguračního souboru a jeho distribucí na všechny počítače Cloudflare. Podrobně v příspěvku na blogu Cloudflare.

    Ladislav Hagara | Komentářů: 3
    18.11. 23:44 | Nová verze

    Byla vydána (Mastodon, 𝕏) první RC verze GIMPu 3.2. Přehled novinek v oznámení o vydání. Podrobně v souboru NEWS na GitLabu.

    Ladislav Hagara | Komentářů: 0
    18.11. 23:22 | Komunita

    Eugen Rochko, zakladatel Mastodonu, tj. sociální sítě, která není na prodej, oznámil, že po téměř 10 letech odstupuje z pozice CEO a převádí vlastnictví ochranné známky a dalších aktiv na neziskovou organizaci Mastodon.

    Ladislav Hagara | Komentářů: 0
    18.11. 19:44 | Nová verze

    Byla vydána nová major verze 5.0 svobodného 3D softwaru Blender. Přehled novinek i s náhledy a videi v obsáhlých poznámkách k vydání. Videopředstavení na YouTube.

    Ladislav Hagara | Komentářů: 0
    Jaké řešení používáte k vývoji / práci?
     (35%)
     (46%)
     (19%)
     (18%)
     (23%)
     (15%)
     (23%)
     (15%)
     (17%)
    Celkem 373 hlasů
     Komentářů: 17, poslední včera 21:57
    Rozcestník

    Dotaz: Spristupnenie pamatovych struktur potomkovi

    16.10.2008 12:37 xsustek | skóre: 6
    Spristupnenie pamatovych struktur potomkovi
    Přečteno: 249×
    Zdravim,

    mam takyto problem. Su dva procesy: rodic a potomok. Rodic sa periodicky budi a ziskava informacie. Potomok caka na UDP a pri dotaze musi nahliadnut do rodicovskych pamatovych strukur resp. musi od neho ziskat nejake info resp. citat jeho pamat.

    Robim to v C-ku a v Linuxe. Nechcem k tomu pouzit vlakna. Zaujima ma ake su moznosti. Nedalo by sa to nejakou rurou? Alebo niecim inym?

    Dakujem

    Odpovědi

    16.10.2008 13:51 Jirka P
    Rozbalit Rozbalit vše Re: Spristupnenie pamatovych struktur potomkovi
    Ta otázka je dost obsáhlá... Dala by se použít roura, unix-domain socket, sdílená paměť, společný soubor... cokoli.
    16.10.2008 14:00 xsustek | skóre: 6
    Rozbalit Rozbalit vše Re: Spristupnenie pamatovych struktur potomkovi
    Co si myslite, ze by bolo najednoduchsie.

    Rodic bude mat staticky alokovanu pamat. Napr. 5 struktur.

    Chcel by som sa ale vyhnut nejakemu binarnemu citaniu. (nieco v tom zmysle, ze by citajuci cital prud dat a nejak ich musel zozpoznavat. Tak isto by som sa chcel vyhnut tomu, aby sa rodic musel prebudit a poskytnut data.

    Viem, ze je to dost nejasne sam v tom nemam uplne jasno. :(

    16.10.2008 14:54 happy barney | skóre: 34 | blog: dont_worry_be_happy
    Rozbalit Rozbalit vše Re: Spristupnenie pamatovych struktur potomkovi
    v tomto prípade by som osobne použil zdieľanú pamäť
    16.10.2008 15:59 xsustek | skóre: 6
    Rozbalit Rozbalit vše Re: Spristupnenie pamatovych struktur potomkovi
    Mohli by ste ma nejako nasmerovat. Su nejane systemove volanie v Linuxe pre to. Ako sa to oficialne vola, aby som si to mohol vyhladat na internete.
    16.10.2008 16:12 Messa | skóre: 39 | blog: Messa
    Rozbalit Rozbalit vše Re: Spristupnenie pamatovych struktur potomkovi
    Buď můžete použít mmap, který by měl přes fork krásně fungovat (man mmap), nebo řekl bych klasičtější System V IPC (viz man shmat).
    16.10.2008 16:07 Messa | skóre: 39 | blog: Messa
    Rozbalit Rozbalit vše Re: Spristupnenie pamatovych struktur potomkovi
    Buď sdílená paměť, nebo rodič po získání informací tyto "natlačí" do potomka, který si je zapamatuje, aby je mohl posílat přes UDP. (Což je v podstatě stejný přístup jako sdílená paměť.) To mi připadají jako jediné možnosti, pokud se chceš vyhnout probouzení rodiče pro poskytnutí dat. Pak by se dal použít ještě trochu úchylnější přístup, a to po získání dat rodičem potomka zabít a znovu forknout s novými daty.

    Jen bych upozornil, že přestože se nejedná o vlákna, při přístupu do sdílené paměti by se AFAIK měla použít nějaká synchronizace, např. mutexy (ty by ve sdílené paměti měly fungovat i mezi procesy).

    Nějak jsem nepochopil, že se chceš vyhnout binárnímu čtení. Číst musíš vždycky :-)
    16.10.2008 16:24 xsustek | skóre: 6
    Rozbalit Rozbalit vše Re: Spristupnenie pamatovych struktur potomkovi
    Nějak jsem nepochopil, že se chceš vyhnout binárnímu čtení.
    Myslel som to tak, ze tie struktury v pamati budem moct citat podobne ako by ich cital proces ktoremu patria. Napr. takto st_rec.name. A nemusel to citat ako nejaky prud dat, kde by som musel vediet kde jedna premenna konci a ina zaciana.

    Takze hovorite, ze zdielana pamat. Tak skusime.
    16.10.2008 16:26 xsustek | skóre: 6
    Rozbalit Rozbalit vše Re: Spristupnenie pamatovych struktur potomkovi
    nebo rodič po získání informací tyto "natlačí" do potomka, který si je zapamatuje
    mohli by ste toto konktretne specifikovat, ako by sa to dalo urobit? Musela by tam byt nejaka aktivita na strane potomka. resp. musel by data nejak spracovavat?
    16.10.2008 16:46 Messa | skóre: 39 | blog: Messa
    Rozbalit Rozbalit vše Re: Spristupnenie pamatovych struktur potomkovi
    Myslel jsem třeba rourou nebo prostě něčím, na co se v rodičovi zavolá write() a v potomkovi read() (nebo samozřejmě fwrite a fread). Přijatá data by se samozřejmě musela zpracovat, ale pokud se to udělá pěkně, nejsou s tím žádné potíže, protože ty data nemusí být multiplatformní (běží to na jednom stroji, že); fread(ptr, sizeof(*ptr), 1, stream); ptr->name není už tak hrozné. Akorát by se v potomkovi muselo zacházet s dvěma vstupy naráz (UDP a tahle roura), a to je trochu složitější - buď přes přes select() nebo neblokující režim. Sdílená paměť bude opravdu lepší řešení, pokud je možné ji použít.
    16.10.2008 17:38 Messa | skóre: 39 | blog: Messa
    Rozbalit Rozbalit vše Re: Spristupnenie pamatovych struktur potomkovi
    Příloha:
    Ještě zpět k těm mutexům - mutex se musí nastavit jako process-shared pomocí (pthread_mutexattr_setpshared(&attr, PTHREAD_PROCESS_SHARED). Do přílohy jsem kdyžtat sesmolil ukázkový program, který dělá zhruba to co xsustek chce (abych si vyzkoušel, že to co radím doopravdy funguje). Dost by mě zajímalo srovnání výkonu oproti jiné meziprocesové synchronizaci...
    16.10.2008 20:32 xsustek | skóre: 6
    Rozbalit Rozbalit vše Re: Spristupnenie pamatovych struktur potomkovi
    Za toto musim fakt podakovat. Este som to neskusal, uz je vecer :). Skusim to cez vikend pripadne odpisem. DIK
    16.10.2008 16:58 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: Spristupnenie pamatovych struktur potomkovi
    Nechcem k tomu pouzit vlakna.

    To je docela chyba, protože právě tohle je jedna z největších výhod threadů. Můžete sice použít sdílenou paměť, ale tím si nepomůžete, stejně budete muset řešit otázku synchronizace (např. pomocí semaforů).

    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.