Indexing Zlib deflated streams for pseudo-random-access to reduce delta-resolution memory requirements

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi,

Why would one have big files delta compressed anyway ? From my experience, this can save a lot of space, even though the process of generating the deltas will definitely take up a lot of memory. In my use-case the packs are generated on a server with plenty of RAM. And even though the most recent version of an object tends to be a base which wouldn't need delta resolution, querying older revisions will require it. As this is done client side most of the time, it would be great to reduce the memory footprint, at the cost of some additional preprocessing time.

Currently, when reapplying deltas on rather big files, assumed that one didn't exclude them for delta compression in the first place, the current algorithm requires the base-buffer, the target buffer as well as the inflated delta stream itself in memory concurrently. Then the algorithm works its way up recursively from the first base object to the last delta until it is done. This causes plenty of possibly large memory allocations, as well as high memory demands.

In my current python and c++ implementation of pack reading, I try to stream all objects. Base objects can already be very efficiently streamed as a plain (streamed) inflate will do. This is different for delta objects. Even though the delta resolution machinery is hidden behind a stream interface, it still produces a big buffer to hold the resolved object.

My current research went far enough to allow delta streams to be merged together at first, so the last delta to be applied gets merged down onto its base delta, and so forth, until all deltas were merged into one big delta which just applies to the base buffer. This delta will have only copy operations which refer to the base object's data, as well as copy operations. Currently, the merged delta stream is kept in memory deflated, and could be streamed more or less easily. The problem I have is that the base object's data still needs to be available for random access, i.e. inflated in memory.

Although this technique safes some memory during processing, as it will never allocate two possibly large base and target buffers, in the end it turns out to be more expensive memory wise as it needs the base buffer as well as the merged delta to be allocated as long as the streaming is in progress, compared to just the possibly smaller target buffer in case of the default recursive algorithm.

Here comes the link to the subject line: If it was possible to index the zip deflated stream somehow, it wouldn't be required to keep an inflated version of the base buffer in memory all the time. Instead, the required portions can be decompressed on demand, using the said zip stream index. Then we would only need the merged delta stream in memory, which should (ideally) be smaller than the target buffer itself.

Do you think it is feasible to burn these extra cycles to reduce the memory footprint ? Do you know whether or how it is possible to index a zip deflated stream for pseudo-random access or can provide hints ? So far, from studying the zlib manual, there seems to be some way of determining zip blocks which can then possibly be linked to the uncompressed data positions, but ... I am absolutely not sure. Ideally, this whole indexing process works by quickly skipping through the zlib stream without actually decompressing it.

Maybe, all this is too much effort, and maybe the merged delta stream's size ends up being larger than the target buffer so it was all for nothing (which one would only know once the preprocessing time was already spent), but maybe it could really help truly 'stream' deltified objects (which has been something like my holy grail for quite some time now).

Thanks,
Sebastian

--
To unsubscribe from this list: send the line "unsubscribe git" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[Index of Archives]     [Linux Kernel Development]     [Gcc Help]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [V4L]     [Bugtraq]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]     [Fedora Users]