Also, delegations are about caching. That's true. It improve NFS performance because a client with a lease does not need to worry about server change and can manipulate files using local cache. But if speculative execution can achieve the same goal without incurring the cost of lease renewal and revoke, delegation becomes less useful. So my question is essentially: if speculative execution is there, why do we still need delegation? Can delegation do anything better? Xin On 8/10/06, Trond Myklebust <trond.myklebust@xxxxxxxxxx> wrote:
On Thu, 2006-08-10 at 14:02 -0400, Xin Zhao wrote: > Thanks. Trond. > > The device is subject to change when server reboot? I don't quite > understand. If the backing device at the server side is not changed, > how come server reboot will cause device ID change? Things like USB, firewire, and fibre channel allocate their device ids on the fly. There is no such thing as a fixed device id in those cases. > About your comment on the second conclusion, I already explained in > one of my previous email. We assume that both server and clients are > under our control. That is, we don't consider too much about > interoperability. The file handle format will be static even the NFS > server is changed. Actually, in our inter-VM inode sharing scheme, we > don't even care about the normal file handle contents. Instead, we > only check our extended fields, which include: server-side inode > address, ino, dev info, i_generation and server_generation. An NFS > client first uses the server-side inode address to locate the inode > object in the server inode cache (we dynamically remapped the inode > cache into the client, in order to expedite metadata retrieval and > bypass inter-VM communication). After getting the inode object, the > NFS client has to validate this inode object corresponds to the file > handle so that it can read the right file attributes stored in the > inode. There are many possibilities that can cause a located inode > stores false information: the inode has been released because someone > on the server remove the file, the inode was filled by another file's > inode (other possibilities?). So we must validate the inode before > using the file attributes retrieved from the mapped inode. > > That's why we bring up this question. Why do this, when people are working on standards and implementations for doing precisely the above within the NFSv4 protocol? > Also, does someone compare NFS v4's delegation mechanism with the > speculative execution mechanism proposed in SOSP 2005 > http://www.cs.cmu.edu/~dga/15-849/papers/speculator-sosp2005.pdf? > > What are the pros and cons of these two mechanisms? Delegations are all about caching. This paper appears to be about getting round the bottlenecks due to synchronous operations. How are the two issues related? Cheers, Trond
- To unsubscribe from this list: send the line "unsubscribe linux-fsdevel" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html