The order of resources in the manifest doesn't matter. Puppet will build a
graph from all resources and dependencies and executes resources from the
same level randomly.
You need something like this:
exec { "start":
path =>
"/usr/local/sbin/:/usr/local/jdk/bin:/bin:/sbin:/usr/sbin:/usr/bin",
command => '/usr/local/sbin/control.sh start',
refreshonly => true,
logoutput => true,
require => [File['/usr/local/sbin/control.sh'], Exec['stop'],
}
On Fri, Sep 19, 2014 at 8:59 PM, Jake Lundberg <[email protected]>
wrote:
> Puppet 3.6.2
>
> First, I understand that Execs try not to run multiple times if called
> many times by many resources and typically wait until they've all been
> "collected" from all resources, but I have a specific case where I need
> different Execs to run in a particular order based on a set of resources
> that change.
>
> The basic pattern is:
> 1. Install/update Configuration file (configuration gets updated on all
> version changes)
> 2. Stop Exec script subscribes to Configuration file
> 3. Package Install/update notifies Start Exec script
> 4. Package requires Configuration file
>
> The basic resource ordering in the manifest looks like:
>
> require foo::config # This contains the File['Config'] resource
>
> #This might be redundant, but trying to force this relationship
> File['Config'] -> Package["foo"]
>
> package { ["foo"]:
> ensure => "${version}-${release}",
> notify => Exec['start']
> }
>
> # Start, stop, restart functions for ads server
> file {"/usr/local/sbin/control.sh":
> source => "puppet:///modules/foo/control.sh",
> ensure => present,
> owner => root,
> group => root,
> mode => 0744,
> }
>
> exec { "stop":
> path =>
> "/usr/local/sbin/:/usr/local/jdk/bin:/bin:/sbin:/usr/sbin:/usr/bin",
> command => '/usr/local/sbin/control.sh stop',
> refreshonly => true,
> logoutput => true,
> subscribe => File['Config'],
> require => File['/usr/local/sbin/control.sh']
> }
>
> exec { "start":
> path =>
> "/usr/local/sbin/:/usr/local/jdk/bin:/bin:/sbin:/usr/sbin:/usr/bin",
> command => '/usr/local/sbin/control.sh start',
> refreshonly => true,
> logoutput => true,
> require => File['/usr/local/sbin/control.sh']
> }
>
>
> However, when puppet apply runs this is what happens:
>
> 1. Configuration file is installed/updated, schedules a refresh of Stop
> Exec
> 2. Package is installed, schedules refresh of Start Exec
> 3. Start Exec runs
> 4. Stop Exec runs
>
> There's probably a better way of doing this (possibly with run stages),
> I'm just curious why this plan does not work. I'm very open to
> improvements.
>
> --
> You received this message because you are subscribed to the Google Groups
> "Puppet Users" group.
> To unsubscribe from this group and stop receiving emails from it, send an
> email to [email protected].
> To view this discussion on the web visit
> https://groups.google.com/d/msgid/puppet-users/b892a4d6-4356-40ab-95a2-ab8ca218e2d1%40googlegroups.com
> <https://groups.google.com/d/msgid/puppet-users/b892a4d6-4356-40ab-95a2-ab8ca218e2d1%40googlegroups.com?utm_medium=email&utm_source=footer>
> .
> For more options, visit https://groups.google.com/d/optout.
>
--
You received this message because you are subscribed to the Google Groups
"Puppet Users" group.
To unsubscribe from this group and stop receiving emails from it, send an email
to [email protected].
To view this discussion on the web visit
https://groups.google.com/d/msgid/puppet-users/CAMo7R_dpewoWCivC-9N_0TKkNfZVy63RL3YStpHR6juoH5Fo_Q%40mail.gmail.com.
For more options, visit https://groups.google.com/d/optout.