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 11:33 | Pozvánky

Konference LinuxDays 2017 proběhne o víkendu 7. a 8. října v Praze v Dejvicích v prostorách FIT ČVUT. Konference OpenAlt 2017 proběhne o víkendu 4. a 5. listopadu na FIT VUT v Brně. Organizátoři konferencí vyhlásili CFP (LinuxDays, OpenAlt). Přihlaste svou přednášku nebo doporučte konference známým.

Ladislav Hagara | Komentářů: 0
včera 06:00 | Nová verze

Byla vydána verze 1.3.0 odlehčeného desktopového prostředí Lumina (Wikipedie, GitHub) postaveného nad toolkitem Qt. Z novinek lze zmínit nový motiv ikon nahrazující Oxygen (material-design-[light/dark]) nebo vlastní multimediální přehrávač (lumina-mediaplayer).

Ladislav Hagara | Komentářů: 2
26.6. 17:33 | Bezpečnostní upozornění

Před šesti týdny byly publikovány výsledky bezpečnostního auditu zdrojových kódů OpenVPN a nalezené bezpečnostní chyby byly opraveny ve verzi OpenVPN 2.4.2. Guido Vranken minulý týden oznámil, že v OpenVPN nalezl další čtyři bezpečnostní chyby (CVE-2017-7520, CVE-2017-7521, CVE-2017-7522 a CVE-2017-7508). Nejzávažnější z nich se týká způsobu, jakým aplikace zachází s SSL certifikáty. Vzdálený útočník může pomocí speciálně

… více »
Ladislav Hagara | Komentářů: 1
26.6. 06:55 | Zajímavý projekt

V Edici CZ.NIC vyšla kniha Průvodce labyrintem algoritmů. Kniha je ke stažení zcela zdarma (pdf) nebo lze objednat tištěnou verzi za 339 Kč (připojení přes IPv4) nebo 289 Kč (připojení přes IPv6).

Ladislav Hagara | Komentářů: 8
26.6. 06:33 | Zajímavý software

Byla vydána verze 2.2.0 svobodného správce hesel KeePassXC (Wikipedie). Jedná se o komunitní fork správce hesel KeePassX s řadou vylepšení.

Ladislav Hagara | Komentářů: 0
26.6. 06:11 | IT novinky

Vývojář Debianu Henrique de Moraes Holschuh upozorňuje v diskusním listu debian-devel na chybu v Hyper-Threadingu v procesorech Skylake a Kaby Lake od Intelu. Za určitých okolností může chyba způsobit nepředvídatelné chování systému. Doporučuje se aktualizace mikrokódu CPU nebo vypnutí Hyper-Threadingu v BIOSu nebo UEFI [reddit].

Ladislav Hagara | Komentářů: 0
24.6. 01:23 | Komunita

Phoronix spustil 2017 Linux Laptop Survey. Tento dotazník s otázkami zaměřenými na parametry ideálního notebooku s Linuxem lze vyplnit do 6. července.

Ladislav Hagara | Komentářů: 3
23.6. 22:44 | Nová verze

Po třech měsících vývoje od vydání verze 5.5.0 byla vydána verze 5.6.0 správce digitálních fotografií digiKam (digiKam Software Collection). Do digiKamu se mimo jiné vrátila HTML galerie a nástroj pro vytváření videa z fotografií. V Bugzille bylo uzavřeno více než 81 záznamů.

Ladislav Hagara | Komentářů: 1
23.6. 17:44 | Nová verze

Byla vydána verze 9.3 open source alternativy GitHubu, tj. softwarového nástroje s webovým rozhraním umožňujícího spolupráci na zdrojových kódech, GitLab. Představení nových vlastností v příspěvku na blogu a na YouTube.

Ladislav Hagara | Komentářů: 3
23.6. 13:53 | Nová verze

Simon Long představil na blogu Raspberry Pi novou verzi 2017-06-21 linuxové distribuce Raspbian určené především pro jednodeskové miniaturní počítače Raspberry Pi. Společně s Raspbianem byl aktualizován také instalační nástroj NOOBS (New Out Of the Box Software). Z novinek lze zdůraznit IDE Thonny pro vývoj v programovacím jazyce Python a především offline verzi Scratche 2.0. Ten bylo dosud možné používat pouze online. Offline bylo možné používat pouze Scratch ve verzi 1.4. Z nového Scratchu lze ovládat také GPIO piny. Scratch 2.0 vyžaduje Flash.

Ladislav Hagara | Komentářů: 2
Chystáte se pořídit CPU AMD Ryzen?
 (6%)
 (31%)
 (1%)
 (9%)
 (44%)
 (9%)
Celkem 853 hlasů
 Komentářů: 65, poslední 1.6. 19:16
    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: 2489×
    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: 71 | 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 | Praha
    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: 32
    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: 32
    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.