Thanks for your response. Having "before" in the configtest exec and "notify" in the dhcpd service causes an error about a circular dependency.

Dropping the "notify" but keeping the "before" makes the order work properly, but the configtest doesn't get triggered when the service restarts.

Is there a way to trigger the test when and only when the service restarts, and guaranteed before the service restarts?

The only other idea I've had is to trigger the "notify" from the File declaration of the config file. This isn't really practical for me because some of my daemons have 20+ config files.

Thanks,
Jonathan


On 15/08/11 23:00, Denmat wrote:
Hi,

A couple of ways come to mind. Use the 'before' metaparameter in your 
configtest exec.

You can use ordering syntax '->' between your resources, see 
http://docs.puppetlabs.com/guides/language_guide.html#chaining-resources

See this for a complete overview:
http://docs.puppetlabs.com/learning/ordering.html

Cheers,
Den

On 15/08/2011, at 23:29, Jonathan Gazeley<jonathan.gaze...@bristol.ac.uk>  
wrote:

Hi all,

I'm trying to set up a routine in puppet where if a service is scheduled for a 
restart, eg because of new configs, then a config test is executed first. If 
the config test fails, the service is not restart (and so keeps running with 
the old config, rather than stopping and causing an outage).

So far I've tried this kind of thing:

# DHCP service
service { "dhcpd":
   require =>  [ File["dhcpd.conf"], Package['dhcp'] ],
   ensure =>  running,
   enable =>  true,
   hasstatus =>  true,
   hasrestart =>  true,
   notify =>  Exec['dhcpd-config-test'],
}

# This exec tests the dhcpd config and fails if it's bad
exec { "dhcpd-config-test":
   command =>  '/etc/init.d/dhcpd configtest 2>&1 | grep "Syntax: OK" | wc -l',
   returns =>  0,
   refreshonly =>  true
}


In this context, is it better to use notify or require in the service declaration? Using 
only "notify" seems to not care about the order, and sometimes the 
dhcpd-config-test is executed *after* the dhcpd service has already been restarted, which 
is useless.

Using only "require" doesn't always trigger dhcpd-config-test when dhcpd 
restarts.

Is there a better way of reliably triggering a config test before the service 
restarts, but only when it restarts, and then failing if necessary?

Thanks,
Jonathan

--
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.



--
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.

Reply via email to