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í
×
eParkomat, startup z ČR, postoupil mezi finalisty evropského akcelerátoru ChallengeUp!
Robot na pivo mu otevřel dveře k opravdovému byznysu
Internet věcí: Propojený svět? Už se to blíží...
včera 16:38 | Komunita

Byly zveřejněny videozáznamy přednášek a workshopů z letošní konference OpenAlt konané 5. a 6. listopadu v Brně. K videozáznamům lze přistupovat ze stránky na SuperLectures nebo přes program konference, detaily o vybrané přednášce nebo workshopu a dále kliknutím na ikonku filmového pásu. Celkově bylo zpracováno 65 hodin z 89 přednášek a workshopů.

Ladislav Hagara | Komentářů: 0
včera 11:30 | Komunita

Bylo oznámeno, že bude proveden bezpečnostní audit zdrojových kódů open source softwaru pro implementaci virtuálních privátních sítí OpenVPN. Audit provede Matthew D. Green (blog), uznávaný kryptolog a profesor na Univerzitě Johnse Hopkinse. Auditována bude verze 2.4 (aktuálně RC 1, stabilní verze je 2.3.14). Audit bude financován společností Private Internet Access [reddit].

Ladislav Hagara | Komentářů: 2
včera 06:00 | Komunita

Na YouTube byl publikován Blender Institute Reel 2016, ani ne dvouminutový sestřih z filmů, které vznikly za posledních 10 let díky Blender Institutu. V institutu aktuálně pracují na novém filmu Agent 327. Dění kolem filmu lze sledovat na Blender Cloudu. Videoukázka Agenta 327 z června letošního roku na YouTube.

Ladislav Hagara | Komentářů: 0
včera 01:02 | Zajímavý článek

Minulý týden byly vydány verze 1.2.3 a 1.1.7 webového poštovního klienta Roundcube. V oznámení o vydání bylo zmíněno řešení bezpečnostního problému nalezeného společností RIPS a souvisejícího s voláním funkce mail() v PHP. Tento týden byly zveřejněny podrobnosti. Útočník mohl pomocí speciálně připraveného emailu spustit na serveru libovolný příkaz. Stejně, jak je popsáno v článku Exploit PHP’s mail() to get remote code execution z roku 2014.

Ladislav Hagara | Komentářů: 1
8.12. 16:00 | Nová verze

Byla vydána verze 0.98 svobodného nelineárního video editoru Pitivi. Z novinek lze zmínit například přizpůsobitelné klávesové zkratky. Videoukázka práce s nejnovější verzí Pitivi na YouTube.

Ladislav Hagara | Komentářů: 1
8.12. 15:00 | Zajímavý software

Stop motion je technika animace, při níž je reálný objekt mezi jednotlivými snímky ručně upravován a posouván o malé úseky, tak aby po spojení vyvolala animace dojem spojitosti. Jaký software lze pro stop motion použít na Linuxu? Článek na OMG! Ubuntu! představuje Heron Animation. Ten bohužel podporuje pouze webové kamery. Podpora digitálních zrcadlovek je začleněna například v programu qStopMotion.

Ladislav Hagara | Komentářů: 5
7.12. 21:21 | Nová verze Ladislav Hagara | Komentářů: 0
7.12. 11:44 | Zajímavý projekt

Na Indiegogo byla spuštěna kampaň na podporu herní mini konzole a multimediálního centra RetroEngine Sigma od Doyodo. Předobjednat ji lze již od 49 dolarů. Požadovaná částka 20 000 dolarů byla překonána již 6 krát. Majitelé mini konzole si budou moci zahrát hry pro Atari VCS 2600, Sega Genesis nebo NES. Předinstalováno bude multimediální centrum Kodi.

Ladislav Hagara | Komentářů: 2
7.12. 00:10 | Nová verze

Byla vydána verze 4.7 redakčního systému WordPress. Kódové označením Vaughan bylo vybráno na počest americké jazzové zpěvačky Sarah "Sassy" Vaughan. Z novinek lze zmínit například novou výchozí šablonu Twenty Seventeen, náhledy pdf souborů nebo WordPress REST API.

Ladislav Hagara | Komentářů: 10
6.12. 12:00 | Zajímavý projekt

Projekt Termbox umožňuje vyzkoušet si linuxové distribuce Ubuntu, Debian, Fedora, CentOS a Arch Linux ve webovém prohlížeči. Řešení je postaveno na projektu HyperContainer. Podrobnosti v často kladených dotazech (FAQ). Zdrojové kódy jsou k dispozici na GitHubu [reddit].

Ladislav Hagara | Komentářů: 28
Kolik máte dat ve svém domovském adresáři na svém primárním osobním počítači?
 (32%)
 (24%)
 (29%)
 (7%)
 (5%)
 (3%)
Celkem 807 hlasů
 Komentářů: 50, poslední 29.11. 15:50
Rozcestník
Reklama
Š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: 2457×
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: 37 | 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.