This is a Vagrant 1.6+ plugin that adds an OpenStack Cloud provider to Vagrant, allowing Vagrant to control and provision machines within OpenStack cloud.
Note: This plugin was originally forked from mitchellh/vagrant-rackspace
- Create and boot OpenStack instances
- Halt and reboot instances
- Suspend and resume instances
- SSH into the instances
- Automatic SSH key generation and Nova public key provisioning
- Automatic floating IP allocation and association
- Provision the instances with any built-in Vagrant provisioner
- Boot instance from volume
- Attach Cinder volumes to the instances
- Create and delete Heat Orchestration stacks
- Support OpenStack regions
- Custom sub-commands within Vagrant CLI to query OpenStack objects
Install using standard Vagrant 1.1+ plugin installation methods. After
installing, vagrant up
and specify the openstack
provider. An example is
shown below.
$ vagrant plugin install vagrant-openstack-provider
...
$ vagrant up --provider=openstack
...
Of course prior to doing this, you'll need to obtain an OpenStack-compatible box file for Vagrant.
After installing the plugin (instructions above), the quickest way to get
started is to specify all the details manually within a config.vm.provider
block in the Vagrantfile
Create a Vagrantfile that looks like the following, filling in your information where necessary.
This Vagrantfile shows the minimal needed configuration.
require 'vagrant-openstack-provider'
Vagrant.configure('2') do |config|
config.vm.box = 'openstack'
config.ssh.username = 'stack'
config.vm.provider :openstack do |os|
os.openstack_auth_url = 'http://keystone-server.net/v2.0/tokens'
os.username = 'openstackUser'
os.password = 'openstackPassword'
os.tenant_name = 'myTenant'
os.flavor = 'm1.small'
os.image = 'ubuntu'
os.floating_ip_pool = 'publicNetwork'
end
end
And then run vagrant up --provider=openstack
.
Note that normally a lot of this boilerplate is encoded within the box file, but the box file used for the quick start, the "dummy" box, has no preconfigured defaults.
This provider exposes quite a few provider-specific configuration options:
username
- The username with which to access OpenStack.password
- The API key for accessing OpenStack.domain_name
- The domain name when using identity API version 3 of keystonetenant_name
- The OpenStack project name to work onproject_name
- The OpenStack project name used in identity v3identity_api_version
- The identity version to use : 2 or 3. If not provided, vagrant will use 2 by default.region
- The OpenStack region to work onopenstack_auth_url
- The endpoint to authenticate against.openstack_compute_url
- The compute service URL to hit. This is good for custom endpoints. If not provided, vagrant will try to get it from catalog endpoint.openstack_network_url
- The network service URL to hit. This is good for custom endpoints. If not provided, vagrant will try to get it from catalog endpoint.openstack_volume_url
- The block storage URL to hit. This is good for custom endpoints. If not provided, vagrant will try to get it from catalog endpoint.openstack_image_url
- The image URL to hit. This is good for custom endpoints. If not provided, vagrant will try to get it from catalog endpoint.endpoint_type
- The endpoint type to use : publicURL, adminURL, internalURL. If not provided, vagrant will use publicURL by default.interface_type
- The endpoint type to use for identity v3: public, admin, internal. If not provided, vagrant will use public by default.
server_name
- The name of the server within OpenStack Cloud. This defaults to the name of the Vagrant machine (viaconfig.vm.define
), but can be overridden with this.flavor
- The name of the flavor to use for the VMimage
- The name of the image to use for the VMavailability_zone
- Nova Availability zone used when creating VMsecurity_groups
- List of strings representing the security groups to apply. e.g. ['ssh', 'http']user_data
- String of User data to be sent to the newly created OpenStack instance. Use this e.g. to inject a script at boot time.metadata
- A Hash of metadata that will be sent to the instance for configuration e.g.os.metadata = { 'key' => 'value' }
scheduler_hints
- Pass hints to the OpenStack scheduler, e.g. { "cell": "some cell name" }
floating_ip
- The floating IP to associate with the VM. This IP must be formerly allocated.floating_ip_pool
- The floating IP Pool or a list of floating IP pool from which a floating IP will be allocated to be associated with the VM. alternative to thefloating_ip
option.
floating_ip_pool
attribute can be either a string or an array. In case of an array, if an IP can't be allocated from the first pool
for any reason, it will try with the second one and so on. Finally, if it does not manage to allocate a floating IP from any pools of
the list, it will fail.
config.vm.provider :openstack do |os|
...
os.floating_ip_pool = ['External-Network-01', 'External-Network-02']
...
end
floating_ip_pool_always_allocate
- if set to true, vagrant will always allocate floating ip instead of trying to reuse unassigned ones
N.B.
If the instance have a floating IP, this IP will be used to SSH into the instance.
networks
- Network list the server must be connected on. Can be omitted if only one private network exists in the OpenStack project
Networking features in the form of config.vm.network
are not
supported with vagrant-openstack
, currently. If any of these are
specified, Vagrant will emit a warning, but will otherwise boot
the OpenStack server.
You can provide network id or name. However, in OpenStack a network name is not unique, thus if there are two networks with the same name in your project the plugin will fail. If so, you have to use only ids. Optionally, you can specify the IP address that will be assigned to the instance if you need a static address or if DHCP is not enable for this network.
Here's an example which connect the instance to six Networks :
config.vm.provider :openstack do |os|
...
os.networks = [
'net-name-01',
'287132f0-57e6-4c31-a1ee-4823e9786ff2',
{
name: 'net-name-03',
address: '192.168.22.43'
},
{
id: '7dfdcf01-5177-4774-9473-2ae92a6447d4',
address: '192.168.43.76'
},
{
name: 'net-name-05'
},
{
id: '01e0950f-c668-4efe-821b-93ff6e427562'
}
]
...
end
N.B.
If the instance does not have a floating IP, the IP of the first network in the list will be used to SSH into the instance
volumes
- Volume list that have to be attached to the server. You can provide volume id or name. However, in OpenStack a volume name is not unique, thus if there are two volumes with the same name in your project the plugin will fail. If so, you have to use only ids. Optionally, you can specify the device that will be assigned to the volume.
Here comes an example that show six volumes attached to a server :
config.vm.provider :openstack do |os|
...
os.volumes = [
'619e027c-f4a9-493d-8c15-c89de81cb949',
'vol-name-02',
{
id: '410096ff-ef71-4ca4-8006-e5bd9e99239a',
device: '/dev/vdc'
},
{
name: 'vol-name-04',
device: '/dev/vde'
},
{
name: 'vol-name-05'
},
{
id: '9e419e91-8f66-4803-bc45-4600182cfd8d'
}
]
...
end
volume_boot
- Volume to boot the VM from. When booting from an existing volume,image
is not necessary and must not be provided.
stacks
- Heat Stacks that will be automatically created when runningvagrant up
, and deleted when runningvagrant destroy
Here comes an example that show two stacks :
config.vm.provider :openstack do |os|
...
os.stacks = [
{
name: 'mystack1',
template: 'heat_template.yml'
}, {
name: 'mystack2',
template: '/path/to//my/heat_template.yml'
}]
end
keypair_name
- The name of the key pair register in nova to associate with the VM. The public key should be the matching pair for the private key configured withconfig.ssh.private_key_path
on Vagrant.public_key_path
- ifkeypair_name
is not provided, the path to the public key will be used by vagrant to generate a keypair on the OpenStack cloud. The keypair will be destroyed when the VM is destroyed.
If neither keypair_name
nor public_key_path
are set, vagrant will generate a new ssh key and automatically import it in OpenStack.
ssh_disabled
- if set totrue
, all ssh actions managed by the provider will be disabled during thevagrant up
. We recommend to use this option only to create private VMs that won't be accessed directly from vagrant. By contrast, others commands likevagrant ssh
orvagrant provision
is run normally but it is likely to fail. Default value isfalse
.
NOTE: The settings in this section are deprecated. By default, the OpenStack provider will use standard Vagrant Synced Folders. Vagrant's rsync options can be configured thusly:
Vagrant.configure("2") do |config|
config.vm.provider :openstack do |provider, override|
override.vm.synced_folder '.', '/vagrant', type: 'rsync',
rsync__exclude: ['some/folder/to/exclude']
end
end
Use of the settings described below will cause the OpenStack provider to fall back to a legacy Rsync implementation that has fewer features. A deprecation warning will also be printed.
sync_method
- Specify the synchronization method for shared folder between the host and the remote VM. Currently, it can be "rsync" or "none". The default value is "rsync". If your OpenStack image does not include rsync, you must set this parameter to "none".rsync_includes
- Ifsync_method
is set to "rsync", this parameter give the list of local folders to sync on the remote VM.rsync_ignore_files
- Is used for the rsync prameter "--exclude-from". Setrsync_ignore_files
to a list of files that contain patterns to exclude from the rsync to /vagrant on a provisioned instance. ".gitignore or ".hgignore" for example.
There is minimal support for synced folders. Upon vagrant up
,
vagrant reload
, and vagrant provision
, the OpenStack provider will use
rsync
(if available) to uni-directionally sync the folder to
the remote machine over SSH.
This is good enough for all built-in Vagrant provisioners (shell, chef, and puppet) to work!
server_create_timeout
- Time to wait in seconds for the server to be created whenvagrant up
. Default is200
server_active_timeout
- Time to wait in seconds for the server to become active whenvagrant up
orvagrant resume
. Default is200
server_stop_timeout
- Time to wait in seconds for the server to stop whenvagrant halt
. Default is200
server_delete_timeout
- Time to wait in seconds for the server to be deleted whenvagrant destroy
. Default is200
http.open_timeout
- Open timeout for any HTTP request. Default is60
http.read_timeout
- Read timeout for any HTTP request. Default is30
We call meta-args, dynamic arguments automatically injected by the vagrant OpenStack provider as
a provisioner argument. The notation for a meta-arg is its name surrounded by double @
character.
The current implementation supports only shell provisioner.
meta_args_support
- Whether meta-args injection is activated or not. Default isfalse
Available meta-args
@@ssh_ip@@
- The IP used by Vagrant to SSH into the machine
Usage example
config.vm.provision "shell", inline: 'echo "$1 : $2" > ~/provision', args: ['IP', '@@ssh_ip@@']
N.B.
Activate meta-args support causes Vagrant to wrap the built-in provisioning middleware into a custom one provided by the OpenStack provider. As a consequence, hooks declared on the built-in provisioning middleware will not be applied (see #248)
There are some standard configuration options that this provider takes into account when creating and connecting to OpenStack machines
config.vm.box
- A box is not mandatory for this provider. However, if you are running Vagrant before version 1.6, vagrant will not start if this property is not set. In this case you can assign any value to it. See section "Box Format" to know more about boxes.config.vm.box_url
- URL of the box when it is necessaryssh.username
- Username used by vagrant for SSH loginssh.port
- Default SSH port is 22. If set, this option will override the default for SSH loginssh.private_key_path
- If set, vagrant will use this private key path to SSH on the machine. If you set this option, thepublic_key_path
option of the provider should be set.
Every provider in Vagrant must introduce a custom box format. This
provider introduces openstack
boxes. You can view an example box in
the example_box/ directory.
That directory also contains instructions on how to build a box.
The box format is basically just the required metadata.json
file
along with a Vagrantfile
that does default settings for the
provider-specific configuration for this provider.
Custom commands are provided for OpenStack. Type vagrant openstack
to
show available commands.
$ vagrant openstack
Usage: vagrant openstack command
Available subcommands:
image-list List available images
flavor-list List available flavors
network-list List private networks in project
subnet-list List subnets for available networks
floatingip-list List floating IP and floating IP pools
volume-list List existing volumes
reset Reset Vagrant OpenStack provider to a clear state
For instance vagrant openstack image-list
lists images available in Glance.
$ vagrant openstack image-list
+--------------------------------------+---------------------+
| ID | Name |
+--------------------------------------+---------------------+
| 594f1287-9de3-4f3e-b82a-6ad223943ab2 | ubuntu-12.04_x86_64 |
| 3e5aca4a-bf12-4721-87df-7bc8fd1fc36c | debian7_x86_64 |
| 3e561121-d8d0-4328-b319-7076bfb3b18a | ubuntu-14.04_x86_64 |
| 5c576643-7ea3-49db-b1c0-9b245d955ee0 | rhel65_x86_64 |
| d3145dd5-654a-4936-b421-9333f02ae66c | centos6_x86_64 |
+--------------------------------------+---------------------+
To work on the vagrant-openstack
plugin, clone this repository out, and use
Bundler to get the dependencies:
Note: Vagrant 1.6 requires bundler version < 1.7. We recommend using last 1.6 version.
$ gem install bundler -v 1.6.6
Install the plugin dependencies
$ bundle install
Once you have the dependencies, verify the unit tests pass with rake
:
$ bundle exec rake
If those pass, you're ready to start developing the plugin. You can test
the plugin without installing it into your Vagrant environment by just
creating a Vagrantfile
in the top level of this directory (it is gitignored)
that uses it, and uses bundler to execute Vagrant:
$ bundle exec vagrant up --provider=openstack
To enable all Vagrant logs set environment variable VAGRANT_LOG
to the desire
log level (for instance VAGRANT_LOG=debug
). If you want only OpenStack provider
logs use the variable VAGRANT_OPENSTACK_LOG
. if both variables are set, VAGRANT_LOG
takes precedence.
The default configuration of the RHEL family of Linux distributions requires a tty in order to run sudo. Vagrant does not connect with a tty by default, so you may experience the error:
sudo: sorry, you must have a tty to run sudo
The best way to take deal with this error is to upgrade to Vagrant 1.4 or later, and enable:
config.ssh.pty = true
We thanks Numergy for giving us access to free compute resources on their OpenStack cloud that enabled us to test our provider on a real OpenStack installation.
If you are also powering an OpenStack cloud, we'd like to hear from you. Test the plugin and report us issues or features you'd like to see.