Не може да се намери клас, когато се изпълнява марионетно приложение с modulepath

Изпълнението на марионетно приложение с превключвателя modulepath е неуспешно с Error: Could not find class apt for vagrant.example.com on node vagrant.example.com

Puppet версията е 3.7.3, работеща на Ubuntu 14.04, управлявана от Vagrant и VirtualBox

Това е командата, която изпълнявам:

sudo puppet apply --debug --verbose --modulepath '/tmp/vagrant-puppet-3/modules-0' /tmp/vagrant-puppet-3/manifests/default.pp

Изходът

vagrant@vagrant:~$ sudo puppet apply --debug --verbose --modulepath '/tmp/vagrant-puppet-3/modules-0'  /tmp/vagrant-puppet-3/manifests/default.pp
Warning: Setting templatedir is deprecated. See http://links.puppetlabs.com/env-settings-deprecations
   (at /usr/lib/ruby/vendor_ruby/puppet/settings.rb:1139:in `issue_deprecation_warning')
Debug: Runtime environment: puppet_version=3.7.3, ruby_version=1.9.3, run_mode=user, default_encoding=US-ASCII
Info: Loading facts
Debug: Loading facts from /tmp/vagrant-puppet-3/modules-0/puppetlabs-apt/lib/facter/apt_update_last_success.rb
Debug: Loading facts from /tmp/vagrant-puppet-3/modules-0/puppetlabs-apt/lib/facter/apt_updates.rb
Info: Loading facts
Debug: Loading facts from /tmp/vagrant-puppet-3/modules-0/puppetlabs-concat/lib/facter/concat_basedir.rb
Info: Loading facts
Debug: Loading facts from /tmp/vagrant-puppet-3/modules-0/puppetlabs-stdlib/lib/facter/facter_dot_d.rb
Debug: Loading facts from /tmp/vagrant-puppet-3/modules-0/puppetlabs-stdlib/lib/facter/pe_version.rb
Debug: Loading facts from /tmp/vagrant-puppet-3/modules-0/puppetlabs-stdlib/lib/facter/puppet_vardir.rb
Debug: Loading facts from /tmp/vagrant-puppet-3/modules-0/puppetlabs-stdlib/lib/facter/root_home.rb
Error: Could not find class apt for vagrant.example.com on node vagrant.example.com
Error: Could not find class apt for vagrant.example.com on node vagrant.example.com

Съдържанието на /tmp/vagrant-puppet-3/manifests/default.pp`

node default 
{ 
  include apt
}

Съдържанието на /tmp/vagrant-puppet-3/modules-0

drwxr-xr-x 1 root vagrant  714 Jan  5 20:03 puppetlabs-apt
drwxr-xr-x 1 root vagrant  680 Jan  5 20:03 puppetlabs-concat
drwxr-xr-x 1 root vagrant  782 Jan  5 20:03 puppetlabs-postgresql
drwxr-xr-x 1 root vagrant  782 Jan  5 20:03 puppetlabs-stdlib

Изпълнението на puppet module list със същия modulepath наистина изброява модулите (включително puppetlabs-apt, за който имам предвид), макар и с предупреждения за зависимости.

vagrant@vagrant:~$ puppet module list --debug --verbose --modulepath '/tmp/vagrant-puppet-3/modules-0'
Warning: Missing dependency 'puppetlabs-apt':
  'puppetlabs-postgresql' (v4.1.0) requires 'puppetlabs-apt' (>=1.1.0 <2.0.0)
Warning: Missing dependency 'puppetlabs-concat':
  'puppetlabs-postgresql' (v4.1.0) requires 'puppetlabs-concat' (>= 1.1.0 <2.0.0)
Warning: Missing dependency 'puppetlabs-stdlib':
  'puppetlabs-apt' (v1.7.0) requires 'puppetlabs-stdlib' (>= 2.2.1)
  'puppetlabs-concat' (v1.1.2) requires 'puppetlabs-stdlib' (>= 3.2.0 < 5.0.0)
  'puppetlabs-postgresql' (v4.1.0) requires 'puppetlabs-stdlib' (v4.x)
/tmp/vagrant-puppet-3/modules-0
├── puppetlabs-apt (v1.7.0)
├── puppetlabs-concat (v1.1.2)
├── puppetlabs-postgresql (v4.1.0)
└── puppetlabs-stdlib (v4.5.0)

Странното е, че puppet module list изглежда намира модулите, но позоваването на който и да е от модулите в моя манифестен файл е неуспешно (същата грешка в класа, ако се опитам да включа postgresql). Имам чувството, че манифестният ми файл е грешен. Пропускам ли нещо очевидно тук?

наздраве


person Stian S    schedule 05.01.2015    source източник


Отговори (1)


преименувайте папката на модула puppetlabs-apt на apt

или променете pp кода

от

include apt 

to

include puppetlabs-apt

Зависи от това как сте дефинирали в apt pp файла.

person BMW    schedule 05.01.2015
comment
Благодаря, че го решихте. Използвам librarian-puppet и начинът, по който бях декларирал зависимостта на модула, накара папката да бъде наречена puppetlabs-apt вместо просто apt. - person Stian S; 09.01.2015