jackrabbit-dev mailing list archives

Site index · List index
Message view « Date » · « Thread »
Top « Date » · « Thread »
From "Marcel Reutegger (JIRA)" <j...@apache.org>
Subject [jira] Commented: (JCR-1117) Bundle cache is not rolled back when the storage of a ChangeLog fails
Date Fri, 20 Feb 2009 13:21:02 GMT

    [ https://issues.apache.org/jira/browse/JCR-1117?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=12675360#action_12675360

Marcel Reutegger commented on JCR-1117:

Wouldn't it make more sense to move the call to clearBundleCache to AbstractBundlePersistenceManager?
In the end any implementation that throws an exception on store(ChangeLog) should ensure the
bundle cache consistency, right?

> Bundle cache is not rolled back when the storage of a ChangeLog fails
> ---------------------------------------------------------------------
>                 Key: JCR-1117
>                 URL: https://issues.apache.org/jira/browse/JCR-1117
>             Project: Jackrabbit Content Repository
>          Issue Type: Bug
>          Components: jackrabbit-core
>    Affects Versions: 1.3, 1.4, 1.5.0, 1.5.2
>            Reporter: Martijn Hendriks
>            Assignee: Martijn Hendriks
>         Attachments: JCR-1117-v2.patch, JCR-1117.patch, stacktrace.txt
> The bundle cache in the bundle persistence managers is not restored to its old state
when the AbstractBundlePersistenceManager.store(ChangeLog changeLog) method throws an exception.
If, for instance, the storage of references fails then the AbstractBundlePersistenceManager.putBundle(NodePropBundle
bundle) method has already been called for all modified bundles. Because of the connection
rollback, the bundle cache will be out-of-sync with the persistent state. As a result, the
SharedItemStateManager will have an incorrect view of the persistent state.
> Furthermore, if the blockOnConnectionLoss property is set to true, then the BundleDbPersistenceManager
can be caught in an infinite loop because of invalid SQL inserts because of an incorrect bundle
cache; see attached stacktrace.

This message is automatically generated by JIRA.
You can reply to this email to add a comment to the issue online.

View raw message