Uploaded image for project: 'Derby'
  1. Derby
  2. DERBY-5430

Embedded nstest shows ERROR 40001: A lock could not be obtained due to a deadlock, in nstest

    XMLWordPrintableJSON

Details

    • Bug
    • Status: Closed
    • Major
    • Resolution: Won't Fix
    • 10.8.2.2
    • None
    • Test
    • None
    • Windows XP, Suse Linux, NsTest Embedded, ibm 1.6 SR9 FP1.
    • Urgent
    • Regression Test Failure

    Description

      When running the nstest system test with Embedded with the 10.8.2.1 release candidate, or a build sync-ed to the top of the 10.8 tree (at level: version: 10.8.2.2 - (1174879M) - the M is to add checks (only do if not null) to number of PreparedStatement.close() calls), I now see a number of deadlock errors if I capture the output to a file.

      The test run with network server did not show this problem.
      10.7.1.1 and 10.8.1.2 did not show this problem.

      There's nothing in derby.log, but this is an example of the error to the console as captured in a file:

      Thread 37 is now running
      ==========> Tester2Thread 37 THREAD starting <======
      Tester2Thread 37 is getting a connection to the database...
      -->Thread Tester2Thread 37 starting with url jdbc:derby:nstestdb;create=true;boo
      tPassword=12345678 <--
      Connection number: 44
      Tester2Thread 37 dbutil.pick_one() -> Obtained row from the table 35979
      Tester2Thread 37 attempting to delete a row with serialkey = 35979
      Tester2Thread 37 deleted row with serialkey 35979 *** SUCCESS ***
      Tester2Thread 37 dbutil.pick_one() -> Obtained row from the table 35978
      java.sql.SQLTransactionRollbackException: A lock could not be obtained due to a
      deadlock, cycle of locks and waiters is:
      Lock : ROW, SYSCOLUMNS, (5,16)
      Waiting XID :

      {1174407, S} , NSTEST, insert into nstesttab (id, t_char, t_dat
      e, t_decimal, t_decimal_nn, t_double, t_float, t_int, t_longint, t_numeric_larg
      e, t_real, t_smallint, t_time, t_timestamp, t_varchar,t_clob,t_blob) values ( ?,
      ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?,cast('00000000000000000000000000000000
      031' as clob(1K)),cast(X'0000000000000000000000000000000000000000000000000000000
      00000000000000000000000000000000000000000000000000000000000000000000000000000000
      000000000000000000000000000000000000000000000000000000031' as blob(10K)))
      Granted XID : {61356, S} , {75588, S} , {147655, S} , {204335, S} , {460963, S
      } , {511711, S} , {565264, S} , {727656, S} , {791364, S} , {1133117, S}
      Lock : ROW, SYSCOLUMNS, (5,16)
      Waiting XID : {1133117, X} , NSTEST, insert into nstesttab (id, t_char, t_dat
      e, t_decimal, t_decimal_nn, t_double, t_float, t_int, t_longint, t_numeric_larg
      e, t_real, t_smallint, t_time, t_timestamp, t_varchar,t_clob,t_blob) values ( ?,
      ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?,cast('00000000000000000000000000000000
      031' as clob(1K)),cast(X'0000000000000000000000000000000000000000000000000000000
      00000000000000000000000000000000000000000000000000000000000000000000000000000000
      000000000000000000000000000000000000000000000000000000031' as blob(10K)))
      Lock : ROW, SYSCOLUMNS, (5,16)
      Waiting XID : {147655, X} , NSTEST, insert into nstesttab (id, t_char, t_date
      , t_decimal, t_decimal_nn, t_double, t_float, t_int, t_longint, t_numeric_large
      , t_real, t_smallint, t_time, t_timestamp, t_varchar,t_clob,t_blob) values ( ?,
      ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?,cast('000000000000000000000000000000000
      31' as clob(1K)),cast(X'00000000000000000000000000000000000000000000000000000000
      00000000000000000000000000000000000000000000000000000000000000000000000000000000
      00000000000000000000000000000000000000000000000000000031' as blob(10K)))
      Lock : ROW, SYSCOLUMNS, (5,16)
      Waiting XID : {61356, X} , NSTEST, insert into nstesttab (id, t_char, t_date,
      t_decimal, t_decimal_nn, t_double, t_float, t_int, t_longint, t_numeric_large,
      t_real, t_smallint, t_time, t_timestamp, t_varchar,t_clob,t_blob) values ( ?, ?
      , ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?,cast('0000000000000000000000000000000003
      1' as clob(1K)),cast(X'000000000000000000000000000000000000000000000000000000000
      00000000000000000000000000000000000000000000000000000000000000000000000000000000
      0000000000000000000000000000000000000000000000000000031' as blob(10K)))
      . The selected victim is XID : 1174407.
      at org.apache.derby.impl.jdbc.SQLExceptionFactory40.getSQLException(Unkn
      own Source)
      at org.apache.derby.impl.jdbc.Util.generateCsSQLException(Unknown Source
      )
      at org.apache.derby.impl.jdbc.TransactionResourceImpl.wrapInSQLException
      (Unknown Source)
      at org.apache.derby.impl.jdbc.TransactionResourceImpl.handleException(Un
      known Source)
      at org.apache.derby.impl.jdbc.EmbedConnection.handleException(Unknown So
      urce)
      at org.apache.derby.impl.jdbc.ConnectionChild.handleException(Unknown So
      urce)
      at org.apache.derby.impl.jdbc.EmbedStatement.executeStatement(Unknown So
      urce)
      at org.apache.derby.impl.jdbc.EmbedPreparedStatement.executeStatement(Un
      known Source)
      at org.apache.derby.impl.jdbc.EmbedPreparedStatement.executeUpdate(Unkno
      wn Source)
      at org.apache.derbyTesting.system.nstest.utils.DbUtil.add_one_row(DbUtil
      .java:201)
      at org.apache.derbyTesting.system.nstest.tester.TesterObject.doIUDOperat
      ion(TesterObject.java:148)
      at org.apache.derbyTesting.system.nstest.tester.Tester1.startTesting(Tes
      ter1.java:118)
      at org.apache.derbyTesting.system.nstest.NsTest.run(NsTest.java:551)
      Caused by: java.sql.SQLException: A lock could not be obtained due to a deadlock
      , cycle of locks and waiters is:
      Lock : ROW, SYSCOLUMNS, (5,16)
      Waiting XID : {1174407, S}

      , NSTEST, insert into nstesttab (id, t_char, t_dat
      e, t_decimal, t_decimal_nn, t_double, t_float, t_int, t_longint, t_numeric_larg
      e, t_real, t_smallint, t_time, t_timestamp, t_varchar,t_clob,t_blob) values ( ?,
      ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?,cast('00000000000000000000000000000000
      031' as clob(1K)),cast(X'0000000000000000000000000000000000000000000000000000000
      00000000000000000000000000000000000000000000000000000000000000000000000000000000
      000000000000000000000000000000000000000000000000000000031' as blob(10K)))
      Granted XID :

      {61356, S}

      ,

      {75588, S}

      ,

      {147655, S}

      ,

      {204335, S}

      , {460963, S
      } ,

      {511711, S}

      ,

      {565264, S}

      ,

      {727656, S}

      ,

      {791364, S}

      ,

      {1133117, S}

      Lock : ROW, SYSCOLUMNS, (5,16)
      Waiting XID :

      {1133117, X}

      , NSTEST, insert into nstesttab (id, t_char, t_dat
      e, t_decimal, t_decimal_nn, t_double, t_float, t_int, t_longint, t_numeric_larg
      e, t_real, t_smallint, t_time, t_timestamp, t_varchar,t_clob,t_blob) values ( ?,
      ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?,cast('00000000000000000000000000000000
      031' as clob(1K)),cast(X'0000000000000000000000000000000000000000000000000000000
      00000000000000000000000000000000000000000000000000000000000000000000000000000000
      000000000000000000000000000000000000000000000000000000031' as blob(10K)))
      Lock : ROW, SYSCOLUMNS, (5,16)
      Waiting XID :

      {147655, X}

      , NSTEST, insert into nstesttab (id, t_char, t_date
      , t_decimal, t_decimal_nn, t_double, t_float, t_int, t_longint, t_numeric_large
      , t_real, t_smallint, t_time, t_timestamp, t_varchar,t_clob,t_blob) values ( ?,
      ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?,cast('000000000000000000000000000000000
      31' as clob(1K)),cast(X'00000000000000000000000000000000000000000000000000000000
      00000000000000000000000000000000000000000000000000000000000000000000000000000000
      00000000000000000000000000000000000000000000000000000031' as blob(10K)))
      Lock : ROW, SYSCOLUMNS, (5,16)
      Waiting XID :

      {61356, X}

      , NSTEST, insert into nstesttab (id, t_char, t_date,
      t_decimal, t_decimal_nn, t_double, t_float, t_int, t_longint, t_numeric_large,
      t_real, t_smallint, t_time, t_timestamp, t_varchar,t_clob,t_blob) values ( ?, ?
      , ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?,cast('0000000000000000000000000000000003
      1' as clob(1K)),cast(X'000000000000000000000000000000000000000000000000000000000
      00000000000000000000000000000000000000000000000000000000000000000000000000000000
      0000000000000000000000000000000000000000000000000000031' as blob(10K)))
      . The selected victim is XID : 1174407.
      at org.apache.derby.impl.jdbc.SQLExceptionFactory.getSQLException(Unknow
      n Source)
      at org.apache.derby.impl.jdbc.SQLExceptionFactory40.wrapArgsForTransport
      AcrossDRDA(Unknown Source)
      ... 13 more

      Attachments

        Issue Links

          Activity

            People

              Unassigned Unassigned
              myrna Myrna van Lunteren
              Votes:
              0 Vote for this issue
              Watchers:
              1 Start watching this issue

              Dates

                Created:
                Updated:
                Resolved: