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 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ářů: 0
    dnes 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ářů: 1
    dnes 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
    dnes 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ářů: 5
    včera 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ářů: 2
    včera 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
    včera 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
    včera 14:00 | Upozornění

    Cloudflare, tj. společnost poskytující "cloudové služby, které zajišťují bezpečnost, výkon a spolehlivost internetových aplikací", má výpadek.

    Ladislav Hagara | Komentářů: 11
    včera 04:22 | Pozvánky

    Letos se uskuteční již 11. ročník soutěže v programování Kasiopea. Tato soutěž, (primárně) pro středoškoláky, nabízí skvělou příležitost procvičit logické myšlení a dozvědět se něco nového ze světa algoritmů – a to nejen pro zkušené programátory, ale i pro úplné začátečníky. Domácí kolo proběhne online od 22. 11. do 7. 12. 2025 a skládá se z 9 zajímavých úloh různé obtížnosti. Na výběru programovacího jazyka přitom nezáleží – úlohy jsou

    … více »
    SoutezKasiopea | Komentářů: 1
    včera 04:11 | Nová verze

    Byla vydána nová verze 2.52.0 distribuovaného systému správy verzí Git. Přispělo 94 vývojářů, z toho 33 nových. Přehled novinek v příspěvku na blogu GitHubu a v poznámkách k vydání.

    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 371 hlasů
     Komentářů: 17, poslední dnes 21:57
    Rozcestník

    Dotaz: meziprocesní komunikace

    31.1.2009 22:42 Jan Honza
    meziprocesní komunikace
    Přečteno: 329×

    Ahoj,
    na Ubuntu mám spuštěné dva nezávislé procesy: "Master" (skript v Perlu) a "Slave" (Céčko). V případě že "Slave" zachytí přerušení měl by o tom odeslat zprávu procesu "Master". Bohužel, protože
    procesy jsou nezávislé nelze pro komunikaci použít běžné roury. Prý lze použít roury přes
    FIFO soubory. Nebo je rozumnější použít sokety (server - klient) ?? Nebo existuje ještě
    další, elegantnější řešení?
     

    Odpovědi

    31.1.2009 23:52 l4m4
    Rozbalit Rozbalit vše Re: meziprocesní komunikace
    Nezávislé znamená, že mezi nimi není vztah rodič-potomek?
    
    Pak jsou v zásadě možnosti (v náhodném pořadí):
    - pojmenované roury (viz mkfifo)
    - SysV IPC (viz např. msgget nebo i shmget)
    - POSIX IPC (viz např. mq_open nebo i shm_open)
    - již zmíněné sockety, pro lokální viz ,Unix domain sockets` v info libc
    
    Doporučovat nebudu nic, protože to záleží na situaci.  FIFO je asi
    nejjednodušší (v perlu viz POSIX::mkfifo), sokety nejjednodušší nejsou,
    ale umožní snáz přejít na připojování klientů z jiných počítačů.
    
    1.2.2009 12:39 Jan Honza
    Rozbalit Rozbalit vše Re: meziprocesní komunikace

    ješte jsem nyní uvažoval (po položení otázky: zda jsou procesy opravdu nezávislé)....

    V případě že bych z perlovského skriptu spustil pomocí "system" proces "Slave"...jednalo by se tím pádem o vztah rodič potomek? Dalo by se požít klasických rour?

     

     

    1.2.2009 17:28 alkoholik25
    Rozbalit Rozbalit vše Re: meziprocesní komunikace
    Ano. Pak se jednoduse budes moct pripojit na stdin/stdout/stderr techto procesu.
    Josef Kufner avatar 1.2.2009 18:11 Josef Kufner | skóre: 70
    Rozbalit Rozbalit vše Re: meziprocesní komunikace
    Pokud Slave je spuštěn Masterem, tak znáš jeho pid a můžeš Slave poslat třeba SIGHUP když Master končí. Pokud končí Slave, posílá se Masterovi SIGCHLD.

    Pokud máš mezi nimi nějaký komunikační kanál, třeba pár rour, tak s ukončením jednoho z nich dostaneš při čtení/zápisu EOF.

    Na jejich spojení nemusíš vytvářet pojmenované roury, stačí nepojmenované, které vytváří pipe. Nebo můžeš přesměrovat stdin+stdout a komunikovat po nich -- to je v mnoha případech nejlepší varianta, protože v kombinaci s textovým komunikačním protokolem se to velmi pohodlně ladí.

    No a pokud ty dva procesy nemají společného vůbec nic, použij prostě unix sockety. Je to výrazně pohodlnější než roura, je to obousměrné a hlavně je to stavěné na více klientů. S rourama je to na první pohled jednodušší, ale to co sockety už mají vyřešené si musíš řešit sám. Navíc změna na tcp socket je pak velmi jednoduchá.

    Další celkem hezkou možností je použití D-Bus. To se ti pak třeba Master může spouštět na požádání automaticky.
    Hello world ! Segmentation fault (core dumped)

    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.