Uploaded image for project: 'Jackrabbit Content Repository'
  1. Jackrabbit Content Repository
  2. JCR-905

Clustering: race condition may cause duplicate entries in search index

    Details

    • Type: Bug
    • Status: Closed
    • Priority: Major
    • Resolution: Fixed
    • Affects Version/s: 1.2.1, 1.2.2, 1.2.3, 1.3, 1.3.1
    • Fix Version/s: 1.3.3
    • Component/s: clustering
    • Labels:
      None

      Description

      There seems to be a race condition that may cause duplicate search index entries. It is reproducible as follows (Jackrabbit 1.3):
      1) Start clusternode 1 that just adds a single node of node type clustering:test.
      2) Shutdown clusternode 1.
      3) Start clusternode 2 with an empty search index.
      4) Execute the query //element(*, clustering:test).
      4) Print the result of the query (UUIDs of nodes in the result set).

      When I just run clusternode 2, then there is one node in the resultset, as expected. However, when I debug clusternode 2 and have a breakpoint (i.e., a pause of a few seconds at line 306 of RepositoryImpl.java - just before the clusternode is started), then the resultset contains two results, both with the same UUID.

        Attachments

        1. JCR-905.patch
          0.8 kB
          Martijn Hendriks
        2. log1.txt
          1 kB
          Martijn Hendriks
        3. log2.txt
          2 kB
          Martijn Hendriks
        4. SearchManager.patch
          0.8 kB
          Marcel Reutegger

          Issue Links

            Activity

              People

              • Assignee:
                Unassigned
                Reporter:
                martijnh Martijn Hendriks
              • Votes:
                0 Vote for this issue
                Watchers:
                0 Start watching this issue

                Dates

                • Created:
                  Updated:
                  Resolved: