1. 14 Nov, 2007 1 commit
  2. 07 Nov, 2007 1 commit
  3. 01 Nov, 2007 1 commit
  4. 26 Oct, 2007 1 commit
  5. 25 Oct, 2007 4 commits
  6. 24 Oct, 2007 1 commit
  7. 14 Oct, 2007 1 commit
  8. 04 Oct, 2007 1 commit
  9. 03 Oct, 2007 2 commits
  10. 02 Oct, 2007 1 commit
  11. 01 Oct, 2007 1 commit
  12. 25 Sep, 2007 1 commit
    • stewart@flamingspork.com[stewart]'s avatar
      [PATCH] BUG#30379 Better randomise time before retry in timeout check (DBTC) · 33412d2b
      stewart@flamingspork.com[stewart] authored
      timoOutLoopStartLab() checks if any transactions have been delayed
      for so long that we are forced to perform some action (e.g. abort,
      resend etc).
      
      It is *MEANT* to (according to the comment):
      > To avoid aborting both transactions in a deadlock detected by time-out
      > we insert a random extra time-out of upto 630 ms by using the lowest
      > six bits of the api connect reference.
      > We spread it out from 0 to 630 ms if base time-out is larger than 3 sec,
      > we spread it out from 0 to 70 ms if base time-out is smaller than 300 msec,
      > and otherwise we spread it out 310 ms.
      
      The comment (as all do) lies.
      
      the API connect reference is not very random, producing incredibly
      predictable "random" numbers. This could lead to both txns being
      aborted instead of just one.
      
      Before:
      timeout value: 123 3
      timeout value: 122 2
      timeout value: 122 2
      timeout value: 122 2
      timeout value: 123 3
      
      After:
      timeout value: 127 7
      timeout value: 126 6
      timeout value: 129 9
      timeout value: 139 19
      timeout value: 137 17
      timeout value: 151 31
      timeout value: 130 10
      timeout value: 132 12
      
      Index: ndb-work/ndb/src/kernel/blocks/dbtc/DbtcMain.cpp
      ===================================================================
      33412d2b
  13. 13 Sep, 2007 2 commits
  14. 12 Sep, 2007 2 commits
  15. 29 Aug, 2007 1 commit
  16. 20 Aug, 2007 4 commits
  17. 16 Aug, 2007 1 commit
  18. 15 Aug, 2007 1 commit
  19. 14 Aug, 2007 3 commits
  20. 13 Aug, 2007 3 commits
  21. 08 Aug, 2007 2 commits
  22. 07 Aug, 2007 1 commit
  23. 30 Jul, 2007 1 commit
  24. 27 Jul, 2007 1 commit
  25. 26 Jul, 2007 2 commits