On Mon, Jul 11, 2011 at 11:36:58AM +0000, Emmanuel Dreyfus wrote:
> I tried starting up from scratch: stop/delete/create/start the volume.
> I get exactly the same result.

I think I tracked down the problem. It happens in dht_deitransform()
As I understand, this function decides which subvolume is to use given
an offet to readdir. Here is the important code:

        cnt = y % max;
        x   = y / max;
        subvol = conf->subvolumes[cnt];

y is the offset requested in the readdir call, max is the amount of
subvolumes. When I do ls /gfs/misc, two readdir operations are sent, 
and I get this:

        1st call: y = 0, cnt = 0, max = 2, x = 0
        2nd call: y = 776, cnt = 0, max = 2, x = 388

Therefore both readdir calls fetch data from the same subvolume, 
which explains why I never see the files from the other ones.

How is it supposed to work? I suspect there is some assumption on 
what offsets the client will use in readdir operations. Or did 
I misunderstood dht logic?


-- 
Emmanuel Dreyfus
[email protected]

_______________________________________________
Gluster-devel mailing list
[email protected]
https://lists.nongnu.org/mailman/listinfo/gluster-devel

Reply via email to