I wanted to post sooner ... oh well... This is resonably complicated and
easier understood on the whiteboard in my office :)

Our build processes uses 3 environments, noop setting, SVN, inventory fakedb
(csv file), and custom reports

*ENVs*

   1. *dev* - separate server, you can do whatever you want here, puppet can
   rebuild this server in case you go to far :)
   2. *test* environment - low impact machines - a place to apply changes to
   a large group of machines without getting fired if something goes wrong
   (although developers might yell at you)
   3. *prod - *high impact machines - only when you are absolutely sure ....

*SVN:*
  3 separately visioned directories
      - *conf *- manifests + site configuration file
      - *dev* - services and modules
      - *global* - everything not supported by environments (tools=[external
node classifier, custom reports, build process code], plugins)

*INVENTORY* - defines node attributes for external_node_classifier (and
provisioning process)
  *environment column - *the external_node_classifier will send a node to
this new environment if he is not currently there.

*Build Process:
  *1. identify changes
  2. move test agents to dev puppet server (via inventory fake db)
      *DEV ENV:*
  3. Iterative development
  4. test
  5. create a release
      *TEST ENV:
  *6. checkout latest test release (automatically forces everything into
SAFE MODE, noop=true)
  7. activate environment (turn safe mode = false)
  8. create production release
     *PROD ENV:
**  *6. checkout latest prod release (automatically forces everything into
SAFE MODE, noop=true)
  7. activate environment (turn safe mode = false)*
*
*Reporting:*
  create new reports dir ENV/RELEASE/SAFE_MODE/
    for each report type (ENV/RELEASE/SAFE_MODE/) - one report per host
      if the report already exists, then the puppetd run does not coincide
with a new release and emails should be sent if anything changes.

*Limitations:
  *- puppet servers manage part of the process by changing the puppet.conf
file
  - environments do not support plugins, external_node_classifiers, etc..
  - noop can only be set on the client side(not per environment)
*
MIsc:
  *there are some other minor points not mentioned.
  - svn commit hooks do things like verify code and notify admins when
releases are created
  - conf and dev repos are separate so that users can make conf changes on
the test environment (skipping the dev steps in the process) and so that
conf changes can be triggered by scripts (EX: rootpwchange script), and
maybe eventually a web interface.
  - when relevent, puppet server checks for the hosts in its environment
(inventory file) and broadcasts a puppetrun call.
  - other...

*Phase 2:*

  1. Tickets are created in some kind of a ticketing system
  2. Code releases reference tickets
  3. system associates all infrastructure changes(from reports) - with the
corresponding build IDs.  Probably by autogenerating tiki pages in the build
management system (trac or whatever)

For any change in the infrastructure, you can see the ticket, the source
changes and the resulting changes in the infrastructure. Then the
infrastrucutre change process becomes a well understood and auditable
process.

enjoy!

Dan

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