On Mon, Dec 21, 2009 at 11:27 AM, Douglas Garstang
<doug.garst...@gmail.com> wrote:
> On Mon, Dec 21, 2009 at 7:44 AM, Matthew Hyclak <hyc...@gmail.com> wrote:
>> On Sun, Dec 20, 2009 at 7:17 PM, Douglas Garstang
>> <doug.garst...@gmail.com> wrote:
>>> On Sun, Dec 20, 2009 at 1:58 PM, Douglas Garstang
>>> <doug.garst...@gmail.com> wrote:
>>>> On Sun, Dec 20, 2009 at 4:57 AM, R.I.Pienaar <r...@devco.net> wrote:
>>>>> hello,
>>>>>
>>>>> ----- "Douglas Garstang" <doug.garst...@gmail.com> wrote:
>>>>>
>>>>>> I'd like to be able to split out my puppet production and test
>>>>>> environments so that I can continue to develop puppet
>>>>>> modules/manifests without breaking production. How are people doing
>>>>>> this? Puppet environments may be one way. I guess I'd have a
>>>>>> main(prod) environment and a test one. When I was finished with
>>>>>> testing, I could rsync the files over to the prod environment. Is
>>>>>> this
>>>>>> how others are doing it?
>>>>>
>>>>> http://www.devco.net/archives/2009/10/10/puppet_environments.php
>>>>>
>>>>> That's how I do it, aim is to avoid many copies of the same module just 
>>>>> because we have multiple environments, but still have the ability to 
>>>>> create those versions during the dev cycle.
>>>>>
>>>>> not for everyone, but maybe it help you in the right direction.
>>>>
>>>> Thanks to everyone for the replies.
>>>>
>>>> Are you using multiple environments though? And, if using multiple
>>>> environments, how do you structure it? The puppet documentation is a
>>>> bit vague on the subject. For instance, it's not clear to me if you
>>>> would structure it so that you have a top level dir ABOVE puppet
>>>> called prod, test etc, or if you would create subdirs BELOW manifests,
>>>> modules etc called prod, test.
>>>>
>>>> The next question is, where do you branch? If you have a top level dir
>>>> above puppet, I guess that's pretty easy, but if you have multiple
>>>> dirs below manifests, modules etc, then you'd need to branch each
>>>> which becomes more complex.
>>>
>>> Hmmm. I'm not following this here. At the moment I have /etc/puppet,
>>> which is a working copy. Every now and then I commit my changes. I can
>>> add a dev environment to this working copy and safely use that to test
>>> modules and manifests on dev nodes, but there's still no way for me to
>>> roll those changes back to the production environment without some
>>> manual process.
>>>
>>> I could make a branch of /etc/puppet, and check it out, but then I'd
>>> need a second copy of puppetmaster running in a second location to
>>> test it against. I'm using passenger, so maybe I could fire up a
>>> second instance on another port, and maybe that would work.
>>>
>>> If I was to branch the prod dir inside puppet into a dev dir, then
>>> this is kind of where I get lost. If I was to branch /etc/puppet/dev
>>> or simialar, once again I'd need to check it out into a new location
>>> where I could work on it, and test it. This still needs a second copy
>>> of puppetmaster running, and it's actually worse this way because I
>>> don't have all the necessary puppet config from further up the tree.
>>>
>>> Grrrr.
>>>
>>> --
>>>
>>> You received this message because you are subscribed to the Google Groups 
>>> "Puppet Users" group.
>>> To post to this group, send email to puppet-us...@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.
>>>
>>>
>>>
>>
>> We handle this as follows:
>>
>> Puppetmaster has /etc/puppet, /etc/puppet-development,
>> /etc/puppet-staging (among others)
>>
>> /etc/puppet-development -> svn checkout of trunk, updated whenever we
>> feel like it
>> /etc/puppet-staging -> svn checkout of a tag, updated Tuesdays
>> /etc/puppet -> svn checkout of a tag, updated Thursdays (allows 2 days
>> of testing a tag in Staging)
>>
>> puppet.conf contains (in addition to the standard stuff):
>>
>> [staging]
>>    modulepath = /etc/puppet-staging/modules:/etc/puppet-staging/services
>>    manifest = /etc/puppet-staging/manifests/site.pp
>>
>> [development]
>>    modulepath =
>> /etc/puppet-development/modules:/etc/puppet-development/services
>>    manifest = /etc/puppet-development/manifests/site.pp
>
> So, Matt, it looks like you have three completely different puppet
> areas (/etc/puppet, /etc/puppet-development and so on). That's kind of
> what I thought I might need to do. There's no point in branching a
> specific directory inside puppet because then you don't have the rest
> of the stuff puppet needs to run, and... I'm not sure how svn feels
> about a branch INSIDE a working copy.
>
> But... how do you serve up those multiple puppet environments? Are you
> running multiple versions of the puppetmaster? I'm using passenger so
> it would seem like it would be fairly easy to run additional
> puppetmasters on different ports, except that I can't find where in
> the passenger config I can change the default /etc/puppet (it's not in
> the conf.d/puppetmaster.conf file).
>
> With multiple puppetmasters running, you would also need to configure
> each client to use a different port. I guess.... that's.... ok as long
> as you aren't changing the role of nodes from dev to prod and back.
>

There is one puppetmaster (well, mongrel) listening on 8140.
Environments are built in to puppet, so you don't have to do anything
different. We have a different client puppet.conf for each environment
that specifies the right paths. Changing a client from one environment
to another is as simple as "puppetd -t --environment=newenvironment"

Matt

--

You received this message because you are subscribed to the Google Groups 
"Puppet Users" group.
To post to this group, send email to puppet-us...@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