Allow to customize vagrant deployment

Extract the Vagrantfile configuration to a Vagrantfile.custom file, to
permit easy customization of the Vagrant deployment without the need to
modify a file under version control.

Closes-Bug: #1517475
Change-Id: I03e3ef373ec47e3d622b77fa9cf88748db99adaa
This commit is contained in:
Martin André 2015-11-18 17:47:15 +09:00
parent 988ee296d6
commit 5eb67e275e
3 changed files with 119 additions and 20 deletions

1
.gitignore vendored
View File

@ -25,6 +25,7 @@ ChangeLog
doc/build doc/build
# Files generated by Vagrant # Files generated by Vagrant
dev/vagrant/Vagrantfile.custom
dev/vagrant/vagrantkey dev/vagrant/vagrantkey
dev/vagrant/vagrantkey.pub dev/vagrant/vagrantkey.pub
dev/vagrant/storage/ dev/vagrant/storage/

View File

@ -3,12 +3,23 @@
require "ipaddr" require "ipaddr"
# Either libvirt or virtualbox class VagrantConfigMissing < StandardError
PROVIDER = "libvirt" end
# Either centos or ubuntu
DISTRO = "centos"
PROVIDER_DEFAULTS = { vagrant_dir = File.expand_path(File.dirname(__FILE__))
# Vagrantfile.custom contains user customization for the Vagrantfile
# You shouldn't have to edit the Vagrantfile, ever.
if File.exists?(File.join(vagrant_dir, 'Vagrantfile.custom'))
eval(IO.read(File.join(vagrant_dir, 'Vagrantfile.custom')), binding)
end
# Either libvirt or virtualbox
PROVIDER ||= "libvirt"
# Either centos or ubuntu
DISTRO ||= "centos"
PROVIDER_DEFAULTS ||= {
libvirt: { libvirt: {
centos: { centos: {
base_image: "centos/7", base_image: "centos/7",
@ -40,15 +51,15 @@ PROVIDER_DEFAULTS = {
} }
# Whether to do Multi-node or All-in-One deployment # Whether to do Multi-node or All-in-One deployment
MULTINODE=false MULTINODE = false unless self.class.const_defined?(:MULTINODE)
# The following is only used when deploying in Multi-nodes # The following is only used when deploying in Multi-nodes
NUMBER_OF_CONTROL_NODES=3 NUMBER_OF_CONTROL_NODES ||= 3
NUMBER_OF_COMPUTE_NODES=1 NUMBER_OF_COMPUTE_NODES ||= 1
NUMBER_OF_STORAGE_NODES=1 NUMBER_OF_STORAGE_NODES ||= 1
NUMBER_OF_NETWORK_NODES=1 NUMBER_OF_NETWORK_NODES ||= 1
NODE_SETTINGS = { NODE_SETTINGS ||= {
aio: { aio: {
cpus: 4, cpus: 4,
memory: 4096 memory: 4096
@ -77,18 +88,25 @@ NODE_SETTINGS = {
# Configure a new SSH key and config so the operator is able to connect with # Configure a new SSH key and config so the operator is able to connect with
# the other cluster nodes. # the other cluster nodes.
unless File.file?("./vagrantkey") unless File.file?(File.join(vagrant_dir, 'vagrantkey'))
system("ssh-keygen -f ./vagrantkey -N '' -C this-is-vagrant") system("ssh-keygen -f #{File.join(vagrant_dir, 'vagrantkey')} -N '' -C this-is-vagrant")
end end
def get_default(setting) def get_default(setting)
PROVIDER_DEFAULTS[PROVIDER.to_sym][DISTRO.to_sym][setting] PROVIDER_DEFAULTS[PROVIDER.to_sym][DISTRO.to_sym][setting]
rescue
raise VagrantConfigMissing,
"Missing configuration for PROVIDER_DEFAULTS[#{PROVIDER}][#{DISTRO}][#{setting}]"
end end
def get_setting(node, setting) def get_setting(node, setting)
NODE_SETTINGS[node][setting] NODE_SETTINGS[node][setting]
rescue
raise VagrantConfigMissing,
"Missing configuration for NODE_SETTINGS[#{node}][#{setting}]"
end end
Vagrant.configure(2) do |config| Vagrant.configure(2) do |config|
config.vm.box = get_default(:base_image) config.vm.box = get_default(:base_image)
@ -98,8 +116,8 @@ Vagrant.configure(2) do |config|
config.vm.network "private_network", type: "dhcp" config.vm.network "private_network", type: "dhcp"
config.vm.network "public_network", dev: get_default(:bridge_interface), mode: 'bridge', type: 'bridge' config.vm.network "public_network", dev: get_default(:bridge_interface), mode: 'bridge', type: 'bridge'
my_privatekey = File.read(File.join(File.dirname(__FILE__), "vagrantkey")) my_privatekey = File.read(File.join(vagrant_dir, "vagrantkey"))
my_publickey = File.read(File.join(File.dirname(__FILE__), "vagrantkey.pub")) my_publickey = File.read(File.join(vagrant_dir, "vagrantkey.pub"))
config.vm.provision :shell, inline: <<-EOS config.vm.provision :shell, inline: <<-EOS
mkdir -p /root/.ssh mkdir -p /root/.ssh
@ -137,9 +155,9 @@ Vagrant.configure(2) do |config|
config.vm.define "operator" do |admin| config.vm.define "operator" do |admin|
admin.vm.hostname = "operator.local" admin.vm.hostname = "operator.local"
admin.vm.provision :shell, path: get_default(:provision_script), args: "operator #{MULTINODE ? 'multinode' : 'aio'} #{get_default(:kolla_path)}" admin.vm.provision :shell, path: get_default(:provision_script), args: "operator #{MULTINODE ? 'multinode' : 'aio'} #{get_default(:kolla_path)}"
admin.vm.synced_folder "../..", get_default(:kolla_path), create:"True", type: get_default(:sync_method) admin.vm.synced_folder File.join(vagrant_dir, '..', '..'), get_default(:kolla_path), create:"True", type: get_default(:sync_method)
admin.vm.synced_folder "storage/operator/", "/data/host", create:"True", type: get_default(:sync_method) admin.vm.synced_folder File.join(vagrant_dir, 'storage', 'operator'), "/data/host", create:"True", type: get_default(:sync_method)
admin.vm.synced_folder "storage/shared/", "/data/shared", create:"True", type: get_default(:sync_method) admin.vm.synced_folder File.join(vagrant_dir, 'storage', 'shared'), "/data/shared", create:"True", type: get_default(:sync_method)
admin.vm.synced_folder ".", get_default(:vagrant_shared_folder), disabled: true admin.vm.synced_folder ".", get_default(:vagrant_shared_folder), disabled: true
admin.vm.provider PROVIDER do |vm| admin.vm.provider PROVIDER do |vm|
vm.memory = MULTINODE ? get_setting(:operator, :memory) : get_setting(:aio, :memory) vm.memory = MULTINODE ? get_setting(:operator, :memory) : get_setting(:aio, :memory)
@ -155,8 +173,8 @@ Vagrant.configure(2) do |config|
config.vm.define hostname do |node| config.vm.define hostname do |node|
node.vm.hostname = "#{hostname}.local" node.vm.hostname = "#{hostname}.local"
node.vm.provision :shell, path: get_default(:provision_script), args: "#{hostname} multinode #{get_default(:kolla_path)}" node.vm.provision :shell, path: get_default(:provision_script), args: "#{hostname} multinode #{get_default(:kolla_path)}"
node.vm.synced_folder "storage/#{node_type}/", "/data/host", create:"True", type: get_default(:sync_method) node.vm.synced_folder File.join(vagrant_dir, 'storage', node_type), "/data/host", create:"True", type: get_default(:sync_method)
node.vm.synced_folder "storage/shared/", "/data/shared", create:"True", type: get_default(:sync_method) node.vm.synced_folder File.join(vagrant_dir, 'storage', 'shared'), "/data/shared", create:"True", type: get_default(:sync_method)
node.vm.synced_folder ".", get_default(:vagrant_shared_folder), disabled: true node.vm.synced_folder ".", get_default(:vagrant_shared_folder), disabled: true
node.vm.provider PROVIDER do |vm| node.vm.provider PROVIDER do |vm|
vm.memory = get_setting(node_type.to_sym, :memory) vm.memory = get_setting(node_type.to_sym, :memory)

View File

@ -0,0 +1,80 @@
# -*- mode: ruby -*-
# vi: set ft=ruby :
# This file is an example of Vagrant configuration.
# Copy it to Vagrantfile.custom and configure it to your liking to customize
# the Vagrant deployment. The Vagrantfile.custom file is sourced by the
# Vagrantfile, it has to be valid ruby code.
# Either libvirt or virtualbox
# PROVIDER = "libvirt"
# Either centos or ubuntu
# DISTRO = "centos"
# PROVIDER_DEFAULTS = {
# libvirt: {
# centos: {
# base_image: "centos/7",
# bridge_interface: "virbr0",
# vagrant_shared_folder: "/home/vagrant/sync",
# sync_method: "nfs",
# provision_script: "bootstrap.sh",
# kolla_path: "/home/vagrant/kolla"
# }
# },
# virtualbox: {
# centos: {
# base_image: "puppetlabs/centos-7.0-64-puppet",
# bridge_interface: "wlp3s0b1",
# vagrant_shared_folder: "/vagrant",
# sync_method: "virtualbox",
# provision_script: "bootstrap.sh",
# kolla_path: "/home/vagrant/kolla"
# },
# ubuntu: {
# base_image: "ubuntu/vivid64",
# bridge_interface: "wlp3s0b1",
# vagrant_shared_folder: "/home/vagrant/sync",
# sync_method: "nfs",
# provision_script: "ubuntu-bootstrap.sh",
# kolla_path: "/usr/local/kolla"
# }
# }
# }
# Whether to do Multi-node or All-in-One deployment
# MULTINODE = false
# The following is only used when deploying in Multi-nodes
# NUMBER_OF_CONTROL_NODES = 3
# NUMBER_OF_COMPUTE_NODES = 1
# NUMBER_OF_STORAGE_NODES = 1
# NUMBER_OF_NETWORK_NODES = 1
# NODE_SETTINGS = {
# aio: {
# cpus: 4,
# memory: 4096
# },
# operator: {
# cpus: 1,
# memory: 1024
# },
# control: {
# cpus: 1,
# memory: 2048
# },
# compute: {
# cpus: 1,
# memory: 1024
# },
# storage: {
# cpus: 1,
# memory: 1024
# },
# network: {
# cpus: 1,
# memory: 1024
# }
# }