我有一个工作的puppet配置来帮助在机器上安装mysql实例。我的环境设置为在同一台机器上运行多个实例(具有不同的配置/端口/等)。
我在清单中的基本设置类似于
File{
owner => $owner,
group => $group,
before => Exec["mysql_install_db-${name}"],
}
exec{"mysql_install_db-${name}":
creates => "/var/lib/mysql/${name}/mysql",
command => "/usr/local/percona/mysql-${version}/usr/bin/mysql_install_db --user=mysql --datadir=/var/lib/mysql/${name} --basedir=/usr/local/percona/mysql-${version}/usr",
logoutput => true,
}
这非常合适,但是现在我想修改此安装过程以运行一些后续命令来使用一些内部存储过程来引导全新安装,并执行其他一些准备工作'我们为新安装做了。
命令基本上就像
mysql -u user < /path/to/bootstrap1.sql
mysql -u user < /path/to/bootstrap2.sql
mysql -u user < /path/to/bootstrap3.sql
我只希望这些运行一次,在mysql_install_db命令之后,但在某种程度上相同的&#34;创建&#34;后卫。
我发现了一些只是将数组传递给命令参数的引用,但该引用的形式是错误报告并不总是一致地工作。
什么是实现这样的事情的首选方法,并确保命令以确定的顺序执行,并且仅在运行mysql_install_db之后执行?
答案 0 :(得分:7)
有几种方法可以只运行exec
一次,并且仅在"mysql_install_db-${name}"
之后运行:
cmd1 && cmd2 && cmd3 ...
)。unless
或onlyif
参数,以便在运行命令之前检查存储过程或是否已存在。这可能很复杂,因此另一种方法是让命令创建文件("command && touch /root/blah-${name}"
)并使用creates
参数。refreshonly
和subscribe
设置为上一个执行。虽然所有这些解决方案都有效,但您不会尊重Puppet描述系统最终状态的精神。对于数据库,用户和授权设置,您可以使用puppetlabs-mysql
模块,以便以自然的方式描述它们。存储的资源是另一个问题,可以在应用程序部署过程中更加逻辑地打包(因为它们必须与应用程序保持同步)。如果无法做到这一点,那么您可以使用条件使SQL脚本具有幂等性。