Ian Boston created SLING-6027:
---------------------------------

             Summary: Support existing Chunked upload functionality in 
streaming mode.
                 Key: SLING-6027
                 URL: https://issues.apache.org/jira/browse/SLING-6027
             Project: Sling
          Issue Type: Bug
          Components: Servlets
    Affects Versions: Servlets Post 2.3.12
            Reporter: Ian Boston


The non streaming uploads support a  partial upload protocol implemented in 
request parameters that is known in Sling terms as "Chunked" upload and 
documented at 
https://cwiki.apache.org/confluence/display/SLING/Chunked+File+Upload+Support  
(not to be confused with Chunked Transfer encoding or the use of Http Range 
headers).

Sling Chunked uploading sends a sequence of POSTs containing multiple parts of 
a file upload. When all the parts are uploaded a final request is sent that 
causes all the parts to be merged into a single file in the JCR. From a 
streaming point of view, each part can be streamed with the streaming 
implementation supported by SLING-5948. Some additional code will be required 
to set the file name appropriately and the struture.

However, when the upload is completed, Sling must merge all the parts. To 
maintain the streaming nature of the upload, this must be achieved without 
incurring any local IO, otherwise the benefits of a streamed upload are lost.

I am not certain how to achieve the merge given the limitations of the JCR API 
other than by transferring all the body parts via the local JVM. That won't 
incur local Disk IO but will multiply the overall IO requirement by 3x.

If JCR/Oak had the functionality to concatenate Binaries it could do this more 
efficiently depending on the DS implementation. If JCR/Oak exposed an Seekable 
OutputStream the Application could avoid needing to save uploads to the JCR as 
individual files. If JCR/Oak allowed an update to a binary to start at a known 
location, again this could be avoided.



--
This message was sent by Atlassian JIRA
(v6.3.4#6332)

Reply via email to