从docker容器内访问vagrant VMs

Sam*_*vdc 5 networking vagrant docker

如何在使用Vagrant/Virtualbox的2 centos VM和使用docker for mac的docker容器之间建立网络.他们都需要能够互相访问.

目前我无法从docker容器中访问vm.

流浪的设置:

Vagrant.configure("2") do |config|

   config.vm.define "build" do |build|
      build.vm.box = "centos/7"
      build.vm.provider "virtualbox"
      build.vm.hostname = "server-a"
      build.vm.network "private_network", ip: "192.168.50.4"
   end

   config.vm.define "test" do |test|
      test.vm.box = "centos/7"
      test.vm.provider "virtualbox"
      test.vm.hostname = "server"
      test.vm.network "private_network", ip: "192.168.50.5"
   end
end
Run Code Online (Sandbox Code Playgroud)

vm可以互相访问,但是docker容器无法访问vm

docker network create -d bridge --gateway=192.168.50.1 --subnet=192.168.50.1/24 mybridge
docker run --network=mybridge alpine ping 192.168.50.4
=> not able to connect
Run Code Online (Sandbox Code Playgroud)

Nic*_*lay 10

您需要连接运行docker容器的网络和将虚假VM引导到主机上相同桥接设备的网络:

1.创建docker网络:

docker network create -d bridge --gateway=192.168.50.1
--subnet=192.168.50.1/24 mybridge
Run Code Online (Sandbox Code Playgroud)

Docker br-<network_id>在主机上创建名称为bridge的桥:

$ docker network ls | grep mybridge
e13b3ccc6691        mybridge              bridge              local

$ brctl show | grep e13b3ccc6691
br-e13b3ccc6691     8000.024277661b29   no  

$ ip r s | grep e13b3ccc6691
192.168.50.0/24 dev br-e13b3ccc6691  proto kernel  scope link  src 192.168.50.1 linkdown 
Run Code Online (Sandbox Code Playgroud)

2.将vagrant VMs网络连接到同一个桥接设备:

Vagrant.configure("2") do |config|
   config.vm.define "build" do |build|
      build.vm.box = "centos/7"
      build.vm.provider "virtualbox"
      build.vm.hostname = "server-a"
      build.vm.network "public_network", ip: "192.168.50.4", bridge: "br-e13b3ccc6691"
   end

   config.vm.define "test" do |test|
      test.vm.box = "centos/7"
      test.vm.provider "virtualbox"
      test.vm.hostname = "server"
      test.vm.network "public_network", ip: "192.168.50.5", bridge: "br-e13b3ccc6691"
   end
end
Run Code Online (Sandbox Code Playgroud)

3.引导VM:

$ vagrant up
Run Code Online (Sandbox Code Playgroud)

4.mybridge网络中启动docker容器:

$ docker run -ti --network=mybridge alpine ping -c2 192.168.50.4
PING 192.168.50.4 (192.168.50.4): 56 data bytes
64 bytes from 192.168.50.4: seq=0 ttl=64 time=0.898 ms
64 bytes from 192.168.50.4: seq=1 ttl=64 time=0.869 ms

--- 192.168.50.4 ping statistics ---
2 packets transmitted, 2 packets received, 0% packet loss
round-trip min/avg/max = 0.869/0.883/0.898 ms
Run Code Online (Sandbox Code Playgroud)

  • 感谢您的热烈响应,我已经在 linux 工作站上进行了这项工作。但是使用“docker for mac”我无法桥接网络。当进一步查看“docker for mac”文档时,这似乎是一个已知的限制。:) https://docs.docker.com/docker-for-mac/networking/#known-limitations-use-cases-and-workarounds (2认同)