为什么我会失去/ 24以外的虚拟机的networking连接?

我有一大堆虚拟机(Ubuntu Server 14.04)托pipe在一台真正的服务器上(Ubuntu Server 14.04 with KVM)。 虚拟机的数量在增长,我很快就会有超过254个。

去testing,

  1. 我在真实服务器的/etc/network/interfaces中将networking掩码从255.255.255.0更改为255.255.254.0 。 真实服务器的IP地址是192.168.1.30

  2. 我用virsh net-edit default做了类似的操作,把virbr0的networking掩码改为255.255.254.0

  3. 我也改变了交换机的networking掩码为255.255.254.0

  4. 我改变了testing虚拟机的configuration,像这样:

     auto eth0 iface eth0 inet static address 192.168.2.35 netmask 255.255.254.0 network 192.168.1.0 broadcast 192.168.2.255 gateway 192.168.1.1 dns-nameservers 192.168.1.13 dns-search example.com 

这是目前的状态:

  1. 我不能ping 192.168.2.35从真正的服务器:它只是坚持“PING 192.168.2.35(192.168.2.35)56(84)字节的数据”。 当停止(Ctrl + C)时,它会抱怨:“143个数据包传输,0收到,100%丢包,时间142134ms”。

  2. 虚拟机192.168.2.35不能ping任何东西(无论是交换机,也不是真正的服务器,也不是google.com),抛出前两个“连接:networking无法访问”错误,或“ping:unknown host google.com “为最后一个。

  3. 虚拟机可以自己ping。

我的configuration有什么问题?

我还是不明白为什么/ 22而不是/ 23

由于您计算的子网错误,并且您尝试使用来自两个不同子网的IP。

或者换一种说法,如果使用/ 23位掩码作为范围的起始地址,则必须是该范围的第一个地址。 192.168.1.1不是23位掩码描述的任何networking的起始地址,因为这只是math运算的结果。

使用23位掩码,有效的networking如下所示。

 $ ipcalc 192.168.0.0/23 Address: 192.168.0.0 11000000.10101000.0000000 0.00000000 Netmask: 255.255.254.0 = 23 11111111.11111111.1111111 0.00000000 Wildcard: 0.0.1.255 00000000.00000000.0000000 1.11111111 => Network: 192.168.0.0/23 11000000.10101000.0000000 0.00000000 HostMin: 192.168.0.1 11000000.10101000.0000000 0.00000001 HostMax: 192.168.1.254 11000000.10101000.0000000 1.11111110 Broadcast: 192.168.1.255 11000000.10101000.0000000 1.11111111 Hosts/Net: 510 $ ipcalc 192.168.2.0/23 Address: 192.168.2.0 11000000.10101000.0000001 0.00000000 Netmask: 255.255.254.0 = 23 11111111.11111111.1111111 0.00000000 Wildcard: 0.0.1.255 00000000.00000000.0000000 1.11111111 => Network: 192.168.2.0/23 11000000.10101000.0000001 0.00000000 HostMin: 192.168.2.1 11000000.10101000.0000001 0.00000001 HostMax: 192.168.3.254 11000000.10101000.0000001 1.11111110 Broadcast: 192.168.3.255 11000000.10101000.0000001 1.11111111 Hosts/Net: 510 

在你的接口configuration中,虽然你似乎有address 192.168.2.35gateway 192.168.1.1 。 鉴于这个掩码你的网关和地址是在完全独立的子网上。 当然你的广播和networking地址设置也是不正确的。

如果使用22位掩码,则会得到一个包含192.168.1.x和192.168.2.x的范围。 被警告你的广播,networking价值还是错误的,他们也需要修正。

 $ ipcalc 192.168.2.0/22 Address: 192.168.2.0 11000000.10101000.000000 10.00000000 Netmask: 255.255.252.0 = 22 11111111.11111111.111111 00.00000000 Wildcard: 0.0.3.255 00000000.00000000.000000 11.11111111 => Network: 192.168.0.0/22 11000000.10101000.000000 00.00000000 HostMin: 192.168.0.1 11000000.10101000.000000 00.00000001 HostMax: 192.168.3.254 11000000.10101000.000000 11.11111110 Broadcast: 192.168.3.255 11000000.10101000.000000 11.11111111 Hosts/Net: 1022