Назад | Перейти на главную страницу

«Unsupported osfamily: Linux» при попытке установить Apache с помощью Puppet

Я пытаюсь настроить простую настройку Puppet на AWS EC2, используя последнюю версию AMI Amazon Linux.

Я выполнил руководство по установке для RHEL и иметь puppetmasterd демон работает.

При применении следующего манифеста в /etc/puppet/manifests/site.pp:

node 'ip-172-31-1-239.eu-west-1.compute.internal' {
  class { 'apache': }
}

Я получаю сообщение об ошибке:

[ec2-user@ip-172-31-1-239 ~]$ sudo puppet agent --test
info: Loading facts in /etc/puppet/modules/concat/lib/facter/concat_basedir.rb
info: Loading facts in /etc/puppet/modules/stdlib/lib/facter/pe_version.rb
info: Loading facts in /etc/puppet/modules/stdlib/lib/facter/root_home.rb
info: Loading facts in /etc/puppet/modules/stdlib/lib/facter/facter_dot_d.rb
info: Loading facts in /etc/puppet/modules/stdlib/lib/facter/puppet_vardir.rb
err: Could not retrieve catalog from remote server: Error 400 on SERVER: Class['apache::version']: Unsupported osfamily: Linux at /etc/puppet/modules/apache/manifests/version.pp:37 on node ip-172-31-1-239.eu-west-1.compute.internal
warning: Not using cache on failed catalog
err: Could not retrieve catalog; skipping run

Из version.pp модуля Apache для Puppet, я могу понять, почему из манифеста не удается установить Apache, но я не могу понять, почему Facter сообщает о osfamily как "Linux" в первую очередь:

[ec2-user@ip-172-31-1-239 ~]$ facter | grep osfamily
osfamily => Linux

[ec2-user@ip-172-31-1-239 ~]$ rpm -qa | grep facter
facter-1.6.18-7.25.amzn1.noarch

[ec2-user@ip-172-31-1-239 ~]$ rpm -qa | grep puppet
puppetlabs-release-6-11.noarch
puppet-2.7.25-1.4.amzn1.noarch
puppet-server-2.7.25-1.4.amzn1.noarch

[ec2-user@ip-172-31-1-239 ~]$ sudo puppet module list
/etc/puppet/modules
├── puppetlabs-apache (v1.4.0)
├── puppetlabs-concat (v1.2.0)
└── puppetlabs-stdlib (v4.5.1)
/usr/share/puppet/modules (no modules installed)

У кого-нибудь есть идеи, как я могу это решить?

Не используйте Amazon Linux. В Модуль Puppet Labs Apache не совместим с Amazon Linux. Вам нужно будет использовать один из дистрибутивов, с которыми он совместим, или создать свой собственный модуль Puppet.

Посмотрев на это свежим взглядом сегодня, я обнаружил, что Facter v1.7.0 включает исправление, которое правильно классифицирует Amazon Linux как «RedHat»: https://github.com/puppetlabs/facter/commit/c12d3b6c557df695a7b2b009da099f6a93c7bd31

Теперь я знаю, почему об этом неправильно сообщают, мне нужно знать, почему я не устанавливаю Facter v1.7.0 из репозитория PuppetLabs Yum, что выходит за рамки этого вопроса.

Проблема, похоже, в файле /usr/lib/ruby/site_ruby/1.8/facter/osfamily.rb

что в конечном итоге приводит к использованию операционной системы как семейства в случае Amazon Linux.

Строка 19:

 when "RedHat", "Fedora", "CentOS", "Scientific", "SLC", "Ascendos", "CloudLinux", "PSBM", "OracleLinux", "OVS", "OEL"

и должно быть:

 when "RedHat", "Fedora", "CentOS", "Scientific", "SLC", "Ascendos", "CloudLinux", "PSBM", "OracleLinux", "OVS", "OEL", "Amazon"