AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 1098802
Accepted
Keith
Keith
Asked: 2022-04-18 05:11:56 +0800 CST2022-04-18 05:11:56 +0800 CST 2022-04-18 05:11:56 +0800 CST

将公共 IPv4 自动分配给正在创建的每个 KVM 虚拟机?

  • 772

我想知道我将如何继续为正在创建的每个 vm 分配一个公共 ipv4。

设置:使用 libvirt 和 kvm 在 CentOS8 上具有 3 个 IP 的主机服务器使用 eth0 作为接口虚拟化 Bridge br0。

经过大量的试验和错误后,我设法通过使用网桥并将 IP 地址分配给来宾操作系统网络文件的接口来手动完成。

虽然我希望这将是自动的,考虑到如果我现在重新安装操作系统,它将回到没有 IP 地址和 id 必须连接到访客并每次手动编辑网络文件中的 ipv4 地址。我怎样才能避免这种情况?

目标:每个 IPv4 都被硬锁定到虚拟机,并且无论操作系统是否重新安装都将保留。

可选目标:如果主机操作系统中的任何 IPv4 未被使用,则应将其分配给下一个创建的 VM。

我每次都必须编写自己的软件来执行此操作还是有更简单的方法?

virtualization networking kvm-virtualization ip-address libvirt
  • 1 1 个回答
  • 185 Views

1 个回答

  • Voted
  1. Best Answer
    Nikita Kipriyanov
    2022-04-18T06:02:45+08:002022-04-18T06:02:45+08:00

    这就是 DHCP 的用途。

    你可以自由选择他们的MAC地址,对吧?在与 VM 相同(可能是虚拟的)以太网段中的系统上设置 DHCP 服务器,并将您的 IP 绑定到某些 MAC。

    您还需要分发一些路由(使用 DHCP 选项 121 和 249)。自带DHCP服务器的机器本身不需要公网IP或者IP与所有客户端在同一个网络;当客户端上仍然没有配置地址时,与 DHCP 服务器的通信就会发生。

    如果您使用 ISC DHCP,则需要执行以下操作。我假设您的主机是您的路由器和虚拟机的 NAT 盒,它还将托管您的 DHCP 服务器。如果您想做其他方式,则需要稍作调整:

    • 在顶部附近定义选项 121 和 249 dhcpd.conf:
    option rfc3442-classless-static-routes code 121 = array of integer 8;
    option ms-classless-static-routes code 249 = array of integer 8;
    

    可能,新版本不需要这个,但我的需要。

    • 创建一个shared-network块,将您的动态私有子网和您的公共地址作为掩码 32 的“子网”:
    option routers 192.168.210.1;
    option domain-name-servers 8.8.8.8, 8.8.4.4;
    
    shared-network libvirt-vm-net {
        subnet 192.168.210.0 netmask 255.255.255.0 {
            range 192.168.210.2 192.168.210.254;
        }
    
        subnet 192.0.2.1 netmask 255.255.255.255 {
            option rfc3442-classless-static-routes 32, 192,168,210,1, 0,0,0,0, 0, 192,168,210,1;        
            option ms-classless-static-routes      32, 192,168,210,1, 0,0,0,0, 0, 192,168,210,1;        
        }
    
        ...
    }
    

    我假设您在 NAT 后面的机器的“专用”网络将是 192.168.210.0/24,并且该网络中的主机将是 0.1(分配给网桥)。静态无类路由(选项 121 和 249)设置将添加以下路由:

    ip route add 192.168.210.1 dev eth0
    ip route add default via 192.168.210.1
    

    尽管没有包含 192.0.2.1/32 和 192.168.210.1 的子网,但一切都需要它;如果您不确定此路由的工作原理,最好在实验室环境中尝试此类设置

    • 使用绑定到静态 IP 地址的所需 MAC 地址创建主机定义:
    host public-server-1 { hardware ethernet 00:11:22:33:44:55; fixed-address 192.0.2.1; }
    ...
    
    • 将这些 MAC 的静态邻居(“ARP”)条目添加到/etc/ethers(在主机上):
    00:11:22:33:44:55 192.0.2.1
    ...
    
    • 通过相应的网桥接口向这些地址添加静态路由;我不知道如何使用你的操作系统发行版的标准网络配置来做到这一点,但通用的 Linux 方式是这样的:
    ip route add 192.0.2.1 dev br0
    ...
    

    然后确保将这些 MAC 分配给 libvirt 配置中的重要虚拟机。其他 VM(其 MAC 未绑定)将照常从配置的范围中获取其地址。

    实际上,我在甚至“更复杂”的设置(DHCP、主机和路由器都是不同的系统)中实现并测试了这个设置,我也不使用 libvirt,我的主机是 PVE。即使是 PXE 引导也适用于“普通”子网机器(如示例中的 192.168.210.0)和“公共 IP”机器(如 192.0.2.1)。

    要允许所有虚拟机访问 Internet,您必须将 NAT 用于私有 IP,并且不要将其用于公共 IP;这不是问题,使用类似的规则iptables -t nat -A POSTROUTING -o <physical-interface-with-public-ip> -s <private-ip-range> -j MASQUERADE。这样,您的私有范围将被转换为主机本身的面向公众的地址,但公共地址不会被转换,而是会按原样路由。同样,在同一个网段上拥有公共和私有地址并通过同一个虚拟 NIC 是没有问题的。

    • 0

相关问题

  • 哪些 939 插槽芯片支持 AMD-V?

  • Windows Server 2008 Hyper-V 虚拟化服务器的最佳 RAID 配置?

  • VirtualBox 上 Ubuntu 的访客优化技巧 [关闭]

  • 外部硬盘上的 virtualbox 虚拟硬盘驱动器(Vista 主机上的 ubuntu 客户机)

  • 物理机重启时自动重启虚拟机(VMWare)

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve