Multimediální server a user space API PipeWire (Wikipedie) poskytující PulseAudio, JACK, ALSA a GStreamer rozhraní byl vydán ve verzi 1.6.0 (Bluesky). Přehled novinek na GitLabu.
UBports, nadace a komunita kolem Ubuntu pro telefony a tablety Ubuntu Touch, vydala Ubuntu Touch 24.04-1.2 a 20.04 OTA-12.
Byla vydána (Mastodon, 𝕏) nová stabilní verze 2.0 otevřeného operačního systému pro chytré hodinky AsteroidOS (Wikipedie). Přehled novinek v oznámení o vydání a na YouTube.
WoWee je open-source klient pro MMORPG hru World of Warcraft, kompatibilní se základní verzí a rozšířeními The Burning Crusade a Wrath of the Lich King. Klient je napsaný v C++ a využívá vlastní OpenGL renderer, pro provoz vyžaduje modely, grafiku, hudbu, zvuky a další assety z originální kopie hry od Blizzardu. Zdrojový kód je na GitHubu, dostupný pod licencí MIT.
Byl představen ICT Supply Chain Security Toolbox, společný nezávazný rámec EU pro posuzování a snižování kybernetických bezpečnostních rizik v ICT dodavatelských řetězcích. Toolbox identifikuje možné rizikové scénáře ovlivňující ICT dodavatelské řetězce a na jejich podkladě nabízí koordinovaná doporučení k hodnocení a mitigaci rizik. Doporučení se dotýkají mj. podpory multi-vendor strategií a snižování závislostí na vysoce
… více »Nizozemský ministr obrany Gijs Tuinman prohlásil, že je možné stíhací letouny F-35 'jailbreaknout stejně jako iPhony', tedy upravit jejich software bez souhlasu USA nebo spolupráce s výrobcem Lockheed Martin. Tento výrok zazněl v rozhovoru na BNR Nieuwsradio, kde Tuinman naznačil, že evropské země by mohly potřebovat větší nezávislost na americké technologii. Jak by bylo jailbreak možné technicky provést pan ministr nijak nespecifikoval, nicméně je známé, že izraelské letectvo ve svých modifikovaných stíhačkách F-35 používá vlastní software.
Nové číslo časopisu Raspberry Pi zdarma ke čtení: Raspberry Pi Official Magazine 162 (pdf).
Sdružení CZ.NIC, správce české národní domény, zveřejnilo Domain Report za rok 2025 s klíčovými daty o vývoji domény .CZ. Na konci roku 2025 bylo v registru české národní domény celkem 1 515 860 s koncovkou .CZ. Průměrně bylo měsíčně zaregistrováno 16 222 domén, přičemž nejvíce registrací proběhlo v lednu (18 722) a nejméně pak v červnu (14 559). Podíl domén zabezpečených pomocí technologie DNSSEC se po několika letech stagnace výrazně
… více »Google představil telefon Pixel 10a. S funkci Satelitní SOS, která vás spojí se záchrannými složkami i v místech bez signálu Wi-Fi nebo mobilní sítě. Cena telefonu je od 13 290 Kč.
Byl publikován přehled dění a novinek z vývoje Asahi Linuxu, tj. Linuxu pro Apple Silicon. Fedora 43 Asahi Remix s KDE Plasma už funguje na M3. Zatím ale bez GPU akcelerace. Vývojáře lze podpořit na Open Collective a GitHub Sponsors.
START TRANSACTION; CREATE TABLE tabulka (ID integer primary key) ENGINE=InnoDB; INSERT INTO tabulka (ID) VALUES (5); ROLLBACK;Podle předchozích zkušeností s PostgreSQL i SQLite měla tabulka zmizet. Nezmizela. Zůstala v ní uložena všechna data. Je to chyba nebo vlastnost MySQL 5.1.37? Mám někde chybu?
Řešení dotazu:
CREATE TABLE obsahuje i skrytý příkaz COMMIT, který transakci ukončí. No jo, MySQL...
CREATE TABLE nebo podobným příkazem je umístěn neviditelný COMMIT. Víc nic.
CREATE TABLE ukončil otevřenou transakci neviditelným příkazem COMMIT.
To znamená, že žádná transakce pak otevřena nebyla.
Příkaz INSERT proběhl ve vlastní lokální transakci.
Když není otevřena žádná transakce, ROLLBACK neudělá nic. Ani nehlásí chybu.
Obecně by to snad SQL databáze měla umět.V 90letech se vypravel v IT nasledujici vtip: 'Pouzivate uz take SQL standard?' '... a ktery z nich myslite?'
db2 => update command options using c off DB20000I Příkaz UPDATE COMMAND OPTIONS byl úspěšně dokončen. db2 => create table tabulka(id integer not null primary key) DB20000I Příkaz SQL byl úspěšně dokončen. db2 => insert into tabulka(id) values(5) DB20000I Příkaz SQL byl úspěšně dokončen. db2 => rollback DB20000I Příkaz SQL byl úspěšně dokončen. db2 => select * from tabulka SQL0204N Název "MAJITEL.TABULKA" není definován. SQLSTATE=42704 db2 =>V Oracle to nejde. Tam create table udela commit.
Na druhou stranu toto je dokumentované chování.
Ač nemohu být podezírán z přehnaných sympatií k MySQL, tohle bych jí nevyčítal:
1. Transakce (předpokládám) fungují i se zapnutým autocommitem, jen se to pak chová, jako byl každý příkaz v samostatné transakci. Ono je potřeba chápat, že hlavní smysl transakcí umožnit vrátit sérii příkazů, když uděláte chybu, ale řešit kolize mezi paralelně přistupujícími klienty a umožnit i v takovém prostředí udržet integritu dat a atomicitu operací. Je potřeba si uvědomit, že ani to, co navenek vypadá jako "jeden příkaz", není obecně atomická operace, která se buď celá provede nebo celá neprovede.
2. To by mi až tak nevadilo, víc mne děsí důsledek tohoto faktu: že se transakční zpracování může týkat jen některých tabulek v databázi. Na druhou stranu, je jen na vás, jestli této možnosti využijete. Svědčí to ale o tom, že u MySQL jsou transakce pořád brány jako jakýsi bonus navíc, ne jako základní princip fungování databáze.
3. Jiné databáze (aspoň některé) umožňují necommitovat automaticky DDL příkazy, ale ani tam se nedoporučuje této možnosti systematicky využívat. Relační databáze vesměs nejsou moc stavěné na časté změny struktury a stavět aplikaci na tom, že to bude fungovat, bych se nezdráhal označit za zásadní designovou chybu.
MyISAM částečně fungují. Když jsem otevřel transakci, vložil záznam a pak dal ROLLBACK, záznam zmizel. Zajímavé bylo, že mezitím ten záznam byl vidět z jiných vláken, takže je to skutečně jen částečné.
Pokud dotaz není uzavřen do transakce, měl by se obalit vlastní transakcí z důvodu zachování integrity. Pokud se mi tohle chování nelíbí, mám možnost si otevřít vlastní transakci a commitovat jak to zrovna potřebuji.
2. MySQL je zajímavá různými enginy. Překvapil mě běžně podporovaný engine Archive se svou transparentní kompresí. Na záznamy prohledávané %LIKE% se určitě hodí lépe než ty ostatní. MyISAM se zase hodí lépe na generování stránek, InnoDB na transakční zpracování, Memory na dočasné key->value tabulky.
Dokonce ten guláš může dohromady pěkně fungovat, zejména pokud vyberu pro každé použití ten správný engine. Popis zboží v e-shopu může být docela dobře v MyISAM, ale zpracování objednávek lépe sluší InnoDB. Transakční logy mohou být ukládány do Archive, editování rozpracované objednávky bude rychlejší v Memory.
Jenže, tohle nikdy nenastavíte správně.
MySQL jsem opustil po napsání této recenze dobré knihy MySQL optimalizace pro vysoký výkon.
Vysvětlím proč. Ty pluginy (engine) vypadají na první pohled jako fajn nápad. Tak jak jsi to popsal, to na papíře vypadá docela dobře. Jenže v praxi narazíš na chování typu:
- Při startu mysql serveru nenajel InnoDB (chyba v konfiguraci jeho parametrů). MySQL ovšem jede (start služby OK), do logu akorát napíše skip-innodb. Nic neindikuje chybu a co hůř, všechno funguje (zejména import obnovené zálohy). Tabulky (které jsou v záloze jako engine=innodb) se bez varování (!!!) vytvoří jako MYISAM. Příkazy jako BEGIN, COMMIT, ROLLBACK se tiše (!!!) ignorují. Data podléhají sillent corruption.
- Replikace fungují pouze s InnoDB, pouze s určitou verzí MySQL a pouze v určitém nastavení InnoDB. Jinak fungují taky, to ano. Jenže data na replice poněkud neodpovídají datům na masteru. Opět, nikde žádná chyba.
Po tomhle všem (a spoustě dalších) si řeknete, že teda dobře nastavíte InnoDB a všechno bude používat pouze tento engine. Jenže ouha, všechny diskové temporary tabulky jsou typu MYISAM. Takže fajné InnoDB, které má nastaveno 666GB paměti a jede rychle, ale jakmile se začně požadovat temporary na disku, tak je výkon zase v hajzlu. Takže začnete řešit MYISAM (kterého jste se nezbavili vs InnoDB). A to už je neřešitelné.
Takže ty engine fungují pouze tehdy, když jde o samostatné tabulky (bez referenčních vazeb, což projistotu opět umí jen InnoDB) a přistupuje k nim jeden uživatel (protože nefungují transakce a hlavně transakční izolace).
Výsledek je, že mnohem raději používám software, který dělá jen jednu věc, ale za to pořádně. To aplikační schéma, které jsi popsal, můžu krásně nahradit: *SQL jako jádro, memcached jako key-value cache a na aplikační logy třeba nějakou dokumentovou DB (podle toho, co s nimi chci dělat).
Výkon vyladím mnohem snadněji a jako bonus si můžu ty služby rozhodit na více HW.
Tiskni
Sdílej: