On Monday, October 27, 2014 10:46:39 AM UTC-5, Nic Scott wrote:
>
> I'm evaluating puppet to see if it can work in our environment and I have 
> to admit the the learning cure with the puppet "terms" are giving me 
> issues. I keep reading documentation into circles. I'm familiar with 
> python, bash scripting, and use munki in my labs, but I'm stilling trying 
> to understand manifest, modules, classes, etc.
>
>
*Puppet jargon primer*

*Manifest* = Puppet source file (with .pp extension).

*Catalog* = the master's collective description of all the machine state 
that should be enforced on one target machine (node), as evaluated at one 
point in time, based on the target machine's state as evaluated prior to 
catalog generation.

*Resource* = a physical resource is more or less any one 'thing' on the 
target machine that is subject to management as a unit -- a file, a system 
service, etc..  More often, though, discussion of "resources" is directed 
at the Puppet representation of configuration specifications for physical 
resources -- declarations in one manifest or another such as

  file { '/tmp/foo': ensure => present }

and the internal representation of the same.  Resources have 'types' (File, 
Service, etc), 'properties' representing persistent characteristics of the 
corresponding physical resource that Puppet can manage, and non-persistent 
'parameters' influencing *how* Puppet manages the resource.

*Class* = abstractly, a categorization of some target nodes, synonymous in 
that sense with "type" or "kind".  Not to be interpreted in the more 
specific sense the term is used in some object oriented programming 
languages.  Concretely, classes' principal purpose is to organize resources 
into named groups.  In reality, it is sometimes hard to see how the 
concrete use of classes fits the abstract definition.

*Defined Type* = a resource type analogous to File, etc., defined in a 
manifest via the Puppet language.  Their representation is similar to 
classes', but the two constructs have important differences.

*Module* = a (more or less) self-contained collection of manifests, often 
various kinds of data, and sometimes custom plugins.  These normally focus 
on providing for management of a specific subsystem (e.g. firewall, web 
server), but sometimes they provide a lower-level general facility such as 
general-purpose extension functions (puppet::stdlib) or custom resource 
types (puppet::concat).  It is intended and hoped that modules be reusable 
in different sites and environments, which is more successful for some 
modules than for others.

 

>
> What I have is a Master and a 1 node setup. They are talking and the 
> Puppet Master is pushing configurations to the node. That's perfect. I 
> handle this by having two manifest on the Master.  A puppet_client_1.pp and 
> my site.pp. My site.pp looks like this:
>
> import "puppet_client_1"
>
> Next step ... manage two nodes. I have this working by creating a new .pp 
> file called puppet_client_2.pp. I then updated my site.pp to include the 
> second nodes manifest.
>
> import "puppet_client_1"
> import "puppet_client_2"
>
>
> My question is ... is this the best practice to manage multiple nodes? 
> What if I have a lab of 20 machines and I want the same configuration on 
> all 20? Can I do a nested manifest somehow, or do I have to create a 
> separate manifest for each node and then copy and paste my configuration 
> into each manifest?
>


You have multiple options here, some of which you can mix and match.  Here 
are many of the more popular:

   1. If most or all of your machines are intended to be configured the 
   same way then you can describe that configuration in a node block labeled 
   "default".  Any machine for which no better-matching node block is 
   available will use the default node block.
   2. You can declare the same configuration for multiple nodes by using a 
   single node block with a comma-delimited list of node names.
   3. You can use regular expressions to match node identifiers to node 
   blocks.
   4. You can use an "external node classifier" (commonly referred to via 
   its initialism, "ENC"), an external program provided by you(*) that 
   specifies global variables and classes for a node based on its identifier.
   5. You can use external data, typically accessed via Puppet's external 
   data subsystem "Hiera", to designate classes for nodes or groups of nodes, 
   to assign class parameter values, and generally to provide data that can be 
   customized based on an hierarchical scheme that you choose.
   
(*) Although I say the ENC approach requires a program provided by "you," 
that doesn't necessarily mean you have to write it from scratch.  The ENC 
in fact serves as a flexible extension point; it is leveraged by several 
different GUI configuration interfaces that might (or might not) appeal to 
you.  Among those is the rather comprehensive GUI integrated into PL's 
for-fee Enterprise product, but there are open source alternatives as well.

Also, recent version of Puppet support a site manifest *directory*, whose 
purpose is to relieve you of having to write all those "import" 
statements.  Instead, Puppet will automatically load all manifests from a 
specified directory for use as its starting point.  With older versions of 
Puppet, it is common to record node blocks in separate manifests in a 
directory such as manifests/nodes/, and to import them all via a single

import "nodes/*.pp"

line in manifests/site.pp.

 

>
> That seems like a lot of work to manage hundreds of nodes. I have to 
> believe puppet scales better then that, but I've having a hard time finding 
> examples.
>
>

Puppet does scale better than that, but details of how to achieve it vary 
somewhat with your specific requirements.

 

> Can anyone share an example of how they are managing multiple nodes?  
> Perhaps point me to an online resource or documentation?
>


The Puppet Reference Manual 
<https://docs.puppetlabs.com/puppet/3.7/reference/> is quite good.  In 
particular, it contains everything I said about node blocks, in more detail 
<https://docs.puppetlabs.com/puppet/3.7/reference/lang_node_definitions.html>.  
It also describes the external node classifier 
<https://docs.puppetlabs.com/guides/external_nodes.html> form and 
function.  Of course, everything I put in my little primer can also be 
found there.

One thing that's hard to find in the reference manual is any documentation 
for Hiera.  Those docs are in a separate manual 
<https://docs.puppetlabs.com/hiera/latest/index.html>, and the main 
reference manual seems to have only one or two links to it.


HTH,

John

-- 
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/a2189fe9-cb33-45ad-b05a-4739351eaf64%40googlegroups.com.
For more options, visit https://groups.google.com/d/optout.

Reply via email to