Uploaded image for project: 'Jackrabbit Oak'
  1. Jackrabbit Oak
  2. OAK-3402

Multiplexing NodeStore support in Oak layer

Details

    • Epic
    • Status: Open
    • Major
    • Resolution: Unresolved
    • None
    • None
    • core
    • Multiplexing Repository

    Description

      Supporting multiplexing repository would have impact on various places in Oak design. There are various sub components in Oak which maintain there own storage built on top of NodeStore. For e.g. indexes are stored within NodeStore, permissions are also stored within NodeStore. Adding multiplexing support would impact such stores in following ways

      The most basic application of multiplexing support is to support private and shared storage. Under this an Oak application would have a private store and a shared store. Content under certain paths would be stored under private repo while all other content is stored under shared repo

      1. Writing - Any content written via JCR API passes through some CommitHooks. These hooks are responsible for updating the indexes, permission store etc. Now if any path say /foo/bar gets modified the commits hooks would need to determine under which path in NodeStore should the derived data (index entries, permission etc) should be stored. For simple case of private and shared store where we have 2 sets of paths private and shared these hooks would need to be aware of that and use different path in NodeStore to store the derived content. Key point to note here that any such storage has to differentiate wether the path from which the content is being derived is a private path or shared path
      1. Reading - Reading requirement compliments the writing problem. While performing any JCR operation Oak might need to invoke QueryIndex, PermissionStore etc. These stores in turn would need to perform a read from there storage area within NodeStore. For multiplexing support these components would then need to be aware that there storage can exist in both shared and private stores

      Terms Used

      1. private repo (PR) - Set of paths which are considered private to the application. Tentative example /lib,/apps
      2. shared repo (SR) - Set of paths which are considered shared and different versions of the application can perform read and write operations on them. Tentative example /content, /etc/workflow/instances
      3. PathToStoreMapper - Responsible for mapping a path to store type. For now it can just answer either PR or SR. But the concept can be generalized

      Aim of this story is to prototype changes in Oak layer in a fork to asses the impact on current implementation

      Attachments

        Issue Links

          Activity

            as already stated in the discussion during the last Oakathon the whole security part in oak is pluggable at runtime and any module may define with it's own RepositoryInitializer, Validator and CommitHook implementations. My gut feeling therefore is that we shall not twist the current default implementations to somehow get it work with this approach but rather make sure all multiplexing parts are treated like a separate repo with their own configuration(s). Also we must not assume that custom implementations are free of 'global' information... so, ultimately I have the feeling that using the composite security setup parts might be better suited for this than bending the existing code to respect the multiplexing.

            angela Angela Schreiber added a comment - as already stated in the discussion during the last Oakathon the whole security part in oak is pluggable at runtime and any module may define with it's own RepositoryInitializer , Validator and CommitHook implementations. My gut feeling therefore is that we shall not twist the current default implementations to somehow get it work with this approach but rather make sure all multiplexing parts are treated like a separate repo with their own configuration(s). Also we must not assume that custom implementations are free of 'global' information... so, ultimately I have the feeling that using the composite security setup parts might be better suited for this than bending the existing code to respect the multiplexing.
            chetanm Chetan Mehrotra added a comment - - edited

            Current prototype is being implemented at https://github.com/chetanmeh/jackrabbit-oak/commits/multiplex-1. All commits having '[multiplex]' in commit message are the changes done as part of this topic (and its subtopics)

            chetanm Chetan Mehrotra added a comment - - edited Current prototype is being implemented at https://github.com/chetanmeh/jackrabbit-oak/commits/multiplex-1 . All commits having ' [multiplex] ' in commit message are the changes done as part of this topic (and its subtopics)

            People

              chetanm Chetan Mehrotra
              chetanm Chetan Mehrotra
              Votes:
              0 Vote for this issue
              Watchers:
              4 Start watching this issue

              Dates

                Created:
                Updated: