Date: Fri, 3 Jul 2009 15:42:05 -0400 (EDT) From: Rick Macklem <rmacklem@uoguelph.ca> To: Jilles Tjoelker <jilles@stack.nl> Cc: "Bjoern A. Zeeb" <bzeeb-lists@lists.zabbadoz.net>, FreeBSD current mailing list <current@freebsd.org> Subject: Re: Install from NFS onto NFS fails on amd64 Message-ID: <Pine.GSO.4.63.0907031533250.15531@muncher.cs.uoguelph.ca> In-Reply-To: <20090702212505.GA39889@stack.nl> References: <20090702121640.D245@maildrop.int.zabbadoz.net> <20090702122955.J245@maildrop.int.zabbadoz.net> <20090702212505.GA39889@stack.nl>
next in thread | previous in thread | raw e-mail | index | archive | help
On Thu, 2 Jul 2009, Jilles Tjoelker wrote: > > This could be because of NFS "sillyrename". To avoid some ESTALE errors, > the NFS client (for NFSv2 and NFSv3 at least) renames if you delete a > file that is currently in use (in this case, the rm binary). Because the > renamed file (name typically starts with .nfs) is in the same directory, > this causes problems when removing directories. Once the file is no > longer in use, it is finally deleted. > Yes, if some file that was in that directory is still open (or mmap'd and the process hasn't yet exit()'d), it will exist as a file named ".nfsXXX" until the v_usecount goes to 0 and then it's removed, which would explain it. > Maybe NFSv4 has a cleaner way to keep a file with 0 links as long as it > is open. > Afraid not. NFSv4 has an Open, but it is an open share lock and not a POSIX style open, so NFSv4 clients still do the silly rename. (ie. The NFSv4 Remove Op is defined as removing the file and not just unlinking it and the NFSv4 server isn't required to retain the file after removal if it is Open'd by a client.) rick
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?Pine.GSO.4.63.0907031533250.15531>