今天在部署Zabbix的Proxy时,在负责安装的Exec中去掉了一些无关的Package的依赖,结果,就出现了依赖关系的问题。
在zabbix::install中,我写的是require mysql::devel
class zabbix::install { require mysql::devel ....
Exec {"zabbix_install":
...
} } define zabbix::config ( reuqire zabbix::install ... ) { ... }
然后mysql那边的情况是
class mysql { include mysql::install, mysql::initial, mysql::service } class mysql::devel { include mysql::install, mysql::install::devel, mysql::initial, mysql::service }
上面mysqld这个类的依赖关系是:
- mysql::service 依赖于 mysql::initial
- mysql::initial 依赖于 mysql::install
实际上,mysql::install::devel只有一个包,但是如果继承的话,依赖关系就不好指定了。
根据Puppet官方说明,require除了include之外,还包含了先后顺序。
http://docs.puppetlabs.com/puppet/3/reference/lang_relationships.html
但是,为什么我这里require之后,就出现问题了呢?
执行的情况看起来是乱序的,总是先执行完Exec["zabbix_install"]之后,才会去部署Class["mysql::initial"]中的内容,所以自动部署的脚本总是失败。
最后,没有办法在Exec中添加了如下内容:
... require => Class["mysql::service"] ...
这时候,执行的情况就是正常的,也没有出现mysql-devel的包在其之后安装的问题。
如果添加mysql::devel或者mysql,都会出现问题(一样的问题)。
这时回想起来,删除的包中有php-mysql,如果要安装该包,一定要先安装mysql-server。
从之前Zabbix Node的部署情况来看,其实也没有按照顺序进行部署,Server的依赖关系处理了一部分后,才去部署MySQL的。