abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 13:22 | Nová verze

    Fossil (Wikipedie) byl vydán ve verzi 2.24. Jedná se o distribuovaný systém správy verzí propojený se správou chyb, wiki stránek a blogů s integrovaným webovým rozhraním. Vše běží z jednoho jediného spustitelného souboru a uloženo je v SQLite databázi.

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

    Byla vydána nová stabilní verze 6.7 webového prohlížeče Vivaldi (Wikipedie). Postavena je na Chromiu 124. Přehled novinek i s náhledy v příspěvku na blogu. Vypíchnout lze Spořič paměti (Memory Saver) automaticky hibernující karty, které nebyly nějakou dobu používány nebo vylepšené Odběry (Feed Reader).

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

    OpenJS Foundation, oficiální projekt konsorcia Linux Foundation, oznámila vydání verze 22 otevřeného multiplatformního prostředí pro vývoj a běh síťových aplikací napsaných v JavaScriptu Node.js (Wikipedie). V říjnu se verze 22 stane novou aktivní LTS verzí. Podpora je plánována do dubna 2027.

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

    Byla vydána verze 8.2 open source virtualizační platformy Proxmox VE (Proxmox Virtual Environment, Wikipedie) založené na Debianu. Přehled novinek v poznámkách k vydání a v informačním videu. Zdůrazněn je průvodce migrací hostů z VMware ESXi do Proxmoxu.

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

    R (Wikipedie), programovací jazyk a prostředí určené pro statistickou analýzu dat a jejich grafické zobrazení, bylo vydáno ve verzi 4.4.0. Její kódové jméno je Puppy Cup.

    Ladislav Hagara | Komentářů: 0
    včera 22:44 | IT novinky

    IBM kupuje společnost HashiCorp (Terraform, Packer, Vault, Boundary, Consul, Nomad, Waypoint, Vagrant, …) za 6,4 miliardy dolarů, tj. 35 dolarů za akcii.

    Ladislav Hagara | Komentářů: 9
    včera 15:55 | Nová verze

    Byl vydán TrueNAS SCALE 24.04 “Dragonfish”. Přehled novinek této open source storage platformy postavené na Debianu v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    včera 13:44 | IT novinky

    Oznámeny byly nové Raspberry Pi Compute Module 4S. Vedle původní 1 GB varianty jsou nově k dispozici také varianty s 2 GB, 4 GB a 8 GB paměti. Compute Modules 4S mají na rozdíl od Compute Module 4 tvar a velikost Compute Module 3+ a předchozích. Lze tak provést snadný upgrade.

    Ladislav Hagara | Komentářů: 0
    včera 04:44 | Nová verze

    Po roce vývoje od vydání verze 1.24.0 byla vydána nová stabilní verze 1.26.0 webového serveru a reverzní proxy nginx (Wikipedie). Nová verze přináší řadu novinek. Podrobný přehled v souboru CHANGES-1.26.

    Ladislav Hagara | Komentářů: 0
    včera 04:33 | Nová verze

    Byla vydána nová verze 6.2 živé linuxové distribuce Tails (The Amnesic Incognito Live System), jež klade důraz na ochranu soukromí uživatelů a anonymitu. Přehled změn v příslušném seznamu. Tor Browser byl povýšen na verzi 13.0.14.

    Ladislav Hagara | Komentářů: 0
    KDE Plasma 6
     (72%)
     (9%)
     (2%)
     (17%)
    Celkem 745 hlasů
     Komentářů: 4, poslední 6.4. 15:51
    Rozcestník
    Štítky: není přiřazen žádný štítek

    Dotaz: mysql: transakce a uzamceni tabulky

    2.11.2008 16:56 zoufalec
    mysql: transakce a uzamceni tabulky
    Přečteno: 2731×
    Jak mam v innodb uzamknout tabulku behem transakce pro zapis? V manualu se pise, ze LOCK TABLE provede COMMIT a START TRANSACTION zase provede UNLOCK TABLE. To musel vymyslet opravdu chytry inzenyr. Da se to nejak obejit treba uzamcenim vsech radku v tabulce, aby to vydrzelo po celou transakci? Dekuji.

    Odpovědi

    3.11.2008 06:39 pht | skóre: 48 | blog: pht
    Rozbalit Rozbalit vše Re: mysql: transakce a uzamceni tabulky
    proc chcete zamykat tabulku pro zapis kdyz mate transakce?
    In Ada the typical infinite loop would normally be terminated by detonation.
    3.11.2008 14:59 qwerty
    Rozbalit Rozbalit vše Re: mysql: transakce a uzamceni tabulky
    ??? co je to za dotaz?

    protoze trnsakce nechrani tabulku proti zmenam od jinych klientu
    3.11.2008 17:56 pht | skóre: 48 | blog: pht
    Rozbalit Rozbalit vše Re: mysql: transakce a uzamceni tabulky
    ??? a proc to chcete takto chranit?
    In Ada the typical infinite loop would normally be terminated by detonation.
    3.11.2008 18:13 pht | skóre: 48 | blog: pht
    Rozbalit Rozbalit vše Re: mysql: transakce a uzamceni tabulky
    jo ja uz to vidim nize ... on ma aplikaci ktera si zrejme plete databazi s textovym souborem, neni schopna pobrat provoz vicero klientu naraz, ale hlavne ze to cele je na te "nejvykonnejsi" databazi, tak v tom pripade jiste inzenyri mysql nekde udelali chybu! :-)
    In Ada the typical infinite loop would normally be terminated by detonation.
    4.11.2008 05:43 zoufalec
    Rozbalit Rozbalit vše Re: mysql: transakce a uzamceni tabulky
    Transakce a zamykani tabulek jsou uplne jine veci, kazde se pouziva za jinym ucelem a jedno druhe nenahradi. Jedno poskytuje atomicitu nekolika operacim najednou, druhe chrani po nejaky cas tabulku pred zmenami. Podle vaseho posmesneho vyjadreni by se zdalo, ze zamykani tabulek je uplne zbytecne. Proc myslite, ze ho tedy databaze poskytuji? Opravdu jste se nikdy nesetkal s potrebou provedeni nejake operace s jistotou, ze se v jejim prubehu tabulka nezmeni? Pak bych to zase ja videl spise na nedostatek praxe.
    4.11.2008 14:23 Ivan
    Rozbalit Rozbalit vše Re: mysql: transakce a uzamceni tabulky
    No nevim. Podle "ideologie" Oracle je lock table zbytecna vec. Tzn. pokud potrebujete zamknout tabulku tak mate zcela jiste chybu v navrhu. V nekterych pripadech Oracle lock table vubec nepodporuje.
    4.11.2008 22:10 zoufalec
    Rozbalit Rozbalit vše Re: mysql: transakce a uzamceni tabulky
    No, podivejte se na modelovy priklad. Mejme v mysql/innodb dva thready T1 a T2:

    T1: set autocommit=0 => OK T2: set autocommit=0 => OK T1: insert into tabulka values ('test') => OK T2: insert into tabulka values ('test') => wait T1: delete from tabulka where id='test' => OK T2: => error: Deadlock found when trying to get lock; try restarting transaction

    Je pekne, ze mysql umi detekovat deadlock a vzpamatovat se z nej bez zatuhnuti, ale prece jen mam pocit, ze by bylo lepsi se deadlockum vyhybat. Prozradte mi prosim jak.

    4.11.2008 22:12 zoufalec
    Rozbalit Rozbalit vše Re: mysql: transakce a uzamceni tabulky
    No, podivejte se na modelovy priklad. Mejme v mysql/innodb dva thready T1 a T2:
    T1: set autocommit=0 => OK
    T2: set autocommit=0 => OK
    T1: insert into tabulka values ('test') => OK
    T2: insert into tabulka values ('test') => wait
    T1: delete from tabulka where id='test' => OK
    T2: => error: Deadlock found when trying to get lock; try restarting transaction
    
    Je pekne, ze mysql umi detekovat deadlock a vzpamatovat se z nej bez zatuhnuti, ale prece jen mam pocit, ze by bylo lepsi se deadlockum vyhybat. Prozradte mi prosim jak.

    5.11.2008 07:57 pht | skóre: 48 | blog: pht
    Rozbalit Rozbalit vše Re: mysql: transakce a uzamceni tabulky
    nepomohlo by tady zmenit isolation level?
    In Ada the typical infinite loop would normally be terminated by detonation.
    5.11.2008 20:14 zoufalec
    Rozbalit Rozbalit vše Re: mysql: transakce a uzamceni tabulky
    To nevim, ale vim, ze zamknuti tabulky je ucinne a resi dalsi obdobne problemy. V zamknuti tabulky na dobu dvou tri malych nenakladnych operaci, ktere probehnou rychle a jen obcas behem administrace aplikace nevidim problem, vysledkem je spolehliva a robustni aplikace, coz je v mem pripade vyrazne dulezitejsi nez vykon. Jen me prekvapuje, ze je tu tolik lidi, kteri se tvari opovrzlive nad pouzivanim standardniho nastroje lock table, tvari se jako mistri sveta, hovori zasvecene o spatnem navrhu aplikace, ale kdyz dojde na prakticky problem, tak je ticho po pesine.
    10.11.2008 14:47 Zdenek Kotala
    Rozbalit Rozbalit vše Re: mysql: transakce a uzamceni tabulky
    No ja se tem lidem nedivim. LOCK TABLE je obezlicka MySQL protoze, kdysi nepouzivala transakce a jinak to proste neslo. Rada lidi to pouziva dodnes a pak se divi, ze jim ta databaze neskaluje. Samozrejmne najdou se asi vyjmecne pripady, kdy je nutne to pouzit, ale osobne jsem to nikdy nepotreboval. Pokud se Vam jedna treba o to, zamknout jen nektere zaznamy, ktere budete pozdeji modifikovat, tak pak existuje v rozumnych databazich SELECT ... FOR UPDATE. Coz vam zamkne prislusne radky. Dalsi uz zminovana vec je pouzit jiny izolacni level.
    11.11.2008 14:37 zoufalec
    Rozbalit Rozbalit vše Re: mysql: transakce a uzamceni tabulky
    Ktery level konkretne na uvedeny konkretni pripad?

    Lock table neni obezlicka MySQL, ale standardni soucast SQL. Vite snad o databazi, kera by to nepodporovala?
    11.11.2008 14:45 Michal Kubeček | skóre: 72 | Luštěnice
    Rozbalit Rozbalit vše Re: mysql: transakce a uzamceni tabulky
    Ještě relativně nedávno třeba Firebird. Dokonce když tuto featuru zaváděli, považovali za nutné v Release Notes uvést příklad, k čemu může takové zamykání tabulky vlastně být dobré. Jiný kraj, jiný mrav…
    6.11.2008 13:16 burlog | skóre: 9
    Rozbalit Rozbalit vše Re: mysql: transakce a uzamceni tabulky
    Odpoved je v dokumentaci k mysql, ted nevim kde presne to je. Pokud dojde k deadlocku, je doporuceno transakci zkusit restartnout, tedy ji provest celou znova.... Neni to asi uplne idealni, ale ve vetsine pripadu to bude fungovat.
    6.11.2008 15:08 zoufalec
    Rozbalit Rozbalit vše Re: mysql: transakce a uzamceni tabulky
    Tohle bohuzel neni odpoved, jak se vyhnout deadlocku. V podstate mi rikate, abych se s nim smiril. Dekuji, ale to neni muj styl.
    4.11.2008 06:39 happy barney | skóre: 34 | blog: dont_worry_be_happy
    Rozbalit Rozbalit vše Re: mysql: transakce a uzamceni tabulky
    na to máte k dispozícii "select for update" a vhodne zvolený "transaction isolation level"
    4.11.2008 16:54 qweasd
    Rozbalit Rozbalit vše Re: mysql: transakce a uzamceni tabulky
    To by me zajimlo, mam dva priklady. 1) dva prikazy insert/update pro jednu nebo dve tabulky, behem nich nesmi dojit k vlozni/zmene zadnych zaznamu, 2) jeden select a jeden insert, behem nich nesmi byt tabulka ctena, ani do ni nesmi byt vlozen jiny zaznam. Jak to udelate bez zamknuti tabulky, aby to bylo spolehlive bez moznosti selhani.
    3.11.2008 16:44 podlesh | skóre: 38 | Freiburg im Breisgau
    Rozbalit Rozbalit vše Re: mysql: transakce a uzamceni tabulky
    Raději se nebudu ptát, k čemu to má být a prostě odpovím na otázku tak jak je položena.
    SELECT * FROM tabulka LOCK IN SHARE MODE
    
    případně exkluzivní zamčení:
    SELECT * FROM tabulka FOR UPDATE
    
    3.11.2008 17:19 zoufalec
    Rozbalit Rozbalit vše Re: mysql: transakce a uzamceni tabulky
    Potrebuji to k portovani jedne aplikace z oracle na mysql aby byla pouzitelna i na free hostinzich. Logika aplikace s tim pocita. U oracle tabulka bez transakce ani zamknout nejde a odemykaji se jen ukoncenim transakce nebo ulozenim save pointu. Opravdu by me zajimalo, proc to v mysql je takhle blbe udelano a vylucuje se to navzajem. Diky za radu.
    3.11.2008 18:20 pht | skóre: 48 | blog: pht
    Rozbalit Rozbalit vše Re: mysql: transakce a uzamceni tabulky
    tak ja bych rekl ze to bude tim, ze se to vzajemne vylucuje. ale v manualu pisou:

    The correct way to use LOCK TABLES and UNLOCK TABLES with transactional tables, such as InnoDB tables, is to begin a transaction with SET AUTOCOMMIT = 0 (not START TRANSACTION) followed by LOCK TABLES, and to not call UNLOCK TABLES until you commit the transaction explicitly.

    nepomuze to?
    In Ada the typical infinite loop would normally be terminated by detonation.
    4.11.2008 05:24 zoufalec
    Rozbalit Rozbalit vše Re: mysql: transakce a uzamceni tabulky
    Aha, to je zajimave, ze autocommit = 0 se chova jinak, nez start transaction. Jesli to nema dalsi posrtranni efekty, tak by to mohlo fungovat, dekuji.
    3.11.2008 17:22 zoufalec
    Rozbalit Rozbalit vše Re: mysql: transakce a uzamceni tabulky
    I kdyz me ted napada, ze tohle asi nezabrani tomu, aby se do tabulky pridaly nove zaznamy, tudiz to neni ekvivalent lock table, ach jo. Existuje jeste nejake jine reseni, jak nahradit zamknuti tabulky v transakci?
    6.11.2008 16:24 razor | skóre: 33
    Rozbalit Rozbalit vše Re: mysql: transakce a uzamceni tabulky
    Ahoj, v dokumentaci píšou:
    The correct way to use LOCK TABLES and UNLOCK TABLES with transactional tables, such as InnoDB tables, is to begin a transaction with SET AUTOCOMMIT = 0 (not START TRANSACTION) followed by LOCK TABLES, and to not call UNLOCK TABLES until you commit the transaction explicitly.
    Takže správně by to mělo být:
    set autocommit = 0;
    lock table t write;
    
    dělám něco s tabulkou t
    
    commit;
    unlock tables;
    
    To nefunguje?
    6.11.2008 17:48 zoufalec
    Rozbalit Rozbalit vše Re: mysql: transakce a uzamceni tabulky
    Ahoj. Jo, tohle uz mi poradili o kousek vyse: http://www.abclinuxu.cz/poradna/databaze/show/244196#8 predevcirem a mohu potvrdit, ze to funguje, diky.
    6.11.2008 18:04 razor | skóre: 33
    Rozbalit Rozbalit vše Re: mysql: transakce a uzamceni tabulky
    jé, tak to jsem slepej, sorry :-)
    8.11.2008 10:34 Ondra
    Rozbalit Rozbalit vše Re: mysql: transakce a uzamceni tabulky
    Zajimava debata. Je tu nejaky alespon stredne pokrocili uzivatel MySQL, ktery by nam, neznalym, objasnil, jaky je rozdil mezi START TRANSACTION a SET AUTOCOMMIT=0, a kdy se ma co spravne pouzivat? Dodnes jsem si myslel, ze je to ekvivalentni, ale jak je videt, tak neni.
    12.11.2008 10:40 Tomas
    Rozbalit Rozbalit vše Re: mysql: transakce a uzamceni tabulky

    Tady lze najít popis chování s autocommit=0/1. IMHO v oficiálním manuálu MySQL je AUTOCOMMIT zadokumentován špatně.

    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.