FYI, We ended up going with a mix of the two suggestions: having 'bg' specified as one of the mount point options, and also having the mount resource specify => present instead of => mounted, and then we use an exec to force the remount, constrained by an unless and onlyif:
exec { "remount-storage": command => "mount -a", unless => "grep $brand /proc/mounts", onlyif => "nc -zv $nfs_server 2049 -w 3", } The works for us in all use cases, and seems to be the best way forwards :) - Andrew On Nov 11, 11:03 am, madAndroid <andrewsta...@gmail.com> wrote: > Thank you so much to all who responded - we've managed to rewrite our > classes to use the mount directive rather (and quite quickly and > painlessly), and it seems a much better way than we had before (using > file and exec resources/directives). Still experiencing the timeouts > during the puppet run when the NFS box goes away (in a dev environment > during testing the new class structure), but we haven't tried the two > options that Len suggested - will be giving those a go, with the trade- > offs in mind. Yes, I agree with John that it does feel like more of a > problem with the way we are implementing the mounts, will give those > suggestions a try as well. > > Thanks again, > Andrew > > On Nov 10, 3:10 pm, jcbollinger <john.bollin...@stjude.org> wrote: > > > On Nov 10, 6:02 am, madAndroid <andrewsta...@gmail.com> wrote: > > > > That sounds a little heavy handed ... > > > > also, I feel that it would probably stop the mount from happening at > > > all? > > > how would the fstab initiate the nfs mount if it's not able to resolve > > > the address of the nfs server correctly? > > > unless I'm missing something .. > > > > On Nov 9, 7:12 pm, Guy Matz <gm...@matz.org> wrote: > > > > > OK. This may seem like a bad idea, but it's a workaround that has > > > > worked > > > > for me: > > > > I add the nfs server to the 127.0.0.1 entry of the hosts file which > > > > causes > > > > NFS to time out pretty immediately. :-\ > > > > > On Wed, Nov 9, 2011 at 10:00 AM, madAndroid <andrewsta...@gmail.com> > > > > wrote: > > > > > We've only recently discovered that puppet can manage mount points > > > > > using the mount directive; > > > > > however, a short while back we built annfs clientand server classes > > > > > without using this resource, and we've encountered a problem where > > > > > puppet seems to hang when the nfs server is unavailable. > > > > > > Using --debug doesn't seem to specify exactly at which point the run > > > > > is failing, which could steer us in the right direction around putting > > > > > something in place in the classes in question. > > > > > > Is there anything we can do, short of switching over to using the > > > > > mount directive/resource, in order to mitigate the problem when the > > > > > nfs server is unavailable? It's preventing us from managing other > > > > > resources on the clients when this happens.. > > > It all comes down to mount options. I'd recommend you absorb the > > material in nfs(5), but options of particular interest include > > 'retry', 'retrans', and 'timeo'. Do notice that the latter two will > > affect all operations on the mounted filesystem, not just the initial > > mount (and maybe not the initial mount at all -- the docs aren't quite > > clear on that). > > > Unlike Len, I would not recommend using the "bg" option. Doing so > > likely would prevent Puppet from hanging for a long time attempting > > the mount, but it would also prevent Puppet from correctly managing > > the resource. Puppet needs to know whether it has succeeded in > > mounting the remote filesystem. It may also cause you trouble later > > if the client never does succeed in mounting the filesystem. > > > John > > -- You received this message because you are subscribed to the Google Groups "Puppet Users" group. To post to this group, send email to puppet-users@googlegroups.com. To unsubscribe from this group, send email to puppet-users+unsubscr...@googlegroups.com. For more options, visit this group at http://groups.google.com/group/puppet-users?hl=en.