Обсуждение: Locking: PostgreSQL Vs. Oracle
Hi all,
I’m in the process of migrating a web application from Oracle to PostgreSQL and, after quite a few headaches, it’s almost there. The last step (I hope) is getting to the bottom of an intermittent locking issue I see when I run integration tests. Most of the time, all tests are passing, but occasionally a test will fail with a stale state exception. Another developer ran a few IT tests and said one run stalled and never finished. Based on a cursory look at the internal PG tables, he said it looked like too many tables were locked due locks propagating out via foreign keys. I’m not sure how this could be possible.
I’ve been looking into the differences between PostgreSQL and Oracle locking behavior, but nothing has jumped out at me so far. I’m not a dba so hopefully I’m missing something obvious. Any advice would be greatly appreciated! Thanks.
Additional information;
Isolation Level: read committed for both dbs
JBoss 6.1 eap
PostgreSQL 9.4
Hibernate 3.64
CONFIDENTIALITY : This e-mail and any attachments are confidential and may be privileged. If you are not a named recipient, please notify the sender immediately and do not disclose the contents to another person, use it for any purpose or store or copy the information in any medium.
Hi all,
I’m in the process of migrating a web application from Oracle to PostgreSQL and, after quite a few headaches, it’s almost there. The last step (I hope) is getting to the bottom of an intermittent locking issue I see when I run integration tests. Most of the time, all tests are passing, but occasionally a test will fail with a stale state exception. Another developer ran a few IT tests and said one run stalled and never finished. Based on a cursory look at the internal PG tables, he said it looked like too many tables were locked due locks propagating out via foreign keys. I’m not sure how this could be possible.
I’ve been looking into the differences between PostgreSQL and Oracle locking behavior, but nothing has jumped out at me so far. I’m not a dba so hopefully I’m missing something obvious. Any advice would be greatly appreciated! Thanks.
Additional information;
Isolation Level: read committed for both dbs
JBoss 6.1 eap
PostgreSQL 9.4
Hibernate 3.64
CONFIDENTIALITY : This e-mail and any attachments are confidential and may be privileged. If you are not a named recipient, please notify the sender immediately and do not disclose the contents to another person, use it for any purpose or store or copy the information in any medium.
HEMPLEMAN Matthew wrote: > I’m in the process of migrating a web application from Oracle to PostgreSQL and, after quite a few > headaches, it’s almost there. The last step (I hope) is getting to the bottom of an intermittent > locking issue I see when I run integration tests. Most of the time, all tests are passing, but > occasionally a test will fail with a stale state exception. Another developer ran a few IT tests and > said one run stalled and never finished. Based on a cursory look at the internal PG tables, he said > it looked like too many tables were locked due locks propagating out via foreign keys. I’m not sure > how this could be possible. Assume you have two tables referencing each other, e.g.: CREATE TABLE parent ( parent_id integer PRIMARY KEY, parent_val text ); CREATE TABLE child ( child_id integer PRIMARY KEY, parent_id integer REFERENCES parent(parent_id), child_val text ); and an entry in "parent", like INSERT INTO parent (parent_id, parent_val) VALUES (1, 'something'); Then if you insert something in "child", like: BEGIN; INSERT INTO child (child_id, parent_id, child_val) VALUES (42, 1, 'other'); you will have a lock on the corresponding row of the "parent" table as long as the transaction lasts. This is necessary because if another concurrent session were allowed to e.g. delete the entry in "parent", the foreign key constraint would be violated. Similar locks are taken for UPDATE or DELETE. > I’ve been looking into the differences between PostgreSQL and Oracle locking behavior, but nothing has > jumped out at me so far. I’m not a dba so hopefully I’m missing something obvious. Any advice would > be greatly appreciated! Thanks. Oracle and PostgreSQL do roughly the same thing in this case. Which version of PostgreSQL is this? Before 9.3 the locks taken on parent tables were unnecessarily strong, so you would encounter problems like the one you describe more easily. http://git.postgresql.org/gitweb/?p=postgresql.git;a=commit;h=0ac5ad5134f2769ccbaefec73844f8504c4d6182 Yours, Laurenz Albe