Sorry, I have only really given you part of the story haven't I.   We have a 
puppet class hierarchy that we use to specify the various components that need 
to go on a particular type of host - e.g app server or web server or db server. 
A dev machine includes several roles (machines are identified by a -dev suffix 
on the hostname but maybe we could do it based on the environment variable?).  

We use the puppet environment variable to say which environment the machine is 
in.   That in turn decides the config variables and package versions. 

Dev machines do require additional manual intervention.  The deb packages get 
installed as normal (version "latest" or whatever) but the app component deb 
installers install themselves plus a symlink pointing to the deb install 
location ( e.g. /usr/lib/myapp/current -> /usr/lib/myapp/deb).  Because the deb 
installers won't overwrite files that have been modified externally, the 
developers can point the symlink (/usr/lib/myapp/cuurent) for the relevant 
component to point to their local checkout/ compile directory and they can be 
working on the code while the rest of their installation keeps up to speed with 
other package versions and configs.  They need to copy the puppet-created 
config file for the particular app  into their working directory and symlink 
from its normal /etc/myapp location) but then they can modify it etc as part of 
the dev process. 

I know I'm making a mess of explaining this, sorry - feel free to point out 
bits that either aren't clear or where we could improve our process!  


----- Reply message -----
From: "Schofield" <dbschofi...@gmail.com>
To: <puppet-users@googlegroups.com>
Subject: [Puppet Users] Re: How to do release managment integration with puppet?
Date: Mon, Dec 3, 2012 8:18 pm
On Monday, December 3, 2012 2:32:15 PM UTC-5, j4m3s wrote:Though we have lots 
of automated testing we still rely on the human touch for checking UI look and 
feel, and doing exploratory testing (in the pre production environment).   Once 
it has passed this step the human can approve it for production deployment by 
updating the version number in hiera. I guess we could have a button on a web 
screen or something to make it easier to promote it, but editing hiera directly 
is easy enough.  If you have a central change management system, it could 
update hiera - but you'll still want it approved for promotion by a human won't 
you, to take into account live service stability/ load, etc?

Do you use hiera to define not only the versions but also which applications 
should be on which environments?  How do you introduced application version 1.0 
to dev for the first time?




-- 
You received this message because you are subscribed to the Google Groups 
"Puppet Users" group.
To view this discussion on the web visit 
https://groups.google.com/d/msg/puppet-users/-/5n3FDDQjhlYJ. 
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