Estou tentando configurar a demonstração de ponte de rede mais básica no Vagrant. Tenho duas máquinas na mesma sub-rede, mas em LANs diferentes, e uma máquina ponte com duas interfaces e uma ponte de rede que é configurada em um script de provisionamento.
Aqui está o meu Vagrantfile
:
$bridge_script = <<SCRIPT
sudo apt-get update
sudo apt-get install -y bridge-utils
sudo brctl addbr br0
sudo brctl addif br0 eth1 eth2
sudo ifconfig br0 up
SCRIPT
Vagrant.configure(2) do |config|
config.vm.define "machine1" do |machine1|
machine1.vm.box = "hashicorp/precise64"
machine1.vm.network "private_network", ip: "192.168.1.2",
virtualbox__intnet: "lan1"
end
config.vm.define "bridge" do |bridge|
bridge.vm.box = "hashicorp/precise64"
bridge.vm.network "private_network", ip: "0.0.0.0",
virtualbox__intnet: "lan1"
bridge.vm.network "private_network", ip: "0.0.0.0",
virtualbox__intnet: "lan2"
bridge.vm.provision :shell, inline: $bridge_script
end
config.vm.define "machine2" do |machine2|
machine2.vm.box = "hashicorp/precise64"
machine2.vm.network "private_network", ip: "192.168.1.3",
virtualbox__intnet: "lan2"
end
end
Não consigo fazer com que nenhuma das máquinas execute ping na outra com êxito. Usando tcpdump
descobri que uma solicitação ARP é passada machine1
até machine2
, mas quando machine2
responde, a resposta nem chega eth2
a bridge
. (Eu só vejo a resposta ARP quando ouço no eth1
formato machine2
.
Como posso fazer isso funcionar?
Responder1
Acontece que, por padrão, o VirtualBox não permite NICs promíscuos, você precisa habilitá-lo explicitamente.
Adicionei as seguintes linhas à bridge
definição e as coisas começaram a funcionar:
bridge.vm.provider :virtualbox do |vb|
vb.customize ["modifyvm", :id, "--nicpromisc2", "allow-all"]
vb.customize ["modifyvm", :id, "--nicpromisc3", "allow-all"]
end