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.