5

我正在尝试在我的 Vagrant 机器上获得对 augeas 的支持。

我尝试使用这些指令安装一些软件包:

package { "augeas-tools":   ensure => installed }
package { "libaugeas-dev":  ensure => installed }
package { "libaugeas-ruby": ensure => installed }

当我尝试在我的清单上使用 augeas 时,在 vm 启动后我收到此错误:

err: Could not find a suitable provider for augeas

我正在使用带有 Vagrant 1.0.3 的精确 32 官方框。

Vagrant 1.0.3 有 ruby​​ 1.8.7 和 puppet 2.7.14

$ ruby -v
$ ruby 1.8.7 (2011-06-30 patchlevel 352) [i686-linux]
$ puppet help
$ Puppet v2.7.14

这是我的php类的小清单,包含在apache类、mysql和其他单独测试的类之后。除了 augeas 命令外,所有东西都正常工作。

class php {

    exec { "apt-update":
        command     => "/usr/bin/apt-get update",
        refreshonly => true;
    }

    package { "augeas-tools":   ensure => installed }
    package { "libaugeas-dev":  ensure => installed }
    package { "libaugeas-ruby": ensure => installed }

    package { "php5":               ensure => installed }
    package { "php5-cli":           ensure => installed }
    package { "php5-xdebug":        ensure => installed }
    package { "php5-curl":          ensure => installed }
    package { "php5-intl":          ensure => installed }
    package { "php5-imap":          ensure => installed }
    package { "php5-mcrypt":        ensure => installed }
    package { "php5-imagick":       ensure => installed }
    package { "php5-sqlite":        ensure => installed }
    package { "php5-gd":            ensure => installed }
    package { "php-apc":            ensure => installed }

    package { 
        "libapache2-mod-php5" : 
            ensure => installed,
            require => Package["php5"]
    }

    augeas { "php-cli":
        require =>  [
                        Package["php5"],
                        Package["augeas-tools"],
                        Package["libaugeas-dev"],
                        Package["libaugeas-ruby"],
                    ],
        context => "/etc/php5/cli/php.ini",
        changes => [
            "set date.timezone Europe/Rome",
            "set short_open_tag Off",
        ];
    }

    augeas { "php-apache":
        require =>  [
                        Package["php5"],
                        Package["augeas-tools"],
                        Package["libaugeas-dev"],
                        Package["libaugeas-ruby"],
                    ],
        context => "/etc/php5/apache2/php.ini",
        changes => [
            "set date.timezone Europe/Rome",
            "set short_open_tag Off",
        ];
    }

}

安装软件包后,使用“vagrant ssh”登录 vagrant 机器,我启动:

vagrant@precise32:~$ ruby -raugeas -e "puts Augeas.open"
#<Augeas:0xb77a3598>

提前致谢!

4

4 回答 4

8

我将以下内容添加到我的 Vagrantfile 中,它开始工作了。

如果在 ubuntu 上,在声明 puppet provisioner 之前添加以下行:

config.vm.provision :shell, :inline => "sudo apt-get update && sudo apt-get install puppet -y"

这将更新您的 apt 包,然后更新最新版本已经修复的 puppet 客户端。

于 2012-12-27T07:18:24.857 回答
7

事实证明,这在我在其他答案中引用的错误 #6907中没有得到修复。该修复仅适用于依赖于随后在运行期间提供的命令的 Puppet 提供程序。

对于 Augeas 提供程序,它使用称为“功能”的内部 Puppet 来检查 ruby​​-augeas 库是否可用。功能只被检查一次并且结果被缓存,所以即使在安装库之后,这意味着该功能仍然被评估为假。

我将此作为错误 #14822提交到上游,并已发送带有修复的拉取请求。使用补丁进行测试,我现在可以成功运行:

notice: /Stage[main]//Package[ruby-augeas]/ensure: created
notice: /Stage[main]//Augeas[test]/returns: executed successfully

我不熟悉 Vagrant,但我认为您需要找到一种解决方法来在 Puppet 运行之前安装 libaugeas-ruby 包。

于 2012-06-05T18:38:16.193 回答
1

在 Puppet 2.7.14 上,这应该可以工作,因为提供者的依赖项只会在需要时进行评估 - 即当 Puppet 需要运行这些 Augeas 资源时。

如果没有完整的 Puppet 日志文件进行确认,我怀疑这是因为您缺少 Augeas 包和需要它们的 Augeas 资源之间的显式依赖关系。请记住,以该顺序在清单中列出资源并不意味着 Puppet 以这种方式执行它。

您可以向每个 Augeas 资源添加需要参数:

augeas { "php-cli":
    require => [ Package["php5"], Package["libaugeas-ruby"] ],
    # ...
}

或者使用链接语法自动使每个 Augeas 资源都依赖于一个包。将其添加到类内的一行,但不在任何资源内:

Package["libaugeas-ruby"] -> Augeas <| |>
于 2012-06-05T12:37:46.457 回答
1

从@m0dlx 阅读答案后,我检查/home/vagrant/postinstall.sh了文件,发现 Vagrant 使用自己的 Ruby 副本:

# The base path to the Ruby used for the Chef and Puppet gems ruby_home="/opt/vagrant_ruby"

之后,我通过更改行找到文件并对其进行augeas.rb编辑/opt/vagrant_ruby/lib/ruby/gems/1.8/gems/puppet-2.7.19/lib/puppet/provider/augeas/augeas.rb

confine :true => Puppet.features.augeas?

confine :true => :augeas

(简而言之,我部分应用了来自 @m0dlx 的补丁。)

之后这个错误就消失了。

于 2013-04-16T09:52:02.410 回答