mysql配置的Puppet中的Augeas失败

mysql配置的Puppet中的Augeas失败,mysql,nginx,puppet,augeas,Mysql,Nginx,Puppet,Augeas,我目前正在开发一些基本的Puppet清单和模块,以便在部署服务器后安装应用程序依赖项。这是一套基本的东西:- 操作系统->Ubuntu 14.04 LTS Nginx PHP5-FPM MySQL 很简单,对吧 在大多数情况下,一切都进行得很顺利;直到我偶然发现使用Augeas用我的自定义配置项更新配置文件的能力。我已经设置了PHP配置项,没有任何问题,例如: augeas { 'php.ini': require => [ Package['php5-fpm'

我目前正在开发一些基本的Puppet清单和模块,以便在部署服务器后安装应用程序依赖项。这是一套基本的东西:-

  • 操作系统->Ubuntu 14.04 LTS
  • Nginx
  • PHP5-FPM
  • MySQL
很简单,对吧

在大多数情况下,一切都进行得很顺利;直到我偶然发现使用Augeas用我的自定义配置项更新配置文件的能力。我已经设置了PHP配置项,没有任何问题,例如:

augeas { 'php.ini':
    require => [
        Package['php5-fpm'],
        Package['libaugeas-ruby'],
    ],
    notify => Service['php5-fpm'],
    context => '/files/etc/php5/fpm/php.ini',
    changes => [
        'set PHP/cgi.fix_pathinfo 0',
    ],
}
这个很好用。没有问题

然而,现在我来看看MySQL配置文件,我使用的是以下内容(这几乎是一个复制粘贴工作)

不幸的是,这根本不起作用。我查看了augeas关于其附带镜头的文档,没有任何问题。以下是Puppet apply命令的初始输出

Error: /Stage[main]/Mysql/Augeas[my.cnf]: Could not evaluate: Save failed with return code false, see debug
当然,下一个逻辑步骤是查看调试信息。其中包含以下信息

Debug: Augeas[my.cnf](provider=augeas): sending command 'set' with params ["/files/etc/mysql/my.cnf/mysqld/bind-address", "0.0.0.0"]
Debug: Augeas[my.cnf](provider=augeas): Put failed on one or more files, output from /augeas//error:
Debug: Augeas[my.cnf](provider=augeas): /augeas/files/etc/mysql/my.cnf/error = put_failed
Debug: Augeas[my.cnf](provider=augeas): /augeas/files/etc/mysql/my.cnf/error/path = /files/etc/mysql/my.cnf
Debug: Augeas[my.cnf](provider=augeas): /augeas/files/etc/mysql/my.cnf/error/lens = /usr/share/augeas/lenses/dist/mysql.aug:39.13-.60:
Debug: Augeas[my.cnf](provider=augeas): /augeas/files/etc/mysql/my.cnf/error/message = Failed to match

好吧,所以我设法让事情发生了;但可能还没有完全了解到底发生了什么

在提出上述问题之前,我查看了可用的库存镜头,在

这两个链接都不起作用,它们本应引导您阅读文档——因此,知道PHP镜头以
'set section/setting value'
的方式工作,我假设MySQL镜头也是这样

事实并非如此。以下语法适合我

augeas { 'my.cnf':
    require => [
        Package['mysql-server'],
        Package['libaugeas-ruby'],
    ],
    notify => Service['mysql'],
    context => '/files/etc/mysql/my.cnf',
    changes => [
        "set target[.='mysqld']/bind-address 0.0.0.0",
    ],
}
以下两个资源是我找到信息的地方。如果有人能给我提供任何其他文件,我将不胜感激

这让我了解了语法可能应该是什么:-


这个脚本的第62-65行对我重申了这一点:-

是的,出于技术原因,MySQL镜头有不同的布局,所以如果文件中已经存在
mysqld
部分,那么您所做的工作就可以了。为了完全安全,您应该添加一个
set target[.='mysqld']mysqld
作为第一个更改,以便在添加值之前创建可能缺少的部分。好的,谢谢您的提示。尽管如此,考虑到我正在使用的配置文件,我保证会有一个mysqld部分——否则我真的没有办法了。:-)非常感谢!
augeas { 'my.cnf':
    require => [
        Package['mysql-server'],
        Package['libaugeas-ruby'],
    ],
    notify => Service['mysql'],
    context => '/files/etc/mysql/my.cnf',
    changes => [
        "set target[.='mysqld']/bind-address 0.0.0.0",
    ],
}