[Libguestfs] [PATCH nbdkit 0/2] Rewrite xz plugin as a filter.

Eric Blake eblake at redhat.com
Wed Nov 21 16:29:55 UTC 2018


On 11/21/18 10:17 AM, Richard W.M. Jones wrote:

> Actually I think we are going to need to retain the block cache.  It
> solves a slightly different problem from placing the cache filter on
> top (in fact both are useful).
> 
> Let's say you have an XZ file with a 100,000 byte block size.  Then
> reading two blocks at 0-1000 and 1000-2000 would result in reading and
> uncompressing a whole block twice.  The block cache in the xz
> plugin/filter avoids this; the cache on top does not.
> 
> Interesting factoid: www.mirrorsite.org rapidly throttles any
> connection that makes repeated range requests ...  However if you open
> a new connection it is unaffected by the throttling on the existing
> connection (I thought it would throttle based on IP address).  Anyway
> this, combined with the large block size in the Fedora Cloud image,
> makes xz + curl virtually unusable.
> 
> I also think the new filter would be better if it made larger reads.
> The plugin makes 8K reads (BUFSIZ) which is likely reasonable for
> reading from a local file.  But the overhead of reading from the curl
> plugin probably makes much larger reads sensible.  I wonder if the
> filter can intuit a good block size to use somehow?

Yes, we need to revisit adding block sizing into nbdkit, as filters may 
easily optimize based on preferred blocksize of the lower layer, while 
possibly advertising a different blocksize up to the client.  The 
existing nbdkit-blocksize-filter would then gain some smarts for being 
more useful for controlling sizes between layers (again, back to the 
question of whether we should improve nbdkit filters to allow multiple 
reuse of the same filter on a single plugin).

-- 
Eric Blake, Principal Software Engineer
Red Hat, Inc.           +1-919-301-3266
Virtualization:  qemu.org | libvirt.org




More information about the Libguestfs mailing list