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 12:33 | IT novinky

    Na blogu Raspberry Pi byla představena rozšiřující deska Raspberry Pi AI HAT+ 2 s akcelerátorem Hailo-10 a 8 GB RAM. Na rozdíl od předchozí Raspberry Pi AI HAT+ podporuje generativní AI. Cena desky je 130 dolarů.

    Ladislav Hagara | Komentářů: 2
    dnes 12:11 | Komunita

    Wikipedie slaví 25. výročí svého založení. Vznikla 15. ledna 2001 jako doplňkový projekt k dnes již neexistující encyklopedii Nupedia. Doména wikipedia.org byla zaregistrována 12. ledna 2001. Zítra proběhne v Praze Večer svobodné kultury, který pořádá spolek Wikimedia ČR.

    Ladislav Hagara | Komentářů: 0
    dnes 04:44 | Nová verze

    Po více než dvou letech od vydání předchozí verze 2.12 byla vydána nová stabilní verze 2.14 systémového zavaděče GNU GRUB (GRand Unified Bootloader, Wikipedie). Přehled novinek v souboru NEWS a v aktualizované dokumentaci.

    Ladislav Hagara | Komentářů: 0
    dnes 02:22 | Nová verze

    Google Chrome 144 byl prohlášen za stabilní. Nejnovější stabilní verze 144.0.7559.59 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Opraveno bylo 10 bezpečnostních chyb. Vylepšeny byly také nástroje pro vývojáře (YouTube).

    Ladislav Hagara | Komentářů: 2
    dnes 01:55 | Humor

    Microsoft zveřejnil zdrojový kód XAML Studia a uvolnil ho pod MIT licencí. XAML Studio je nástroj ze světa Windows, určený pro tvorbu uživatelského rozhraní aplikací pomocí XAML (Extensible Application Markup Language). Stalo se tak zhruba po osmi letech od prvního prohlášení Microsoftu, že se tento kód chystá zveřejnit.

    NUKE GAZA! 🎆 | Komentářů: 0
    dnes 01:44 | Zajímavý projekt

    TimeCapsule, 'časová kapsle', je jazykový model trénovaný výhradně na datech z určitých míst a časových období, aby se tak napodobila autentická slovní zásoba, způsob vyjadřování a názory dané doby. Na Hugging face jsou k dispozici modely natrénované na historických textech dostupných v oblasti Londýna mezi lety 1800 až 1875.

    NUKE GAZA! 🎆 | Komentářů: 4
    včera 17:55 | Nová verze

    Radicle byl vydán ve verzi 1.6.0 s kódovým jménem Amaryllis. Jedná se o distribuovanou alternativu k softwarům pro spolupráci jako např. GitLab.

    Ladislav Hagara | Komentářů: 0
    včera 13:22 | Upozornění

    Zemřel Scott Adams, tvůrce komiksových stripů Dilbert parodujících pracovní prostředí velké firmy.

    Ladislav Hagara | Komentářů: 4
    včera 13:00 | Nová verze

    Sdružení CZ.NIC vydalo novou verzi Knot Resolveru (6.1.0). Jedná se o první vydanou stabilní verzi 6, která je nyní oficiálně preferovanou a doporučovanou verzí, namísto předešlé verze 5. Více o Knot Resolveru 6 je možné se dočíst přímo v dokumentaci.

    VSladek | Komentářů: 3
    včera 01:22 | Nová verze

    Byl vydán Linux Mint 22.3 s kódovým jménem Zena. Podrobnosti v přehledu novinek a poznámkách k vydání. Vypíchnout lze, že nástroj Systémová hlášení (System Reports) získal mnoho nových funkcí a byl přejmenován na Informace o systému (System Information). Linux Mint 22.3 bude podporován do roku 2029.

    Ladislav Hagara | Komentářů: 1
    Které desktopové prostředí na Linuxu používáte?
     (14%)
     (5%)
     (0%)
     (8%)
     (19%)
     (3%)
     (6%)
     (3%)
     (11%)
     (44%)
    Celkem 443 hlasů
     Komentářů: 12, poslední včera 21:12
    Rozcestník

    Dotaz: postgresql - otazka k transakcim

    31.12.2009 22:23 amater-analytik
    postgresql - otazka k transakcim
    Přečteno: 407×
    mam postgresql databazi (tedy uvazuji o nasazeni), s ktero komunikuje N procesu, ktere 'jenom' ctou. Pouze jeden proces chce psat. Je mozno nejak zaridit, aby ten 'write-proces' pokracoval v praci, tedy aby nebyla nejakym postgresql transakcnim mechanismem zrusena ta write-transakce.

    Jestlize by to bylo nutne, at se ukonci nejaka ta 'read' transakce. Slo by to? Nebo to projde vzdy?

    Řešení dotazu:


    Odpovědi

    31.12.2009 23:20 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: postgresql - otazka k transakcim
    Záleží na tom, jak těm transakcím nastavíte isolation level. PostgreSQL používá MGA, takže tam by s tím při správném nastavení neměl být problém.
    okbob avatar 31.12.2009 23:24 okbob | skóre: 30 | blog: systemakuv_blog | Benešov
    Rozbalit Rozbalit vše Re: postgresql - otazka k transakcim
    V PostgreSQL čtení nikdy neblokuje zápis, a naopak zápis neblokuje čtení.

    Abyste se případně nedivil - víte, že PostgreSQL nepodporuje špinavé čtení, tedy, dokud transakce nepotvrdí změny, tak jsou pro ostatní transakce tyto změny neviditelné (pokud nepoužijete jeden velice ošklivý trik).

    Pavel
    1.1.2010 15:49 amater-analytik
    Rozbalit Rozbalit vše Re: postgresql - otazka k transakcim
    dekuji za odpoved. Dovolte jeste kratkou doplnkovou otazku.

    Jak jsem tomu porozumnel, tak vsechny soubezne transakce budou 'vzdy' provedeny i kdyz nejaka read_transakce RT precetla objekt A, write_transakce WT objekt A zmennila a pote RT objekt A znovu precetla (obe cteni dodaly ten samy vysledek - coz vyhovuje, bylo by dokonce neprijemne, kdyby mela RT v druhem cteni videt ty zmeny zpusobene skrz WT).

    Slovo 'vzdy' jsem dal do uvozovek, protoze je asi mozne, ze z nejakych systemovych duvodu se nepodari transakci provest. Je mozne se od pgsql dozvedet, ze COMMIT nebyl uspesny? Nebo se to neresi a v takovych pripadech pgsql server provede sam shutdown, nebo se proste zhrouti a po naslednem restartu se provede recovery ci neo podobneho.

    Server ma UPS a je to znackovy vyrobek. Centos 5.x. V tech write_transakcich ze zapisuji merici hodnoty. Jaka je podle vaseho mineni pravdepodobnost, ze ta write_transakce skonci spatne. Jestli jste to uz napr. vubec nekdy slysel, treba jsou to nepravdepodbne situace a je mozno to s klidnym svedomim nechat byt.
    okbob avatar 1.1.2010 17:18 okbob | skóre: 30 | blog: systemakuv_blog | Benešov
    Rozbalit Rozbalit vše Re: postgresql - otazka k transakcim
    Samozřejmě, že COMMIT může být neúspěšný - např. může dojít místo na disku. COMMIT je příkaz jako každý jiný, pokud není úspěšně vykonán, je skrze mechanismy odpovídající použitému programovacímu jazyku, signalizovaná chyba.

    Shutdown by byl trochu silný tabák, nemyslíte?

    Pravděpodobnost neúspěšného COMMITu Vaší hypotetické aplikace Vám opravdu nedokáži sdělit. Bude +/- stejná jako pravděpodobnost, že se Vám podaří zapsat data na disk. Málokterá zařízení v obvyklé cenové hladině Vám budou garantovat 100% dostupnost, bez ohledu na značkovost a UPS - na druhou stranu chyby nejsou běžné. Jelikož sám sebe označujete za amatéra, tak nepředpokládám, že byste programoval aplikace od kterých se vyžaduje bezpečnostní audit (sw, kde by případná chyba ohrožovala životy nebo majetek),takže to můžete neřešit.
    1.1.2010 18:20 amater-analytik
    Rozbalit Rozbalit vše Re: postgresql - otazka k transakcim
    dekuji, s tim COMMITem to je tak, ze ve vetsine prikladu se na vysledek nikdo nepta a to me znejistelo, ale nyni jsem nasel nekolik, kde to je jak rikate.

    Nevim, jak oznacit, ze je to zodpovezeno, snad nejaky admin udela ten hacek. Dekuji.
    okbob avatar 1.1.2010 19:59 okbob | skóre: 30 | blog: systemakuv_blog | Benešov
    Rozbalit Rozbalit vše Re: postgresql - otazka k transakcim
    Ona take vetsina aplikaci je pofiderne napsana. Nastesti - kazda ACID databaze nejakym zpusobem garantuje konzistenci dat, bez ohledu na to, jak jsou psane aplikace.
    3.1.2010 02:34 trekker.dk | skóre: 72
    Rozbalit Rozbalit vše Re: postgresql - otazka k transakcim
    (obe cteni dodaly ten samy vysledek - coz vyhovuje, bylo by dokonce neprijemne, kdyby mela RT v druhem cteni videt ty zmeny zpusobene skrz WT).
    Tohle AFAIK závisí na tom, jak moc je transakce izolována. Ve výchozím nastavení:
    kluster=> begin transaction;
    kluster=> select * from hosts;
     id | jmeno  |      ip       | jader | loadavg | pamet 
    ----+--------+---------------+-------+---------+-------
      2 | host1  | 192.168.253.1 |     2 |       0 |  2048
    
    ... nyní jsem jinou transakcí změnil hodnotu "jader" na 3
    
    kluster=> select * from hosts;
    
     id | jmeno  |      ip       | jader | loadavg | pamet 
    ----+--------+---------------+-------+---------+-------
      2 | host1  | 192.168.253.1 |     3 |       0 |  2048
    kluster=> commit;
    Čiže v jedné transakci, která jenom čte, se projevují paralelně prováděné změny. Pokud to nechceš, je potřeba nastavit set transaction isolation level repeatable read (v PG tj. serializable)
    Quando omni flunkus moritati
    okbob avatar 3.1.2010 09:37 okbob | skóre: 30 | blog: systemakuv_blog | Benešov
    Rozbalit Rozbalit vše Re: postgresql - otazka k transakcim
    ju, jenom přidám poznámku, že nejnižší úroveň - špinavé čtení není v PostgreSQL implementováno.

    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.