cvs commit: src/sys/nfsclient nfs_vnops.c
Robert Watson
rwatson at FreeBSD.org
Sat Jan 12 14:26:12 PST 2008
On Sat, 29 Dec 2007, Adam McDougall wrote:
> Can this be merged to 6 as well? I've been running the patch ported to
> 6-stable for a while with no problems. Thanks.
Adam,
Sorry for the delay in responding -- I'll merge this to 6-STABLE after
6.3-RELEASE is over and done with.
Robert N M Watson
Computer Laboratory
University of Cambridge
>
> On Tue, Nov 27, 2007 at 12:20:59PM +0000, Robert Watson wrote:
>
> rwatson 2007-11-27 12:20:59 UTC
>
> FreeBSD src repository
>
> Modified files: (Branch: RELENG_7)
> sys/nfsclient nfs_vnops.c
> Log:
> Merge nfs_vnops.c:1.277 from HEAD to RELENG_7:
>
> Remove hacks from the NFSv2/3 client intended to handle a lack of a
> server-side RPC retranmission cache for non-idempotent operations: these
> hacks substituted 0 (success) for the expected EEXIST in the event that
> a target name already existed for LINK, SYMLINK, and MKDIR operations,
> under the assumption that EEXIST represented a second application of the
> original RPC rather than a true failure.
>
> Background: certain NFS operations (in this case, LINK, SYMLINK, and
> MKDIR) are not idempotent, as they leave behind persisting state on the
> server that prevents them from being replayed without an error;if an UDP
> RPC reply is lost leading to a retransmission by theclient, the second
> reply will return EEXIST rather than success, asthe new object has
> already been created. The NFS client previouslysilently mapped the
> EEXIST return into success to paper over thisproblem.
>
> However, in all modern NFS server implementations, a reply cache is kept
> in order to retransmit the original reply to a retransmitted request,
> rather than performing the operation a second time, allowing this hack
> to be avoided. This allows link()-based filelocking over NFS to operate
> correctly, as an application requestingthe creation of a new link for a
> file to tell if it succeededatomically or not.
>
> Other NFS clients, including Solaris and Linux, generally follow this
> behavior for the same reasons. Most clients also now default to TCP,
> which also helps avoid the issue of retransmitted but non-idempotent
> requests in most cases.
>
> Reported by: Adam McDougall <mcdouga9 at egr dot msu dot edu>,
> Timo Sirainen <tss at iki dot fi>
> Reviewed by: mohans
>
> Approved by: re (kensmith)
>
> Revision Changes Path
> 1.276.2.1 +4 -25 src/sys/nfsclient/nfs_vnops.c
> _______________________________________________
> cvs-src at freebsd.org mailing list
> http://lists.freebsd.org/mailman/listinfo/cvs-src
> To unsubscribe, send any mail to "cvs-src-unsubscribe at freebsd.org"
>
>
More information about the cvs-src
mailing list