Назад | Перейти на главную страницу

Как сделать простой сетевой мост в Vagrant?

Я пытаюсь настроить самую простую демонстрацию сетевого моста в Vagrant. У меня есть две машины в одной подсети, но в разных локальных сетях, и машина-мост с двумя интерфейсами и сетевой мост, который настраивается в сценарии подготовки.

Вот мой 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

Я не могу заставить одну машину успешно пинговать другую. С помощью tcpdump Я обнаружил, что запрос ARP передается от machine1 полностью до machine2, но когда machine2 отвечает, до ответа даже не доходит eth2 на bridge. (Я вижу ответ ARP только при прослушивании eth1 в machine2.

Как я могу заставить это работать?

Оказывается, по умолчанию VirtualBox не позволяет иметь беспорядочные сетевые адаптеры, вы должны явно включить его.

Я добавил следующие строки в bridge определение и все начало работать:

bridge.vm.provider :virtualbox do |vb|
  vb.customize ["modifyvm", :id, "--nicpromisc2", "allow-all"]
  vb.customize ["modifyvm", :id, "--nicpromisc3", "allow-all"]
end