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 19:22 | IT novinky

    Ministerstvo financí ve spolupráci s finanční správou dnes představilo beta verzi aplikace využívající umělou inteligenci pro předvyplnění daňového přiznání. Není třeba přepisovat údaje z různých potvrzení, ani hledat správné řádky, kam údaje napsat. Stačí nahrát dokumenty a využít AI.

    Ladislav Hagara | Komentářů: 6
    včera 18:33 | Zajímavý projekt

    Výrobce počítačových periferií Keychron zveřejnil repozitář se schématy šasi klávesnic a myší. Licence je restriktivní, zakazuje většinu komerčních užití a v podstatě jsou tak data vhodná pouze pro výukové účely, hlášení a opravy chyb, případně výrobu vlastního příslušenství.

    |🇵🇸 | Komentářů: 0
    včera 18:22 | Nová verze

    Správce balíčků APT, používaný v Debianu a odvozených distribucích, byl vydán ve verzi 3.2 (seznam změn). Mezi novinkami figurují nové příkazy pro práci s historií, včetně vracení transakcí.

    |🇵🇸 | Komentářů: 0
    včera 14:33 | IT novinky

    Společnost Anthropic oznámila Projekt Glasswing a s ní související AI model Claude Mythos Preview. Jedná se o iniciativu zaměřenou na kybernetickou bezpečnost, do které se zapojily velké technologické společnosti Amazon Web Services, Anthropic, Apple, Broadcom, Cisco, CrowdStrike, Google, JPMorganChase, Linux Foundation, Microsoft, NVIDIA a Palo Alto Networks. Anthropic věří, že nový AI model Claude Mythos Preview dokáže

    … více »
    Ladislav Hagara | Komentářů: 1
    včera 13:55 | Zajímavý software

    Firma Ojective Development vydala svůj nástroj pro monitorování a řízení odchozích síťových připojení Little Snitch i pro operační systém Linux. Linuxová verze se skládá ze tří komponent: eBPF program pro zachytávání provozu a webové rozhraní jsou uvolněny pod GNU GPLv2 a dostupné na GitHubu (převážně Rust a JavaScript), jádro backendu je proprietární pod vlastní licencí, nicméně zdarma k použití a redistribuci (cena přitom normálně … více »

    » FIDESZ🧡! « | Komentářů: 0
    8.4. 18:44 | IT novinky

    Vojenské zpravodajství (VZ) se v březnu zapojilo do mezinárodní operace proti aktivitám hackerské skupiny APT28, která je spojovaná s ruskou vojenskou zpravodajskou službou GRU a která přes slabě zabezpečené routery prováděla kybernetické útoky na státní a další organizace v ČR i zahraničí. Operaci vedl americký Federální úřad pro vyšetřování (FBI) a jejím cílem bylo odebrat útočníkům přístup k napadeným zařízením a ty následně … více »

    Ladislav Hagara | Komentářů: 23
    8.4. 16:44 | IT novinky

    Tvůrcem nejpopulárnější kryptoměny bitcoin, který se skrývá za pseudonymem Satoši Nakamoto (Satoshi Nakamoto), je britský kryptograf Adam Back. Na základě vlastní investigativní práce to tvrdí americký deník The New York Times (NYT). Několik indicií podle autorů jasně ukazuje na to, že Back a Nakamoto jsou stejný člověk. Jde mimo jiné o podobný odborný a osobnostní profil či totožné chyby a manýry v psaném projevu.

    Ladislav Hagara | Komentářů: 11
    8.4. 14:44 | Nová verze

    Google Chrome 147 byl prohlášen za stabilní. Nejnovější stabilní verze 147.0.7727.55 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Vylepšeny byly také nástroje pro vývojáře. Přehled novinek v Chrome DevTools 145 až 147 také na YouTube.

    Ladislav Hagara | Komentářů: 0
    8.4. 12:44 | Nová verze

    Vývojáři z Laboratoří CZ.NIC vydali nové verze aplikací Datovka (Datovka 4.29.0, Mobilní Datovka 2.6.2). V případě desktopové verze přibyly možnosti projít všechny uložené zprávy, zkontrolovat časy expirací časových razítek a přerazítkovat datové zprávy, které lze v ISDS přerazítkovat. Novinkou je také možnost vytahovat myší ze seznamu ZFO soubory datových zpráv, tento úkon jde udělat i pomocí tlačítek Ctrl+C. Nová verze Mobilní Datovky přináší jen drobné úpravy.

    VSladek | Komentářů: 1
    7.4. 21:55 | Nová verze

    MicroPython (Wikipedie), tj. implementace Pythonu 3 optimalizovaná pro jednočipové počítače, byl vydán ve verzi 1.28.0. Z novinek lze vypíchnout novou třídu machine.CAN.

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (14%)
     (7%)
     (1%)
     (12%)
     (30%)
     (3%)
     (6%)
     (2%)
     (14%)
     (23%)
    Celkem 1249 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník

    Dotaz: Sockets & multithreading C++

    11.2.2011 19:59 Filgron
    Sockets & multithreading C++
    Přečteno: 711×

    Zdravím zdejší guru,

     

    v nedávné době jsem se začal zabývat a zajímat o používání socketů v C++ a tvorbou jednoduchých client/server aplikací. Postoupil jsem k problému, kdy chci řešit modelovou situaci:

    Existuje server, který periodicky načítá informace z blíže nespecifikovaného zdroje a ukládá si je do mezipaměti (pro zjednodušení řekněme soubor), tento server bude ,,poslouchat" na síti a bude obsluhovat klienty (klient se buďto pouze připojí, zažádá o informace z mezipaměti a hned se odpojí, nebo zůstane na kafe a bude si se serverem vyměňovat lichotky delší dobu). Klientů může být v jedné chvíli připojeno více, ale taky může být jen jeden a nebo o kafe v tuto chvíli nemá zájem nikdo.

    Zvažují vhodnou implementaci, zda-li to pojat jako více-vláknovou aplikaci, kdy jedno vlákno se stará o ukládání dat do mezipaměti, další o správu socketů s tím, že pro každého klienta by existovalo zvláštní vlákno, které by mu čaj naservírovalo.

    Druhou možností, co mne napadá je využití neblokovaného režimu socketů a selectu.

     

    Rád bych se Vás zeptal, který způsob je vhodnější, popř. pokud by Vás napadla jakákoliv jiná možnost, byl bych za ni velice rád)

     

    Ještě maličkost, ohledně více-vláknových aplikací bych Vás chtěl poprosit o radu, jakou knihovnu při nich eventuálně použít s tím, aby případná migrace mezi operačními systémy byla co nejméně bolestná (myšlen Tux a Win). Předem děkuju za Váš čas a případné kopance)

    Odpovědi

    11.2.2011 22:02 Messa | skóre: 39 | blog: Messa
    Rozbalit Rozbalit vše Re: Sockets & multithreading C++
    Pokud to má mít vysoký výkon nebo to má obsluhovat mnoho najednou připojených klientů, pak je nejlepším řešením epoll, select apod. Jinak si to můžeš naprogramovat, jak chceš :)

    Řešení pomocí vláken - tedy jedno vlákno na jednoho připojeného klienta - je řekl bych oblíbené, protože komunikace s klientem se pak snadno programuje. S vlákny mohou být problémy - žerou prostředky (paměť, také context switch není nejlevnější), špatně se ladí, mohou vznikat opravdu ošklivé chyby při špatné synchronizaci vláken. Tisíce vláken vedle sebe asi není ideální stav.

    Řešení pomocí selectu, epollu apod. je výkonnější, ale implementace takového serveru je o něco těžší.

    Je možná i kombinace - spojení, na kterých se zrovna nic neděje, mohou odpočívat v selectu/epollu, když ale něco přijde, může se o ně začít starat pro ně vyhrazené vlákno.

    Selectování/epollování rozdělit do více procesů, aby nebylo příliš spojení na jeden proces - počet otevřených deskriptorů je defaultně omezen tuším na 1024, dá se to zvýšit, ale AFAIK zase ne o moc.

    Jenom bych chtěl upozornit, že při selectování nemusejí být sokety v neblokujícím režimu :) Ten je zcela nutně potřeba snad až u edge-triggered epollu.

    Jestli je to vážně míněný projekt, je dobré přemýšlet i o bezpečnosti - o tom, jakým způsobem by útočník mohl server znepřístupnit nebo shodit, např. příliš velkým počtem spojení s napůl odeslaným požadavkem.

    11.2.2011 23:14 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: Sockets & multithreading C++
    Pokud to má mít vysoký výkon nebo to má obsluhovat mnoho najednou připojených klientů, pak je nejlepším řešením epoll, select apod.

    Jen za předpokladu, že vygenerování odpovědi je velmi rychlé a nenáročné. Jinak je tato varianta dost nešťastná.

    Řešení pomocí vláken - tedy jedno vlákno na jednoho připojeného klienta - je řekl bych oblíbené, protože komunikace s klientem se pak snadno programuje.

    Spíš bych řekl, že použití vláken - aspoň u linuxových aplikací - moc populární není a stále výrazně převažuje používání samostatných procesů. Kromě již zmíněného k tomu asi přispěla i skutečnost, že vlastně až s jádry 2.6 (OK, u Red Hatu o chloupek dřív) přišla rozumně použitelná implementace POSIX threads.

    12.2.2011 11:06 pht | skóre: 48 | blog: pht
    Rozbalit Rozbalit vše Re: Sockets & multithreading C++
    Vlákna. Jelikož máme více jádrové procesory, tak to do jistého počtu vláken poběží rychleji, než kdyby se obsluha požadavků dělala sériově. Pokud bude počet vláken najednou extrémně vysoký, můžete začít vlákna poolovat.
    jakou knihovnu při nich eventuálně použít s tím, aby případná migrace mezi operačními systémy byla co nejméně bolestná
    Boost.
    In Ada the typical infinite loop would normally be terminated by detonation.
    12.2.2011 12:41 dad
    Rozbalit Rozbalit vše Re: Sockets & multithreading C++
    Threads are evil. Avoid them. (D.Hipp, sqlite)

    http://www.eecs.berkeley.edu/Pubs/TechRpts/2006/EECS-2006-1.pdf
    12.2.2011 13:55 Sten
    Rozbalit Rozbalit vše Re: Sockets & multithreading C++
    Doporučuji si nastudovat řešení nginxu, lépe už to nejde :-) (je to kombinace vláken a epollu)

    Boost je multiplatformní. Umí thready (Boost::Thread) i sockety (Boost::ASIO).
    12.2.2011 22:02 Filgron
    Rozbalit Rozbalit vše Re: Sockets & multithreading C++

    Děkuji všem za názory/připomínky, po lehkém zvážení jsem se rozhodl započít vývoj v knihovně Qt (kterou aspoň částečně již znám), výhodu vidím v tom, že víceméně na jakoukoliv funkcionalitu (např. parsování XML) existují knihovny a také samozřejmě využití signálů a slotů + víceméně bezproblémová portace na Win.

    Prozatimní poupravený návrh počítá s tím, že bude existovat jedno vlákno (které bude načítat informace z externího zdroje do mezipaměti v loopu, signálem je bude zasílat hlavní třídě, popř. bude od hlavní třídy očekávat instrukce (čtené slotem a přidávané do fronty, která se provede při každém průchodu cyklem)

    Ohledně připojování klientů, zatím stále váhám, jestli použít QThreadPool, kde by každý klient měl vlastní vlákno (neočekává se velký počet klientů , max 5 současně), nebo použít select (ač u něj nevím, jak v Qt).

    K další otázce, projekt je zatím myšlen pouze pro ,,studijní" účely, samozřejmě při ,,reálném" nasazení by jej bylo třeba zabezpečit.

    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.