pfs softlinks
Matthew Dillon
dillon at apollo.backplane.com
Mon Apr 5 08:50:23 PDT 2010
:Hey,
:
:> Regular softlinks (e.g. from snapshots) resolve correctly, but for PFS
:> softlinks, the b-tree search won't return anything. What are the
:> parameters I need to set?
:
:Ok I got it! The question is not "pfs or regular softlink", but whether
:the softlink target name exceeds a certain length. For short names (<=
:24 chars), the target name can be found in the `struct
:hammer_inode_data', for longer names a data block has to be retrieved.
:
:PFS links still won't resolve correctly, though. I'm getting this:
:
: lrwxr-xr-x 0 root wheel 10 Jun 7 2009 master -> @@PFS00001
:
:instead of:
:
: lrwxr-xr-x 0 root wheel 10 Jun 7 2009 master ->
:@@0xffffffffffffffff:00001
:
:`hammer_vop_readlink' seems to do some dort of pfs-lookup. I'm working
:on it :)
:
:Daniel
Ah. I should have guessed that was what it was. Yes, you figured
it out.
The actual softlink is, in fact, "@@PFS00001". HAMMER detects
the special name and expands it to the transaction-id for the
actual PFS.
See line 992 hammer_vnops.c and also around line 1730.
The reason we have to do this is primarily for slave PFSs whos
snapshot transaction id changes as the mirroring code updates
the slave. The softlink has to change with it so when you CD
into the softlink you get the 'latest' snapshot.
-Matt
Matthew Dillon
<dillon at backplane.com>
More information about the Hammer
mailing list