chef-boneyard/chef-provisioning-vagrant

machine_batch converge optimization (virtualbox)

Opened this issue · 5 comments

The virtualbox provider does not yet support the --parallel option. The :converge action is responsible for also bootstrapping the chef-client which is done serially via vagrant up. If the machines' run lists or recipes have been configured, the vagrant up command will provision those recipes and will converge serially because the ssh transport is not used in this case.

This use case identified a workflow issue. Once all the vms are created and bootstrapped, convergence should fallback to using the ssh transport.

Here's the workaround:

machine_list = ['create-1', 'create-2']

# create and bootstrap vms
machine_batch do
  machines machine_list
end

# :converge_only to force ssh transport
machine_batch do
  machine_list.each { |m|
    machine m do
      recipe 'build-essential'
    end
  }
  action :converge_only
end

Setting converge_only as per the example here https://gist.github.com/patrick-wright/7bf6e7345eb6d93fbeac#comment-1340092 doesn't actually seem to do anything but install Chef as it somehow zeroes out the run_list

@cheeseplus I had the day off but this idea came to me randomly. Could you try this updated version:
https://gist.github.com/patrick-wright/7bf6e7345eb6d93fbeac

@Patrick-Wright while it works it doesn't speed up anything - same results as the initial implementation, serial converging

Alright. We've tried enough workarounds :) I tried one last thing to isolate the chef-client bootstrap from the machine run lists.

The basic example in the description works. What this recipe is trying to accomplish is not behaving as chef-provisioning intends.

require 'chef/provisioning'

controller_config = <<-ENDCONFIG
  config.vm.box = "centos65"
  config.vm.network "forwarded_port", guest: 443, host: 9443 # dashboard-ssl
  config.vm.network "forwarded_port", guest: 4002, host: 4002
  config.vm.network "forwarded_port", guest: 5000, host: 5000
  config.vm.network "forwarded_port", guest: 8773, host: 8773 # compute-ec2-api
  config.vm.network "forwarded_port", guest: 8774, host: 8774 # compute-api
  config.vm.network "forwarded_port", guest: 35357, host: 35357
  config.vm.provider "virtualbox" do |v|
    v.memory = 2048
    v.cpus = 2
    v.customize ["modifyvm", :id, "--nicpromisc2", "allow-all"]
    v.customize ["modifyvm", :id, "--nicpromisc3", "allow-all"]
    v.customize ["modifyvm", :id, "--natdnshostresolver1", "on"]
  end
  config.vm.network "public_network", ip: "192.168.100.60", bridge: 'en0: Wi-Fi (AirPort)'
  config.vm.network "private_network", ip: "192.168.200.60"
ENDCONFIG

with_driver "vagrant:#{File.dirname(__FILE__)}/vms"

# create machine and set converge true to bootstrap client (serially)
machine_batch do
  machine 'controller' do
    machine_options :vagrant_config => controller_config
    converge true
  end

  [ ['compute1', 61], ['compute2', 62], ['compute3', 63] ].each do |name, ip_suff|
    machine name do
      machine_options :vagrant_config => <<-ENDCONFIG
config.vm.box = "centos65"
config.vm.provider "virtualbox" do |v|
  v.memory = 2048
  v.cpus = 2
  v.customize ["modifyvm", :id, "--nicpromisc2", "allow-all"]
  v.customize ["modifyvm", :id, "--nicpromisc3", "allow-all"]
  v.customize ["modifyvm", :id, "--natdnshostresolver1", "on"]
end
config.vm.network "public_network", ip: "192.168.100.#{ip_suff}", bridge: 'en0: Wi-Fi (AirPort)'
config.vm.network "private_network", ip: "192.168.200.#{ip_suff}"
ENDCONFIG
      converge true 
    end
  end
end

# copy and paste and included run list attributes.  
# This is where I hoped the converge would run in parallel.  It does not :(
 machine_batch do
  machine 'controller' do
    machine_options :vagrant_config => controller_config
    role 'os-compute-single-controller'
    recipe 'openstack-network::identity_registration'
    role 'os-network-dhcp-agent'
    role 'os-network-metadata-agent'
    role 'os-network-server'
    recipe 'openstack-common::openrc'
    chef_environment 'vagrant-multi-nova'
    file '/etc/chef/openstack_data_bag_secret',"#{File.dirname(__FILE__)}/.chef/encrypted_data_bag_secret"
  end

  [ ['compute1', 61], ['compute2', 62], ['compute3', 63] ].each do |name, ip_suff|
    machine name do
      machine_options :vagrant_config => <<-ENDCONFIG
config.vm.box = "centos65"
config.vm.provider "virtualbox" do |v|
  v.memory = 2048
  v.cpus = 2
  v.customize ["modifyvm", :id, "--nicpromisc2", "allow-all"]
  v.customize ["modifyvm", :id, "--nicpromisc3", "allow-all"]
  v.customize ["modifyvm", :id, "--natdnshostresolver1", "on"]
end
config.vm.network "public_network", ip: "192.168.100.#{ip_suff}", bridge: 'en0: Wi-Fi (AirPort)'
config.vm.network "private_network", ip: "192.168.200.#{ip_suff}"
ENDCONFIG
      role 'os-compute-worker'
      chef_environment 'vagrant-multi-nova'
      file '/etc/chef/openstack_data_bag_secret',"#{File.dirname(__FILE__)}/.chef/encrypted_data_bag_secret"
    end
  end
end

@Patrick-Wright making sure I understand this: the issue is that vagrant up will re-run chef-client on the box?