Search Postgresql Archives

Misunderstanding transactions and locks

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi,

I'm using Django with Postgres 8.3.9 on CentOS Linux.

I'm trying to figure out why locking isn't working as I'm expecting. I have a
an operation wrapped in a transaction where I explicitely grab an exclusive
lock on my table. When another process concurrently runs to do the same, it
should block on attempting to acquire the exclusive lock, no?

That is not what I am seeing. I see two processes both doing this

2010-06-16 12:14:31.909608500 LOG:  connection received: host=[local]
2010-06-16 12:14:31.909748500 DEBUG:  forked new backend, pid=30726 socket=6
2010-06-16 12:14:31.909784500 LOG:  connection authorized: user=tugdbuser
database=tugd
b
2010-06-16 12:14:31.911516500 LOG:  statement: SET DATESTYLE TO 'ISO'
2010-06-16 12:14:31.911630500 LOG:  statement: SHOW client_encoding
2010-06-16 12:14:31.911768500 LOG:  statement: SHOW
default_transaction_isolation
2010-06-16 12:14:31.911849500 LOG:  statement: SET client_encoding = 'UTF8'
2010-06-16 12:14:31.911972500 LOG:  statement: BEGIN; SET TRANSACTION
ISOLATION LEVEL R
EAD COMMITTED
2010-06-16 12:14:31.912028500 LOG:  statement: SET TIME ZONE
E'America/New_York'
2010-06-16 12:14:31.912373500 LOG:  statement: SELECT version()
...skipping...
2010-06-16 12:14:31.913008500 LOG:  statement: LOCK TABLE instances IN ROW
EXCLUSIVE MODE

The first lock does not seem to prevent the second from completing.

Am I misunderstanding how locks work in postgres?

Thanks,
Mike
-- 
Michael P. Soulier <michael_soulier@xxxxxxxxx>, 613-592-2122 x2522
"Any intelligent fool can make things bigger and more complex... It takes a
touch of genius - and a lot of courage to move in the opposite direction."
--Albert Einstein

Attachment: pgpYDROJlQ6D6.pgp
Description: PGP signature


[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Index of Archives]     [Postgresql Jobs]     [Postgresql Admin]     [Postgresql Performance]     [Linux Clusters]     [PHP Home]     [PHP on Windows]     [Kernel Newbies]     [PHP Classes]     [PHP Books]     [PHP Databases]     [Postgresql & PHP]     [Yosemite]
  Powered by Linux