Hi Luke,

"sometimes" means this:

[root@test-hpc puppet]# puppetd -vt --noop
info: Retrieving plugin
err: Could not retrieve catalog from remote server: Error 400 on SERVER:
Could not find resource 'Class[Common_software]' for relationship from
'Class[Default_repositories]' on node hpc.tornado
warning: Not using cache on failed catalog
err: Could not retrieve catalog; skipping run
[root@test-hpc puppet]# vi manifests/nodes.pp
[root@test-hpc puppet]# puppetd -vt --noop
info: Retrieving plugin
err: Could not retrieve catalog from remote server: Error 400 on SERVER:
Could not find resource 'Class[Common_software]' for relationship from
'Class[Default_repositories]' on node hpc.tornado
warning: Not using cache on failed catalog
err: Could not retrieve catalog; skipping run
[root@test-hpc puppet]# puppetd -vt --noop
info: Retrieving plugin
err: Could not retrieve catalog from remote server: Error 400 on SERVER:
Could not find resource 'Class[Common_software]' for relationship from
'Class[Default_repositories]' on node hpc.tornado
warning: Not using cache on failed catalog
err: Could not retrieve catalog; skipping run
[root@test-hpc puppet]# puppetd -vt --noop
info: Retrieving plugin
info: Caching catalog for hpc.tornado
info: Applying configuration version '1348562251'
info: create new repo ofed in file /etc/yum.repos.d/ofed.repo
notice: /Stage[pre]/Default_repositories::Configure/Yumrepo[ofed]/des
<cut>

This is in the test lab, in this particular case agent and server are the
same host.

Every parent class has one child '-site' class, each defined in its own
module directory, so for this example there is
modules/common_software/manifests/init.pp and
modules/common_software-site/manifests/init.pp

What do you mean by "inherit properly"?

BR,
Nikita

On 25 September 2012 13:19, Luke Bigum <luke.bi...@lmax.com> wrote:

> Hi Nikita,
>
> On 25/09/12 10:05, Nikita Burtsev wrote:
>
>> Hello,
>>
>> We have a weird problem with includes:
>> err: Could not retrieve catalog from remote server: Error 400 on SERVER:
>> Could not find resource 'Class[Common_software]' for relationship from
>> 'Class[Default_repositories]'
>>
>> My wild guess would be that "common_software" gets in before
>> "default_repositories" and thus the error message. If i run agent again it
>> sometimes goes away and configuration gets applied, sometimes it does not.
>> I even tried using stages, did not help.
>>
>>
> No, this is not an ordering problem, because ordering (generally) doesn't
> come into it when talking classes and relationships. It doesn't matter in
> which order your classes are declared. It might be more helpful if I reword
> the error to:
>
> "The class Default_repositories has a dependency on the class
> Common_software, but I can't find the class Common_software declared
> anywhere"
>
> You say below you use inheritance. If your site classes inherit from
> common_software, then common_software is implicitly declared in your
> manifests, so you shouldn't see this problem. Are you *sure* all your child
> classes inherit properly?
>
> When you say "it sometimes gets applied", is this for the same node or
> different nodes? I would expect this problem to always be there, not be
> intermittent. If it's intermittent, do you have other conditionals around
> the inclusion of your site software classes?
>
>  nodes.pp looks like this;
>>
>> stage { pre: before => Stage[main] }
>>
>> node 'basenode' {
>>
>>         class { 'default_repositories' : stage => pre }
>>         <some stuff here>
>>         include common_software-site
>>        <some more stuff here>
>> }
>>
>> We have multiple (read: many) sites with configuration which varies here
>> and there. To make things a bit more sane and to reduce duplication we
>> decided to have common code base we ship to each site which then changes
>> from site to site using inheritance mechanism, so, for example, there is
>> class called "common_software" which defines some resources and then there
>> is "common_software-site" which inherits base class and adds some
>> functionality.
>>
>> If I include child class in nodes.pp problem is there, but including
>> parent class fixes the problem.
>>
>> Any thoughts on the matter?
>>
>> BR,
>> Nikita
>> --
>> 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/-/X2-ki-**AVTZ0J<https://groups.google.com/d/msg/puppet-users/-/X2-ki-AVTZ0J>
>> .
>> To post to this group, send email to puppet-users@googlegroups.com.
>> To unsubscribe from this group, send email to puppet-users+unsubscribe@**
>> googlegroups.com <puppet-users%2bunsubscr...@googlegroups.com>.
>> For more options, visit this group at http://groups.google.com/**
>> group/puppet-users?hl=en<http://groups.google.com/group/puppet-users?hl=en>
>> .
>>
>
>
> --
> Luke Bigum
> Senior Systems Engineer
>
> Information Systems
> Ph: +44 (0) 20 3192 2520
> luke.bi...@lmax.com | http://www.lmax.com
> LMAX, Yellow Building, 1A Nicholas Road, London W11 4AN
>
>
> FX and CFDs are leveraged products that can result in losses exceeding
> your deposit.  They are not suitable for everyone so please ensure you
> fully understand the risks involved.  The information in this email is not
> directed at residents of the United States of America or any other
> jurisdiction where trading in CFDs and/or FX is restricted or prohibited
> by local laws or regulations.
>
> The information in this email and any attachment is confidential and is
> intended only for the named recipient(s). The email may not be disclosed
> or used by any person other than the addressee, nor may it be copied in
> any way. If you are not the intended recipient please notify the sender
> immediately and delete any copies of this message. Any unauthorised
> copying, disclosure or distribution of the material in this e-mail is
> strictly forbidden.
>
> LMAX operates a multilateral trading facility.  Authorised and regulated
> by the Financial Services Authority (firm registration number 509778) and
> is registered in England and Wales (number 06505809). Our registered
> address is Yellow Building, 1A Nicholas Road, London, W11
> 4AN.
>

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