[pve-devel] [PATCH storage] workaround zfs create -V error for unaligned sizes

Mira Limbeck m.limbeck at proxmox.com
Fri Mar 29 10:12:13 CET 2019


Oh, forget this one, forgot to commit the updated code. Sending a v2

On 3/29/19 10:11 AM, Mira Limbeck wrote:
> fixes the 'cannot create '...': volume size must be a multiple of
> volume block size' error by always rounding the size up to the next 1M
> boundary. this is a workaround until
> https://github.com/zfsonlinux/zfs/issues/8541 is solved.
> the current manpage says 128k is the maximum blocksize, but a local test
> showed that values up to 1M are allowed. it might be possible to
> increase it even further (see f1512ee61).
>
> Signed-off-by: Mira Limbeck <m.limbeck at proxmox.com>
> ---
>   PVE/Storage/ZFSPoolPlugin.pm | 7 ++++++-
>   1 file changed, 6 insertions(+), 1 deletion(-)
>
> diff --git a/PVE/Storage/ZFSPoolPlugin.pm b/PVE/Storage/ZFSPoolPlugin.pm
> index 6e08457..246c0f1 100644
> --- a/PVE/Storage/ZFSPoolPlugin.pm
> +++ b/PVE/Storage/ZFSPoolPlugin.pm
> @@ -309,7 +309,12 @@ sub zfs_get_pool_stats {
>   
>   sub zfs_create_zvol {
>       my ($class, $scfg, $zvol, $size) = @_;
> -
> +
> +    # always align size to 128k as workaround until
> +    # https://github.com/zfsonlinux/zfs/issues/8541 is solved
> +    my $padding = (128 - $size % 128) % 128;
> +    $size = $size + $padding;
> +
>       my $cmd = ['create'];
>   
>       push @$cmd, '-s' if $scfg->{sparse};




More information about the pve-devel mailing list