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>