V Amsterdamu probíhá Open Source Summit Europe. Organizace Linux Foundation představuje novinky. Pod svá křídla převzala open source dokumentovou databázi DocumentDB.
Přesně před 34 lety, 25. srpna 1991, oznámil Linus Benedict Torvalds v diskusní skupině comp.os.minix, že vyvíjí (svobodný) operační systém (jako koníček, nebude tak velký a profesionální jako GNU) pro klony 386 (486), že začal v dubnu a během několika měsíců by mohl mít něco použitelného.
86Box, tj. emulátor retro počítačů založených na x86, byl vydán ve verzi 5.0. S integrovaným správcem VM. Na GitHubu jsou vedle zdrojových kódů ke stažení také připravené balíčky ve formátu AppImage.
Vláda Spojených států získala desetiprocentní podíl v americkém výrobci čipů Intel. Oznámili to podle agentur americký prezident Donald Trump a ministr obchodu Howard Lutnick. Společnost Intel uvedla, že výměnou za desetiprocentní podíl obdrží státní dotace v hodnotě 8,9 miliardy dolarů (zhruba 186 miliard Kč). Částka podle Intelu zahrnuje dříve přislíbené subvence 5,7 miliardy dolarů z programu CHIPS na podporu výroby čipů v USA,
… více »Organizace Apache Software Foundation (ASF) vydala verzi 27 integrovaného vývojového prostředí a vývojové platformy napsané v Javě NetBeans (Wikipedie). Přehled novinek na GitHubu. Instalovat lze také ze Snapcraftu a Flathubu.
Knihovna FFmpeg byla vydána ve verzi 8.0 „Huffman“. Přibyla mj. podpora hardwarově akcelerovaného kódování s využitím API Vulcan, viz seznam změn.
Národní úřad pro kybernetickou a informační bezpečnost (NÚKIB) vydal Zprávu o stavu kybernetické bezpečnosti ČR za rok 2024 (pdf). V loňském roce NÚKIB evidoval dosud nejvíce kybernetických bezpečnostních incidentů s celkovým počtem 268. Oproti roku 2023 se však jedná pouze o drobný nárůst a závažnost dopadů evidovaných incidentů klesá již třetím rokem v řadě. V minulém roce NÚKIB evidoval pouze jeden velmi významný incident a významných incidentů bylo zaznamenáno 18, což oproti roku 2023 představuje pokles o více než polovinu.
Byl publikován aktuální přehled vývoje renderovacího jádra webového prohlížeče Servo (Wikipedie). Servo mimo jiné nově zvládne animované obrázky APNG a WebP.
Na chytré telefony a počítačové tablety v Rusku bude od začátku příštího měsíce povinné předinstalovávat státem podporovanou komunikační aplikaci MAX, která konkuruje aplikaci WhatsApp americké společnosti Meta Platforms. Oznámila to dnes ruská vláda. Ta by podle kritiků mohla aplikaci MAX používat ke sledování uživatelů. Ruská státní média obvinění ze špehování pomocí aplikace MAX popírají. Tvrdí, že MAX má méně oprávnění k přístupu k údajům o uživatelích než konkurenční aplikace WhatsApp a Telegram.
Společnost PINE64 stojící za telefony PinePhone nebo notebooky Pinebook publikovala na svém blogu srpnový souhrn novinek. Kvůli nedostatečnému zájmu byla ukončena výroba telefonů PinePhone Pro.
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)
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.
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.
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.
Tiskni
Sdílej: