ORA-00060: deadlock detected while waiting for resource

后端 未结 4 2092
误落风尘
误落风尘 2021-02-01 17:40

I have a series of scripts running in parallel as a nohup on an AIX server hosting oracle 10g. These scripts are written by somebody else and are meant to be executed concurrent

相关标签:
4条回答
  • 2021-02-01 18:08

    I was testing a function that had multiple UPDATE statements within IF-ELSE blocks.

    I was testing all possible paths, so I reset the tables to their previous values with 'manual' UPDATE statements each time before running the function again.

    I noticed that the issue would happen just after those UPDATE statements;

    I added a COMMIT; after the UPDATE statement I used to reset the tables and that solved the problem.

    So, caution, the problem was not the function itself...

    0 讨论(0)
  • 2021-02-01 18:09

    You can get deadlocks on more than just row locks, e.g. see this. The scripts may be competing for other resources, such as index blocks.

    I've gotten around this in the past by engineering the parallelism in such a way that different instances are working on portions of the workload that are less likely to affect blocks that are close to each other; for example, for an update of a large table, instead of setting up the parallel slaves using something like MOD(n,10), I'd use TRUNC(n/10) which mean that each slave worked on a contiguous set of data.

    There are, of course, much better ways of splitting up a job for parallelism, e.g. DBMS_PARALLEL_EXECUTE.

    Not sure why you're getting "PL/SQL successfully completed", perhaps your scripts are handling the exception?

    0 讨论(0)
  • 2021-02-01 18:12

    I ran into this issue as well. I don't know the technical details of what was actually happening. However, in my situation, the root cause was that there was cascading deletes setup in the Oracle database and my JPA/Hibernate code was also trying to do the cascading delete calls. So my advice is to make sure that you know exactly what is happening.

    0 讨论(0)
  • 2021-02-01 18:16

    I was recently struggling with a similar problem. It turned out that the database was missing indexes on foreign keys. That caused Oracle to lock many more records than required which quickly led to a deadlock during high concurrency.

    Here is an excellent article with lots of good detail, suggestions, and details about how to fix a deadlock: http://www.oratechinfo.co.uk/deadlocks.html#unindex_fk

    0 讨论(0)
提交回复
热议问题