A plugin to configure a VLAN within a guest.
The implementation relies on Vagrant's guest capabilities. Currently, the plugin supports only Debian-derived guests and in particular has been tested only on Ubuntu. However, contributions to add support for other guests are more than welcome.
Use vagrant plugin install
:
$ vagrant plugin install vagrant-vlan
Setting up a VLAN is accomplished using the config.vlan.add
gestures. The gesture takes similar parameters to config.vm.network
, with
some exceptions. Valid parameters are as follows:
vlan
The VLAN identifier. An integer in the range [1, 4094].parent
The parent (or physical) interface to which the VLAN interface should attach.type
Method of IP assignment. Valid values are "dhcp" and "static".ip
Required iftype
is "static". The IP address to be assigned to the interface.netmask
Required iftype
is "static". The netmask to use for the interface.
The name of the interface will be constructed automatically using the format
parent
.vlan
.
Note that the VLAN plugin runs immediately after Vagrant network configuration,
so parent
can include interfaces configured using config.vm.network
.
Create VLAN 5 on interface eth0
, and assign it the static IP 10.0.1.2/24.
The name of the VLAN interface will be eth0.5
.
config.vlan.add vlan: 5, parent: "eth0",
type: "static", ip: "10.0.1.2", netmask: "255.255.255.0"
The config
object in the example is what was passed by Vagrant to the
config.vm.define
block.
- Fork it
- Create your feature branch (
git checkout -b my-new-feature
) - Commit your changes (
git commit -am 'Add some feature'
) - Push to the branch (
git push origin my-new-feature
) - Create a new Pull Request