请假下大家,如何在 pve 中利用 openwrt 接管所有虚拟机的 ip 分配 - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
请不要把任何和邀请码有关的内容发到 NAS 节点。

邀请码相关的内容请使用 /go/in 节点。

如果没有发送到 /go/in,那么会被移动到 /go/pointless 同时账号会被降权。如果持续触发这样的移动,会导致账号被禁用。
njzy
V2EX    NAS

请假下大家,如何在 pve 中利用 openwrt 接管所有虚拟机的 ip 分配

  •  
  •   njzy 2023-11-27 09:40:41 +08:00 via iPhone 3789 次点击
    这是一个创建于 683 天前的主题,其中的信息可能已经有所发展或是发生改变。
    我局域网下已经有一个 dhcp 服务了 子网掩码为 255.255.0.0 分配地址段为 192.168.1.1-192.168.1.254

    pve vmbr0 的 ip 为 192.168.2.1 能做到开一台 openwrt 虚拟机接管所有虚拟机的 ip 分配吗 让它们分配到 192.168.2.*,同时不会跟我局域网中的 dhcp 发生冲突且可以互相访问
    第 1 条附言    2023-11-29 13:16:23 +08:00

    通过设置静态路由和nat ip伪装规则,目前已经实现,大致拓扑图可见: network

    13 条回复    2023-11-29 13:48:00 +08:00
    var1122
        1
    var1122  
       2023-11-27 09:48:10 +08:00
    openwrt 把挂上的虚拟网卡设置为 lan 口,然后其它虚拟机都挂这个虚拟网卡,然后就可以让 openwrt 分配 IP 了;
    好久没这么干了,之前这么做过
    var1122
        2
    var1122  
       2023-11-27 09:52:56 +08:00
    草,好像你想访问局域网的设备有点问题;;; G 了,这个我没实际落地过
    njzy
        3
    njzy  
    OP
       2023-11-27 09:57:10 +08:00 via iPhone
    @var1122 wan 口为 vmbr0 新建一个 vmbr1 作为 lan 口,然后其他虚拟机把网络桥接端口改为 vmbr1?
    totoro625
        4
    totoro625  
       2023-11-27 10:10:25 +08:00
    @njzy 互相访问有点麻烦
    openwrt 下的虚拟机 192.168.2.* 能访问上级 192.168.1.*
    上级 192.168.1.* 访问下级 192.168.2.* 挺麻烦的,我是直接在 openwrt 上建立端口转发,顺手安装 Tailscale 组网
    uion
        5
    uion  
       2023-11-27 10:14:14 +08:00
    https://github.com/xYx-c/build-openwrt
    可以参考我这个,pve 启动负责拨号的 openwrt 还未启动,做个延迟定时任务主动获取 dhcp 服务的分配的 ip
    var1122
        6
    var1122  
       2023-11-27 10:50:25 +08:00
    @njzy 这个方法就是 openwrt 做子路由了;同级路由下只能由一个 DHCP ,俩个就会冲突;可以试试配置 openwrt 做 NAT 转发,然主路由挂 192.168.2.1/24 的静态路由。
    afirefish
        7
    afirefish  
       2023-11-27 11:10:48 +08:00
    有多网口的话。比如说 A,B,C 三个网口。C 网口为 pve 的 vmbr0 。
    pve 创建虚拟机 openwrt ,直通网卡 A,B 。
    A 为 WAN ,接网关为 192.168.1.x 的路由器。openwrt 网关为 192.168.2.1 。
    B 为 LAN ,C 网口接 B 网口。
    然后关闭 openwrt 的 wan 防火墙,上级路由器配置静态路由。

    缺点就是白白浪费两个网口。
    totoro625
        8
    totoro625  
       2023-11-27 22:00:21 +08:00
    @afirefish #7 这样能实现什么,让 PVE 的 IP 变成 192.168.2.* 吗?,似乎没有任何作用,并不能使 192.168.1.* 访问下级 192.168.2.*
    totoro625
        9
    totoro625  
       2023-11-27 22:09:50 +08:00
    @afirefish #7 弄错了,上级路由器配置静态路由后就能访问下级了

    感觉单网口就能实现,创建一个虚拟网卡 vmbr1
    pve 创建虚拟机 openwrt ,添加 vmbr0 作为 wan ,vmbr1 作为 lan
    在 PVE 网络管理界面删除 vmbr0 的 CIDR 及网关内容,在 vmbr1 添加 openwrt 的 CIDR 及网关内容,应用即可。
    njzy
        10
    njzy  
    OP
       2023-11-28 14:22:12 +08:00
    @totoro625 尝试了,我的主路由是 routeros ,加上静态路由后感觉并没有生效,访问不了二级路由,二级路由倒是可以访问一级
    njzy
        11
    njzy  
    OP
       2023-11-29 13:18:14 +08:00   1
    @totoro625 搞定了,就是加静态路由和 nat ip 伪装规则,详细的拓扑图可见我上面更新的内容
    xiaoxiang69460
        12
    xiaoxiang69460  
       2023-11-29 13:34:35 +08:00
    感觉 PVE 里的 2 个 Openwrt VM 可以合并为一个。VM 的 Openwrt 可以防火墙配置为无 NAT ,配合上级 RouterOS 设置静态路由达到 2 个网段互访,且内网没有 NAT ,仅需要配置 RouterOS NAT 192.168.0.0/16 到外网即可(因为没用过 RouterOS ,不太清楚是否需要额外设置,Openwrt 我目前在用,是不需要的)。
    njzy
        13
    njzy  
    OP
       2023-11-29 13:48:00 +8:00
    @xiaoxiang69460 分两个原因我是希望 nas 虚拟机还有 emby 服务可以正常网络发现,不然都是 10.0.0.0/24 网段里,打开 infuse app 应该不会自动搜到这两个服务
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     3569 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 33ms UTC 04:16 PVG 12:16 LAX 21:16 JFK 00:16
    Do have faith in what you're doing.
    ubao snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86