Skip site navigation (1)Skip section navigation (2)
Date:      Sun, 3 Sep 2017 13:51:38 +1000
From:      Jason Tubnor <jason@tubnor.net>
To:        Ruben <mail@osfux.nl>
Cc:        "freebsd-virtualization@freebsd.org" <freebsd-virtualization@freebsd.org>
Subject:   Re: bhyve VM drive size limit?
Message-ID:  <CACLnyC%2BpvLNyU4LV6GAaA-WEEkyEDxQebWLnUD_OF0V2NVJd-w@mail.gmail.com>
In-Reply-To: <147e2841-bb29-1fe6-11cc-917f22bf8e87@osfux.nl>
References:  <F11DB42E-B903-42B2-B1FA-0649BE86C0B7@host852.com> <CACLnyC%2ByGV29p32_HtzszHfgYNVS5uyRdhnG6315OtOpTJYNZQ@mail.gmail.com> <CACLnyCKimVH1jJ%2BBhF86Vo1Oq1Uj2byUi6x-ZDqwB-tbpE1-0g@mail.gmail.com> <CACLnyCJ7iyvE8_v_OXrAg1aMiUfv4B2jeX6_bsjEL4AuC=GYZA@mail.gmail.com> <147e2841-bb29-1fe6-11cc-917f22bf8e87@osfux.nl>

next in thread | previous in thread | raw e-mail | index | archive | help
Hi Ruben,

On 3 September 2017 at 00:52, Ruben <mail@osfux.nl> wrote:

>
> Perhaps slightly off-topic, but might you have any recommendations
> regarding those blocksizes?
>

I use 8k zvol block sizes.  This seems to work consistently for me with
OpenBSD and Windows Server 2016 guests.  While you could probably go
larger, it really depends on your use case and how the data intends to move
around in the guest.  Some people have had performance issues with 8k
blocks, however, I am yet to experience this.  Chyves by default used 512
byte block sizes, this is sub-optimal for a guest with > 9GB storage needs,
so I change the default settings back to 8k.

>
> I'm not really that well versed in blocksizes / filesystems and am often
> wondering where my 5TB zvol (bhyves into an ext4 volume for an ubuntu
> guest) exactly disappears into :P


For the above, I have experienced where block sizes were defined at 512
bytes, the associated block checksums would eat up the storage, just as
quick as the data being committed to the zvol (even more so as the
snapshots pile up).  Increasing the zvol block size increased the storage
to checksum ratio, reducing how much the checksum overhead had an affect on
the storage.  Keep in mind, this is with a zmirror, so mileage may vary
with raidz or raidz2 setups.  Another thing to keep in mind, as you
increase the block size, this can have performance impacts on the guest as
a 4k update in the guest filesystem, would but upwards pressure on array
performance if you used say 32-64k blocks (rewriting > 32x the
data+checksum calcs).

I suggest trying different sizes for the same workload you plan to commit
to the guest storage to see which has the best storage to performance ratio.

Cheers,

Jason.

P.S.  In the above, I wouldn't commit the 5TB to the guest in one hit.
Either grow it out as you need it or add additional zvols to your guest as
needed.



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?CACLnyC%2BpvLNyU4LV6GAaA-WEEkyEDxQebWLnUD_OF0V2NVJd-w>