Skip site navigation (1)Skip section navigation (2)
Date:      Sun, 29 Apr 2007 16:43:49 -0300
From:      Patrick Tracanelli <eksffa@freebsdbrasil.com.br>
To:        current@freebsd.org
Cc:        Ivan Voras <ivoras@fer.hr>
Subject:   My experies with gvirstor
Message-ID:  <4634F575.4010905@freebsdbrasil.com.br>

next in thread | raw e-mail | index | archive | help
Here is what I got as my experiences with gvirstor so far.

With kern.geom.virstor.debug=15 get really slow. While accessing
(newfs'ing) /dev/virstor/home system starts to get 98% of CPU cycles. No
problem after all, just mentioning in case this shouldnt happen.

With a 40GB device I cannot create a 2TB virtual gvirstor device. While 
in newfs, in a certain moment I get:

...
...
...
  3542977888, 3543354240, 3543730592, 3544106944, 3544483296, 3544859648,
3545236000, 3545612352, 3545988704, 3546365056,
  3546741408, 3547117760, 3547494112,

and it STOPS. Checking for debug I can find out that BIO Delaying is
working, because I get:

GEOM_VIRSTOR[1]: All physical space allocated for home
GEOM_VIRSTOR[2]: Delaying BIO (size=65536) until free physical space can
be found on virstor/home

If I ./gvirstor add home ad4s1, things start to work back. But ad4s1 is
way too small and Is not enough. But at least a 1G device I can create:

/dev/virstor/home    946G    4.0K    870G     0%    /usr/home4

So my question, how can I make the math to find out how much real space 
I will need to create a gvirstor device sized N?

# ./gvirstor status home
         Name             Status  Components
virstor/home  43% physical free  ad2s1

Since it is a 40GB devie, something close to 34GB was used to store
structure of a 1TB device. Is this usage related to the chunk size?

Anyway I still adding and removing disks from the gvirstor

         Name             Status  Components
virstor/home  91% physical free  ad2s1
                                  ad0s2d
                                  ggate0

I am also importing ggate devices into gvirstor wihtout problems. It is 
amazing that it works since it gives us teorically ilimited storage 
space. In a single machine we are limited at number of disks. But with 
multiple machines importing ggate exports, it seems amazingly.

however, if I export gvirstor device, the other side (ggate client) can
only import it if it is umounted in the local machine (the one where
gvirstor resides):

/dev/ggate0    946G    4.0K    870G     0%    /mnt

If I try to mount it, I get:

# mount /dev/virstor/home /usr/home4
mount: /dev/virstor/home: Operation not permitted

And, if I try to export a mounted gvirstor device, ggated starts fine:

# ggated -v
info: Reading exports file (/etc/gg.exports).
debug: Added 10.69.69.69/32 /dev/md0 RW to exports list.
debug: Added 10.69.69.69/32 /dev/virstor/home RW to exports list.
info: Exporting 2 object(s).
info: Listen on port: 3080.

But on remote side:

# ggatec create -v -o rw 10.69.69.1 /dev/virstor/home
info: Connected to the server: 10.69.69.1:3080.
debug: Sending version packet.
debug: Sending initial packet.
debug: Receiving initial packet.
debug: Received initial packet.
info: Connected to the server: 10.69.69.1:3080.
debug: Sending version packet.
debug: Sending initial packet.
debug: Receiving initial packet.
debug: Received initial packet.
error: ggatec: ioctl(/dev/ggctl): Invalid argument.

And, back on the server side, ggated:

error: Cannot open /dev/virstor/home: Operation not permitted.
debug: Connection removed [10.69.69.69 /dev/virstor/home].
warning: Cannot send initial packet: Bad file descriptor.

Thatīs bad fun :( I thought I could do more lego play. This seems like 
the same problem I had in the past, trying to export a mounted gmirror 
device.

Its probably a ggate limitation.

Anyways, this is again, just to report the experiences I had by now.

Up to now I didnt get panics or unexpected behavior.

With this command:


# dd if=/dev/zero of=/usr/home4/40G.bin count=40000 bs=1024k


While running

iostat -w1 ad0 ad2

I can see there is no performance difference comparing writings to the 
ad provider or to a gvirstor provider. I can also see that the disk 
usage is one provider each time. I only get activiry on ad0 when ad2 has 
ended up its space. gstat shows me the same thing.

However, let me ask something. Is metadata information updated 
synchronously?

I ask it because removing /usr/home4/40G.bin (rm /usr/home4/40G.bin) 
takes about 1 and a half minute to finish (newfs was made with -U flag).

I will do some more testings during the week.







Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?4634F575.4010905>