Setting a time limit for a transaction in MySQL/InnoDB
Posted
by
Trevor Burnham
on Server Fault
See other posts from Server Fault
or by Trevor Burnham
Published on 2011-03-01T18:59:31Z
Indexed on
2011/03/02
7:26 UTC
Read the original article
Hit count: 541
This sprang from this related question, where I wanted to know how to force two transactions to occur sequentially in a trivial case (where both are operating on only a single row). I got an answer—use SELECT ... FOR UPDATE
as the first line of both transactions—but this leads to a problem: If the first transaction is never committed or rolled back, then the second transaction will be blocked indefinitely. The innodb_lock_wait_timeout
variable sets the number of seconds after which the client trying to make the second transaction would be told "Sorry, try again"... but as far as I can tell, they'd be trying again until the next server reboot. So:
- Surely there must be a way to force a
ROLLBACK
if a transaction is taking forever? Must I resort to using a daemon to kill such transactions, and if so, what would such a daemon look like? - If a connection is killed by
wait_timeout
orinteractive_timeout
mid-transaction, is the transaction rolled back? Is there a way to test this from the console?
Clarification: innodb_lock_wait_timeout
sets the number of seconds that a transaction will wait for a lock to be released before giving up; what I want is a way of forcing a lock to be released.
Update: Here's a simple example that demonstrates why innodb_lock_wait_timeout
is not sufficient to ensure that the second transaction is not blocked by the first:
START TRANSACTION;
SELECT SLEEP(55);
COMMIT;
With the default setting of innodb_lock_wait_timeout = 50
, this transaction completes without errors after 55 seconds. And if you add an UPDATE
before the SLEEP
line, then initiate a second transaction from another client that tries to SELECT ... FOR UPDATE
the same row, it's the second transaction that times out, not the one that fell asleep.
What I'm looking for is a way to force an end to this transaction's restful slumber.
© Server Fault or respective owner