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í
×
    včera 17:22 | IT novinky

    Josef Průša oznámil zveřejnění kompletních CAD souborů rámů tiskáren Prusa CORE One a CORE One L. Nejsou vydány pod obecnou veřejnou licenci GNU ani Creative Commons ale pod novou licencí OCL neboli Open Community License. Ta nepovoluje prodávat kompletní tiskárny či remixy založené na těchto zdrojích.

    Ladislav Hagara | Komentářů: 2
    včera 17:00 | Komunita

    Nový CEO Mozilla Corporation Anthony Enzor-DeMeo tento týden prohlásil, že by se Firefox měl vyvinout v moderní AI prohlížeč. Po bouřlivých diskusích na redditu ujistil, že v nastavení Firefoxu bude existovat volba pro zakázání všech AI funkcí.

    Ladislav Hagara | Komentářů: 0
    včera 10:11 | IT novinky

    V pořadí šestou knihou autora Martina Malého, která vychází v Edici CZ.NIC, správce české národní domény, je titul Kity, bity, neurony. Kniha s podtitulem Moderní technologie pro hobby elektroniku přináší ucelený pohled na svět současných technologií a jejich praktické využití v domácích elektronických projektech. Tento knižní průvodce je ideální pro každého, kdo se chce podívat na současné trendy v oblasti hobby elektroniky, od

    … více »
    Ladislav Hagara | Komentářů: 1
    včera 03:11 | Komunita

    Linux Foundation zveřejnila Výroční zprávu za rok 2025 (pdf). Příjmy Linux Foundation byly 311 miliónů dolarů. Výdaje 285 miliónů dolarů. Na podporu linuxového jádra (Linux Kernel Project) šlo 8,4 miliónu dolarů. Linux Foundation podporuje téměř 1 500 open source projektů.

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

    Jean-Baptiste Mardelle se v příspěvku na blogu rozepsal o novinkám v nejnovější verzi 25.12.0 editoru videa Kdenlive (Wikipedie). Ke stažení také na Flathubu.

    Ladislav Hagara | Komentářů: 0
    včera 02:00 | Nová verze

    OpenZFS (Wikipedie), tj. implementace souborového systému ZFS pro Linux a FreeBSD, byl vydán ve verzi 2.4.0.

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

    Kriminalisté z NCTEKK společně s českými i zahraničními kolegy objasnili mimořádně rozsáhlou trestnou činnost z oblasti kybernetické kriminality. V rámci operací OCTOPUS a CONNECT ukončili činnost čtyř call center na Ukrajině. V prvním případě se jednalo o podvodné investice, v případě druhém o podvodné telefonáty, při kterých se zločinci vydávali za policisty a pod legendou napadeného bankovního účtu okrádali své oběti o vysoké finanční částky.

    Ladislav Hagara | Komentářů: 4
    18.12. 14:44 | IT novinky

    Na lepší pokrytí mobilním signálem a dostupnější mobilní internet se mohou těšit cestující v Pendolinech, railjetech a InterPanterech Českých drah. Konsorcium firem ČD - Telematika a.s. a Kontron Transportation s.r.o. dokončilo instalaci 5G opakovačů mobilního signálu do jednotek Pendolino a InterPanter. Tento krok navazuje na zavedení této technologie v jednotkách Railjet z letošního jara.

    Ladislav Hagara | Komentářů: 6
    18.12. 12:22 | Bezpečnostní upozornění

    Rozšíření webového prohlížeče Urban VPN Proxy a další rozšíření od stejného vydavatele (např. 1ClickVPN Proxy, Urban Browser Guard či Urban Ad Blocker) od července 2025 skrytě zachytávají a odesílají celé konverzace uživatelů s AI nástroji (včetně ChatGPT, Claude, Gemini, Copilot aj.), a to nezávisle na tom, zda je VPN aktivní. Sběr probíhá bez možnosti jej uživatelsky vypnout a zahrnuje plný obsah dotazů a odpovědí, metadata relací i

    … více »
    Ladislav Hagara | Komentářů: 5
    18.12. 05:22 | Zajímavý software

    QStudio, tj. nástroj pro práci s SQL podporující více než 30 databází (MySQL, PostgreSQL, DuckDB, QuestDB, kdb+, …), se stal s vydáním verze 5.0 open source. Zdrojové kódy jsou k dispozici na GitHubu pod licencí Apache 2.0.

    Ladislav Hagara | Komentářů: 6
    Kdo vám letos nadělí dárek?
     (8%)
     (0%)
     (0%)
     (0%)
     (8%)
     (8%)
     (23%)
     (31%)
     (23%)
    Celkem 13 hlasů
     Komentářů: 10, poslední včera 12:54
    Rozcestník

    Dotaz: fork() a broadcasting vsem klientum

    3.3.2009 19:30 Peter Silon
    fork() a broadcasting vsem klientum
    Přečteno: 281×

    Zdravim,

    Mam TCP server a pre kazde nove spojeni vytvaram novy proces - fork. Potrebuju mit ale moznost zasielania sprav vsem pripojenym klientum. Ako pri pouziti fork-u zistim pocet klientu a vsetky sockety na ktore mam boradcastovat ?

    Napadlo ma reseni, kde si pred kazdym frok-om ulozim socket descriptor

    if ((csd = accept(sd, (struct sockaddr *)&cliaddr, &clilen)) < 0) {
                if (errno == EINTR)
                    continue;
                else
                    printError(ERR_ACCEPT, sd);
    }

    bnd_sock.push_back(csd);
      if ((pid = fork()) == 0) ....

    alebo je lepsi pouzit select() ?

    Odpovědi

    4.3.2009 09:00 rastos | skóre: 63 | blog: rastos
    Rozbalit Rozbalit vše Re: fork() a broadcasting vsem klientum
    Potomok ma svoj vlastný pamäťový priestor, do ktorého rodič nevidí. Rodič sa tak nanajvýš dozvie PID potomka. Buď použiješ thready, alebo musíš vymyslieť nejakú formu medziprocesovej komunikácie medzi rodičom a deťmi.
    10.3.2009 16:58 Messa | skóre: 39 | blog: Messa
    Rozbalit Rozbalit vše Re: fork() a broadcasting vsem klientum
    Buď místo forkací architektury použiješ select, jak níže naznačuješ, a "broadcastování" budeš dělat jednoduššeji pomocí nějaké datové struktury, nebo, pokud chceš zůstat u forku, budeš muset zajistit způsob, jak předat zprávu dětskému procesu, aby on sám mohl tu zprávu odeslat klientovi. Na to je na webu plno tutorialů. Půjde to přes System V IPC, přes roury nebo sokety nebo i přes nějaké sdílené paměti.

    Možná si myslíš, že při acceptu si uložíš fd klienta do nějakého vektoru (jak asi ukazuješ v tom kusu kódu), forkneš proces pro obsluhování toho spojení a pak zprávy určené všem klientům prostě napereš to těch file deksriptů, co sis zapamatoval. Jenže takhle jednoduše to nedělej, protože klient může mít pomalejší linku (nebo může nastat jedna z tisíce dalších náhodných situací), obsluhovací podproces může mít právě rozposílaný jeden příkaz, a doprostřed toho bys poslal tu "broadcastovou" zprávu - tím bys mohl narušit protokol ("rozbít" spojení). Muselo by tam být přinejmenším nějaké zamykání, ale to by mohlo být bezpečnostní riziko (server by mohl zamrznout, třeba když si nějaký klient nechá poslat schválně jen půl zprávy).

    Kromě posílání zpráv podprocesům budou na webu určitě i ukázky nějakých jednoduchých irc-like chatů, řešících v podstatě kompletně tvůj problém. Dává se to ve školách jako domácí/samostatné úkoly.
    10.3.2009 18:22 faha
    Rozbalit Rozbalit vše Re: fork() a broadcasting vsem klientum

    Jak pise kolega, pri forkovani vznikne uplne novy proces, ktery nema s rodicem prilis mnoho spolecneho, kompletne oddeleny pametovy prostor, sance samozdrejme je s nim komunikovat jsou, jiz zde zminovany IPC.

    Sdilena pamet mezi vice procesy patri taky do IPC, standartne se IPC deli na tyto kategorie.

    - zpravy - doruceni

    - synchronizace (tusim ze do toho spadaji veci kolem race condition semafory[mutexy atd])

    - sdilena pamet

    - vzdalene volani procedu (RPC)

    O tom, ze se IPC pouziva vas muze presvedcit napr. utilitka ipcs, ukazuje vyuziti IPC mechanismu v systemu.

    ------ Segmenty sdílené paměti --------
    klíč     shmid      vlastník  práva     bajty      nattch     stav
    0x0056a4d5 25362433       660        384        3
    0x0056a4d6 40304642       660        131072     2
    0x00000000 589827           777        393216     3          cíl
    0x00000000 1114116         644        110592     3          cíl
    0x00000000 1310725        600        393216     2          cíl
    0x00000000 1441798        600        393216     2          cíl
    0x00000000 5210119        600        393216     2          cíl
    0x00000000 5242888        600        393216     2          cíl
    0x00000000 47218700      776        1382400    0
    0x00000000 47251469      776        1382400    0
    0x00000000 47284238      776        1382400    0
    0x00000000 47317007      776        1382400    0
    0x00000000 47349776       776        1382400    0
    0x00000000 47382545      776        1382400    0
    0x00000000 47415314      776        1382400    0
    0x00000000 47448083      776        1382400    0

    ------ Pole semaforů --------
    klíč     semid      vlastník  práva     nsems
    0x0056a4d5 360450         660        1

    ------ Fronty zpráv --------
    klíč     msqid      vlastník  práva     užité bajty zprávy
     

    Vlastnik jsem zamerne smazal.

    Select neni vubec spatny napad podle me, taky je zde moznost misto fork to predelat do vlaken, vlakna natrpi nevyhodou oddeleneho pametoveho prostoru poku me pamet neklame.

    Otazka je kolik tech klientu pocitate ze budeme mit pripojenych online, ono schovavat si kazdy deskriptor neni zrovna med, spise bych sel tou cestou rodicovsky proces informuje o to,ze je treba neco udelat (neco jako priznak/vlajka) a procesy obsluhujici klienty se podle toho zaridit, nejspise samy presne vedi kdyz se jim to hodi zpravovat.

    Pak tu mame jeste roury a "pojmenovane" roury, k tomu vam nic nereknu, pouzil jsem to asi 2x v zivote, jo funguje to, hojne se to i pouziva viz. nar konstrukce tar | gzip.

    Pokud nechcete nic louskat v anglictine nebo je Vam proti srsti zkuste si procist serial na rootu, zejmena od 20kap. nahoru nebo tak nejak, obcas stroji za to i komentare. Me v zacatkach velmi pomohlo kniha Linux Zaciname programovat nez mi ji nejaky paznecht ukradl vcetne batohu, knizko ooo jak mi chybis. Koupil jsem si tedy druhy dil taky neni spatny.

    http://www.root.cz/serialy/programovani-pod-linuxem-pro-vsechny/

    Drzim palec, developery potrebuje jako sul.

    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.