These are the release notes for nbdkit stable release 1.26. This describes the major changes since 1.24.
nbdkit 1.26.0 was released on 7 June 2021.
nbdkit is now hosted on gitlab: https://listman.redhat.com/archives/libguestfs/2021-February/msg00021.html
There were no security issues found. All past security issues and information about how to report new ones can be found in nbdkit-security(1).
nbdkit-gzip-plugin and nbdkit-tar-plugin have been removed. They were deprecated in nbdkit 1.22. The functionality has been replaced by nbdkit-gzip-filter(1) and nbdkit-tar-filter(1) respectively.
nbdkit-streaming-plugin(1) has been deprecated and will be removed in nbdkit 1.30. You can use nbdcopy(1) instead.
nbdkit-curl-plugin(1) adds these features:
followlocation=false to disable following redirects.
cookiejar to control saving cookies.
nbdkit-ssh-plugin(1) now advertises multi-conn if the server is OpenSSH, improving performance (Eric Blake).
nbdkit-ondemand-plugin(1) has a new
wait=true flag allowing you to choose between clients waiting for an export to become free or being immediately rejected.
nbdkit-sparse-random-plugin(1) now does not generate fully random data within each block. Using perf we observed that the plugin was spending 34% of the total time during benchmarks just doing this. You can enable the old behaviour using
nbdkit-file-plugin(1) now checks if the file is read-only and exports a read-only NBD connection in this case (Eric Blake).
nbdkit-vddk-plugin(1) has been tested with VDDK 7.0.2.
There is a new API for use by filters to manage “contexts”. Instead of the previous 1-1 relationship between filter connections and plugin connections, filters can now open more than one context into the backend from a single connection, or share contexts between connections (Eric Blake).
New nbdkit-multi-conn-filter(1) which allows you to add multi-conn support to plugins which don't support it (although the emulation is expensive), or change whether multi-conn is advertised to clients (Eric Blake).
nbdkit-cow-filter(1) now ignores flush/FUA requests (which are not useful for a temporary overlay). The filter now implements extents and efficient trimming. Fine-grained locking is used around shared structures, greatly improving parallel performance. Added support for multi-conn.
nbdkit-cache-filter(1) advertises multi-conn when possible (Eric Blake).
nbdkit-cache-filter and nbdkit-cow-filter can now handle arbitrary sized disks, instead of rounding the disk size down.
nbdkit-blocksize-filter(1) supports parallel requests (Eric Blake).
nbdkit-checkwrite-filter(1) supports multi-conn (Eric Blake).
nbdkit-ext2-filter(1) no longer supports multi-conn. The filter is single-threaded so it does not matter, but it was not safe. Fix trim, zero and flush support (Eric Blake).
nbdkit-readahead-filter(1) fixes multi-conn support (Eric Blake).
nbdkit-gzip-filter(1) and nbdkit-xz-filter(1) now both support multi-conn (Eric Blake).
nbdkit-python-plugin(3) supports the following new features:
nbdkit-rust-plugin(3) updated for newer Rust compiler versions (Alan Somers).
nbdkit-golang-plugin(3) now uses and requires golang modules. Golang ≥ 1.13 must be used.
.cleanup callback for plugins and filters. This is called shortly before
.unload, but unlike
.unload it is guaranteed that no plugin or filter code has been dlclosed (Eric Blake).
nbdkit_extents_full is a helper function for filters which can be used to read all extents from a plugin covering a region.
Old plugins that we use for testing were rebuilt so they no longer depend on libselinux (thanks Thomas Weißschuh).
nbdkit-ssh-plugin(1) can still be built even if ssh-keygen is unavailable for testing it (thanks Thomas Weißschuh).
Improve tests/test-captive.sh to avoid crashes during testing.
Test coverage on FreeBSD has been improved, fewer tests should skip unnecessarily.
nbdkit and plugins can now be built with -fvisibility=hidden, which allows the compiler to make some optimizations.
Add a dependency so nbdkit is relinked if the linker script (nbdkit.syms) changes (Eric Blake).
xorriso is now preferred over genisoimage or mkisofs (see https://wiki.debian.org/genisoimage).
It is now possible to compile nbdkit with clang with warnings enabled. Several warnings have been suppressed or fixed.
MALLOC_PERTURB_ are only enabled when running the tests, not when running nbdkit from the build directory. This makes it easier to do benchmarks.
nbdkit_peer_* implemented on OpenBSD.
When fuzzing nbdkit we now recommend using the -t 1 flag (which disables threads). This improves the fuzz-stability of nbdkit.
Authors of nbdkit 1.26:
- Alan Somers
- Eric Blake
- Michael Ablassmeier
- Richard W.M. Jones
- Timm Bäder
Copyright (C) 2021 Red Hat Inc.
Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:
- Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
- Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.
- Neither the name of Red Hat nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission.
THIS SOFTWARE IS PROVIDED BY RED HAT AND CONTRIBUTORS ''AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL RED HAT OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.