The kind of thing I was thinking of was selecting where to run jobs by
puppet class, or even requiring that certain classes are assigned to certain
nodes (requiring a pre-req class before you actually send over a job to
build).  In my mind I envisioned extensions to something like Foreman where
you can get a list of jobs that are valid for each node by clicking the node
(in a job you could apply constraints like only boxes with mysql::server and
> 4G of ram).

Another example of the kinds of terrible stuff I engineer when left to my
own devices is I wrote a job in rundeck that at the end wrote a .pp to /tmp/
and called it so that I could use templates in Puppet to build the
configuration file to distribute.  Basically a lot of the time I just need a
way to trigger one time puppet manifests with a gui of some kind I can give
to developers.  I could very easily just spit a few scripts onto the boxes
and call those for the build, I just want a way to enable/disable the jobs.

I can't think of any other good way to say "do a one time run of
project::build_core on the following matching nodes: x, y, z".  I am really
just using rundeck for the equivalent of that.  Other things I would think
of using this for is handling deploying a bunch of servers where server 1
has to be fully provisioned before 2 and on 2 at least one service has to be
up before 3 can do its thing.  It's something that's still a hassle to do
well within Puppet.

On Tue, Sep 13, 2011 at 4:07 PM, Brian Gupta <brian.gu...@brandorr.com>wrote:

> If you want something simple and don't need a GUI, many folks are using
> either Capistrano (Ruby) or the very similar Fabric (Python) for deployment.
> You can populate hostlists via Foreman queries. That said, I am not sure
> what sort of integration with Puppet/Foreman you are looking for.
>
> Cheers,
> Brian
>
> On Tue, Sep 13, 2011 at 3:53 PM, Ashley Penney <apen...@gmail.com> wrote:
>
>> I know this has come up on the list numerous times before but I
>> thought it would be a good time to see if the state of the art has
>> advanced for this kind of thing.  I wanted to know how people are
>> handling higher level deployment of applications - things that have to
>> be done repeatedly but not all the time.  An example of this is
>> checking an application out of svn, building it, creating a package
>> and then moving it off to a repo.  Or even just building/installing
>> locally for developers.
>>
>> It never seems to fit well into Puppet for me and I end up with crazy
>> complicated manifests to deal with this kind of thing.  I recently
>> moved these jobs into Rundeck (www.rundeck.org) which works pretty
>> well but doesn't really leverage any of the stuff I have within
>> Foreman/Puppet.  I've seen suggestions to use mcollective but this
>> doesn't easily integrate our existing scripts (written in many
>> languages) or processes and would require me to force a lot of
>> developers to work differently.  I could just have classes that
>> trigger scripts only when some condition is met (like /.buildapp
>> files) or something along those lines but nothing seems elegant.
>>
>> What I'm trying to find out is what other people did to handle this?
>> I want something I can build up over time and slowly migrate legacy
>> apps and processes into without having to do a massive up front
>> development.  It should also be relatively simple and not require me
>> to code anything as anyone on the list who knows me can tell you that
>> I am absolutely awful at coding.
>>
>> --
>> 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.
>>
>>
>
>
> --
> <http://aws.amazon.com/solutions/solution-providers/brandorr/>
>
>  --
> 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