provisioning - Chef: ¿Por qué se omiten los recursos en un paso "include_recipe"?
vagrant (2)
Chef parece estar procesando los recursos en un orden extraño, causando que mi compilación falle. Mi receta principal ( mytardis-chef/site-cookbooks/recipes/default.rb
) comienza así:
include_recipe "build-essential"
include_recipe "mytardis::deps"
include_recipe "mytardis::nginx"
include_recipe "mytardis::postgresql"
mytardis-chef/cookbooks/build-essential/recipes/default.rb
tiene este aspecto:
case node[''platform'']
when "ubuntu","debian"
%w{build-essential binutils-doc}.each do |pkg|
package pkg do
action :install
end
end
when "centos","redhat","fedora","scientific"
%w{gcc gcc-c++ kernel-devel make}.each do |pkg|
package pkg do
action :install
end
end
end
... (es una versión anterior de https://github.com/opscode-cookbooks/build-essential/blob/master/recipes/default.rb
)
En tiempo de ejecución, por razones que no entiendo, esta receta esencial para la compilación se carga pero no se ejecuta:
[default] Waiting for VM to boot. This can take a few minutes.
[default] VM booted and ready for use!
[default] Mounting shared folders...
[default] -- v-root: /vagrant
[default] -- v-csr-3: /tmp/vagrant-chef-1/chef-solo-3/roles
[default] -- v-csc-2: /tmp/vagrant-chef-1/chef-solo-2/cookbooks
[default] -- v-csc-1: /tmp/vagrant-chef-1/chef-solo-1/cookbooks
[default] -- v-csdb-4: /tmp/vagrant-chef-1/chef-solo-4/data_bags
[default] Running provisioner: Vagrant::Provisioners::ChefSolo...
[default] Generating chef JSON and uploading...
[default] Running chef-solo...
[Sun, 08 Jul 2012 05:14:32 +0200] INFO: *** Chef 10.12.0 ***
[Sun, 08 Jul 2012 05:14:32 +0200] DEBUG: Building node object for lucid32
[Sun, 08 Jul 2012 05:14:32 +0200] DEBUG: Extracting run list from JSON attributes provided on command line
[Sun, 08 Jul 2012 05:14:32 +0200] INFO: Setting the run_list to ["recipe[mytardis]"] from JSON
[Sun, 08 Jul 2012 05:14:32 +0200] DEBUG: Applying attributes from json file
[Sun, 08 Jul 2012 05:14:32 +0200] DEBUG: Platform is ubuntu version 10.04
[Sun, 08 Jul 2012 05:14:32 +0200] INFO: Run List is [recipe[mytardis]]
[Sun, 08 Jul 2012 05:14:32 +0200] INFO: Run List expands to [mytardis]
[Sun, 08 Jul 2012 05:14:32 +0200] INFO: Starting Chef Run for lucid32
[Sun, 08 Jul 2012 05:14:32 +0200] INFO: Running start handlers
[Sun, 08 Jul 2012 05:14:32 +0200] INFO: Start handlers complete.
...
[Sun, 08 Jul 2012 05:14:33 +0200] DEBUG: Loading Recipe mytardis via include_recipe
[Sun, 08 Jul 2012 05:14:33 +0200] DEBUG: Found recipe default in cookbook mytardis
[Sun, 08 Jul 2012 05:14:33 +0200] DEBUG: Loading Recipe build-essential via include_recipe
[Sun, 08 Jul 2012 05:14:33 +0200] DEBUG: Found recipe default in cookbook build-essential
[Sun, 08 Jul 2012 05:14:33 +0200] DEBUG: Loading Recipe mytardis::deps via include_recipe
[Sun, 08 Jul 2012 05:14:33 +0200] DEBUG: Found recipe deps in cookbook mytardis
[Sun, 08 Jul 2012 05:14:33 +0200] DEBUG: Loading Recipe mytardis::nginx via include_recipe
[Sun, 08 Jul 2012 05:14:33 +0200] DEBUG: Found recipe nginx in cookbook mytardis
[Sun, 08 Jul 2012 05:14:33 +0200] DEBUG: Loading Recipe iptables via include_recipe
[Sun, 08 Jul 2012 05:14:33 +0200] DEBUG: Found recipe default in cookbook iptables
[Sun, 08 Jul 2012 05:14:33 +0200] DEBUG: Loading Recipe mytardis::postgresql via include_recipe
[Sun, 08 Jul 2012 05:14:33 +0200] DEBUG: Found recipe postgresql in cookbook mytardis
[Sun, 08 Jul 2012 05:14:33 +0200] DEBUG: Loading Recipe postgresql::server via include_recipe
[Sun, 08 Jul 2012 05:14:33 +0200] DEBUG: Found recipe server in cookbook postgresql
[Sun, 08 Jul 2012 05:14:33 +0200] DEBUG: Loading Recipe postgresql::client via include_recipe
[Sun, 08 Jul 2012 05:14:33 +0200] DEBUG: Found recipe client in cookbook postgresql
[Sun, 08 Jul 2012 05:14:33 +0200] INFO: Processing package[postgresql-client] action install (postgresql::client line 37)
[Sun, 08 Jul 2012 05:14:33 +0200] DEBUG: package[postgresql-client] checking package status for postgresql-client
....
[Sun, 08 Jul 2012 05:14:45 +0200] ERROR: gem_package[pg] (postgresql::client line 42) has had an error
.
make
sh: make: not found
Es decir, la receta esencial para la compilación se "encuentra" y "carga", pero es la receta postgres la que se "procesa" primero. Y como build-essential (que instala el compilador de C) no se ejecutó, este último falla.
La parte relevante de mi Vagrantfile se ve así:
config.vm.provision :chef_solo do |chef|
chef.log_level = :debug
chef.cookbooks_path = ["mytardis-chef/site-cookbooks", "mytardis-chef/cookbooks"]
chef.roles_path = "mytardis-chef/roles"
chef.data_bags_path = "mytardis-chef/data_bags"
chef.add_recipe "mytardis"
end
Anteriormente estaba usando una versión ligeramente anterior de Chef (¿quizás 10.10.0?) En esa versión, build-essential tampoco se estaba ejecutando, pero mytardis :: deps sí. Ahora utilizando Chef 10.12.0. La máquina física es OSX, VM es Ubuntu Lucid.
Entonces, algunas preguntas:
- ¿Por qué no se está "procesando" build-essential?
- ¿Cuál es la forma correcta de hacer esto? (No escribí estas recetas, y entiendo que lo hacen o han trabajado para su autor).
- ¿Deben seguir funcionando las características de "sombra" de los libros de cocina y de los libros de cocina? Supuestamente está en desuso: http://tickets.opscode.com/browse/CHEF-2308 (intenté hacer un enlace simbólico debajo de site-cookbooks / mytardis / recipes / build-essential pero no me alegro).
Resulta que esto es una parte bastante normal (pero poco documentada) de cómo trabaja Chef: compila todo y luego comienza a ejecutarse. Excepto que algunas recetas (como Postgres) saltan la cola para instalarse realmente en tiempo de compilación, usando un código como este:
action :nothing
end.run_action(:run)
La solución es que cualquier cosa que deba ejecutarse antes de Postgres también debe hacer esto. Afortunadamente, las nuevas versiones de Build-essentials permiten. Establece los atributos en un rol de la siguiente manera:
name "myapp"
run_list(
"recipe[build-essential]",
"recipe[myapp]"
)
default_attributes(
"build_essential" => {
"compiletime" => true
}
)
Si está escribiendo un libro de cocina, agregue el atributo a su archivo de atributos:
node.default[''build_essential''][''compiletime''] = true
Gracias a Colin arriba.