On second-thought, #3 would be out of the question if you wanted to use
%{primary_group} as a hierarchy level in Hiera.  You will need to either
write a fact to determine the group based on something atomic about the
system or do something at provision time.  Do you have this
node-to-primary/secondary-group mapping in a source of truth like a MySQL
database?  If so, then you could utilize a Hiera backend to query this
source of truth.  There are Hiera-mysql backends that will allow you to
read from database tables, so this is also an option.  I would likely lean
toward option #1, however.

Hope this helps.


On Sat, Mar 24, 2012 at 3:55 AM, Gary Larizza <g...@puppetlabs.com> wrote:

>
>
> On Fri, Mar 23, 2012 at 3:42 AM, Pablo Fernandez 
> <pablo.fernan...@cscs.ch>wrote:
>
>> **
>>
>> Dear all,
>>
>>
>>
>> This is a continuation of another thread, but I think the question
>> diverged enough to create a new one.
>>
>>
>>
>> I have a hiera hierarchy like this:
>>
>> :hierarchy:
>>
>> - %{fqdn}
>>
>> - %{secundary_group}
>>
>> - %{primary_group}
>>
>> - %{productname}
>>
>> - all
>>
>>
>>
>> And I need to define the secondary/primary groups as facts, on the nodes.
>> Gary has suggested me to use plugins, that they will provide the facts
>> before puppet runs... but I was thinking: for plugins to give facts, taken
>> directly from within the puppet code, puppet needs to run first, doesn't
>> it?
>>
>>
>>
>> So, I guess I could create a module and a ruby script:
>>
>> - mygroups/lib/facter/addgroup.rb
>>
>> And write some code in Ruby to call Facter.add(:primary_group).
>>
>>
>>
>> My problem is (besides the fact that I know nothing about Ruby)... how do
>> I insert the values for primary_group and secondary_group inside that
>> function, within a simple puppet run?
>>
>
> I would ask how you could classify a node's primary or secondary group
> based on looking at?  Is there a file on disk that indicates its group?
>  Will you use its IP address?  Hostname?  Something like this?
>
> It sounds like you want to use Puppet to place a file on the filesystem
> indicating its primary_group, but that you want to Puppet to manage this
> file (or you want to manage the data in Puppet itself).  You have a number
> of options here:
>
> 1.  Use something atomic about the machine to determine its primary_group.
>  If you can say 'based on its IP address, it should be in this group' or
> 'based on its hostname, it will be in THIS group', then write a fact to
> determine this for you.  Remember that in your custom fact you can do:
>  Facter.value(:ipaddress) or Facter.value(:hostname) to get a node's
> ipaddress or hostname.  This is the better method since it relies on
> something NOT provided by Puppet to determine its group.  The Facter fact
> would run before the Puppet run, determine its group, and then you'd be
> fine.  Most places I visit do something like this.
>
> 2.  Do something at provision-time.  Do you already have a source of truth
> that maps each node to a primary_group?  In your kickstart before running
> Puppet you could query this source of truth and create a file (to be read
> by a fact) that would determine the primary_group.
>
> 3.  Set it in the %{fqdn} level of the Hiera hierarchy.  This is
> less-optimal as you would need to create a YAML file for every node in your
> infrastructure and set its 'primary_group' parameter in the YAML file.  If
> you don't have a source of truth that maps each node to a primary_group,
> and you can't determine the group based on something ABOUT the node itself
> (as in case #1), then Hiera can/will be your node/group source of truth.
>
> Does this sound like what you need?
>
>
>
>>
>>
>> I guess I could use a file with the definitions, like
>> /etc/facts.d/groups... but that would require two puppet runs: one to
>> create the file, and the second that loads the facts.
>>
>>
>>
>> I was thinking of a possible alternative... a module "mygroups" with
>> sub-classes, that I import from the nodes:
>>
>>
>>
>> node 'blabla' { include mygroups::green }
>>
>>
>>
>> And then in the module, make a mygroups/lib/facter/green.rb that does
>> Facter.add(:primary_group) = 'green' (or however you do it with Ruby). But
>> how do I make sure the module green.rb is loaded, but not the other modules
>> that will be there too?
>>
>>
>>
>> Or maybe I could use parameters, that the plugin will recognize somehow?
>>
>>
>>
>>
>>
>> I hope the questions are clear enough, because this is clearly not clean
>> in my head.
>>
>> Thanks!
>> Pablo
>>
>> --
>> 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.
>>
>
>
>
> --
>
> Gary Larizza
> Professional Services Engineer
> Puppet Labs
>
>


-- 

Gary Larizza
Professional Services Engineer
Puppet Labs

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