On 5/15/2014 12:14 PM, Christopher Wood wrote:
(inline)

On Thu, May 15, 2014 at 11:45:21AM -0700, Ramin K wrote:

I'd also like to disagree slightly with Christopher who also
posted in this thread. Your profile:: classes are the perfect place
for all sorts of site specific nonsense including resources. In
fact if you're not sufficiently embarrassed of your profile classes
you're probably not taking full advantage of that abstraction
layer. I wrote about how I use/abuse them here,
https://ask.puppetlabs.com/question/5235/what-goes-in-the-profile-part-of-roleprofile/

(I think I had this exact conversation when discussing profiles at
work.)

This is usually where I say: If you have site-specific things you
should modularize those and add the relevant include statements and
chaining to the profile, with the data in hiera.

For us that includes a site level in hiera so that hosts at different
sites get different puppetmasters (server not ca_server), ntp
servers, resolvers, and so on. This helps us use the mnemonic that
anything in node yaml indicates either an oddity or an error. This
will also let us quickly include a module if we need it somewhere
else.

Of course, your mileage may vary, mine sure has at times.

Oh good, disagreement. I think much harder when that happens :-)

We probably agree more than disagree, but the statement that bothered me was that profile was a place of pure includes and chains. Sure everything should be modularized, but often the time to do it is eventually and sometimes never. Generalization should only happen once you need more than one and fully understand the problem. Perhaps we could mimic Knuth and say "Premature generalization is a distraction from automating your production system."

I think there is a distinction between small systems and large ones which affect both our point of views. I run a smallish system that I own completely. Without dissenting opinions about what should be on servers I'm free to make sweeping changes to how we manage a daemon with hardly anyone noticing let alone caring. And because I'm manpower limited, I'm unlikely to do generalization unless absolutely needed. In a larger system many sites, divisions, etc are going to do things differently and generalization is required much earlier and often. Also with a larger staff the additional code and complexity is worth it if it keeps everyone from reinventing the wheel.

Ramin

--
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 puppet-users+unsubscr...@googlegroups.com.
To view this discussion on the web visit 
https://groups.google.com/d/msgid/puppet-users/537654FF.2000502%40badapple.net.
For more options, visit https://groups.google.com/d/optout.

Reply via email to