Изпълнението на марионетно приложение с превключвателя 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). Имам чувството, че манифестният ми файл е грешен. Пропускам ли нещо очевидно тук?
наздраве