Uploaded image for project: 'Cocoon'
  1. Cocoon
  2. COCOON-1977

Unsynchronized access to HashMap in ResourceReader

Details

    • Bug
    • Status: Closed
    • Critical
    • Resolution: Fixed
    • 2.1.9, 2.1.10
    • 2.1.11, 2.2
    • * Cocoon Core
    • None
    • Urgent

    Description

      I've just had a production server lock up, and when I forced a stack trace I saw lots of these:

      "TP-Processor30" daemon prio=5 tid=0x00ce2a50 nid=0x52 runnable [bccfd000..bccffc30]
              at java.util.HashMap.get(HashMap.java:325)
              at org.apache.cocoon.reading.ResourceReader.getLastModified(ResourceReader.java:238)
              at org.apache.cocoon.components.pipeline.AbstractProcessingPipeline.process(AbstractProcessingPipeline.java:468)
              at org.apache.cocoon.components.treeprocessor.sitemap.ReadNode.invoke(ReadNode.java:84)
       etc.

      What I've noticed is that the 'documents' HashMap in ResourceReader (a static member) is accessed in an unsynchronized fashion; neither is documents synchronized, or are the puts and gets to it. This is a potential (and actual!!) hazard, and can lead to crashes or hangs.

      Suggest that line 94 of ResourceReader.java is changed from:

          private static final Map documents = new HashMap();

      to

          private static final Map documents = Collections.synchronizedMap(new HashMap());


      Work-around:
      enable quick-modified-test in configuration which by-passes use of the document URI cache:

      <map:reader logger="sitemap.reader.resource" name="resource" pool-max="32" src="org.apache.cocoon.reading.ResourceReader">
            <quick-modified-test>true</quick-modified-test>
      </map:reader>

      Attachments

        Activity

          joerg.heinicke@gmx.de Jörg Heinicke added a comment -
          I'm wondering what this "caching" does buy us at all? Can somebody tell in which cases the reader is really faster? From what I understand in those cases, when one request.getRequestURI() resolves to different inputSources. I'd remove documents and quickTest completely.
          joerg.heinicke@gmx.de Jörg Heinicke added a comment - I'm wondering what this "caching" does buy us at all? Can somebody tell in which cases the reader is really faster? From what I understand in those cases, when one request.getRequestURI() resolves to different inputSources. I'd remove documents and quickTest completely.
          joerg.heinicke@gmx.de Jörg Heinicke added a comment -
          Fixed as proposed. Thanks for your commitment.
          joerg.heinicke@gmx.de Jörg Heinicke added a comment - Fixed as proposed. Thanks for your commitment.

          People

            joerg.heinicke@gmx.de Jörg Heinicke
            ellispritchard Ellis Pritchard
            Votes:
            0 Vote for this issue
            Watchers:
            0 Start watching this issue

            Dates

              Created:
              Updated:
              Resolved: