为 minikube 正在运行的现有虚拟桥设置桥

为 minikube 正在运行的现有虚拟桥设置桥

我设法使用 kvm2 驱动程序在我的系统上设置了 minikube,它似乎可以工作。但是我希望能够启动仪表板并从外部访问它,即从网络内的另一个设备访问它。

我跑了virsh net-dumpxml minikube-net

<network>
  <name>minikube-net</name>
  <uuid>c382666a-6aee-48bf-bfd9-3b782c423fad</uuid>
  <bridge name='virbr1' stp='on' delay='0'/>
  <mac address='52:54:00:da:f8:54'/>
  <dns enable='no'/>
  <ip address='192.168.39.1' netmask='255.255.255.0'>
    <dhcp>
      <range start='192.168.39.2' end='192.168.39.254'/>
    </dhcp>
  </ip>
</network>

我跑了ip addr

1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
       valid_lft forever preferred_lft forever
    inet6 ::1/128 scope host
       valid_lft forever preferred_lft forever
2: eth0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc mq state UP group default qlen 1000
    link/ether 00:15:5d:38:01:0c brd ff:ff:ff:ff:ff:ff
    inet 10.0.0.201/24 brd 10.0.0.255 scope global noprefixroute dynamic eth0
       valid_lft 85622sec preferred_lft 85622sec
    inet6 fe80::d286:599c:62eb:c6f1/64 scope link noprefixroute
       valid_lft forever preferred_lft forever
3: virbr0: <NO-CARRIER,BROADCAST,MULTICAST,UP> mtu 1500 qdisc noqueue state DOWN group default qlen 1000
    link/ether 52:54:00:34:cb:78 brd ff:ff:ff:ff:ff:ff
    inet 192.168.122.1/24 brd 192.168.122.255 scope global virbr0
       valid_lft forever preferred_lft forever
4: virbr0-nic: <BROADCAST,MULTICAST> mtu 1500 qdisc pfifo_fast master virbr0 state DOWN group default qlen 1000
    link/ether 52:54:00:34:cb:78 brd ff:ff:ff:ff:ff:ff
5: virbr1: <NO-CARRIER,BROADCAST,MULTICAST,UP> mtu 1500 qdisc noqueue state DOWN group default qlen 1000
    link/ether 52:54:00:da:f8:54 brd ff:ff:ff:ff:ff:ff
    inet 192.168.39.1/24 brd 192.168.39.255 scope global virbr1
       valid_lft forever preferred_lft forever
6: virbr1-nic: <BROADCAST,MULTICAST> mtu 1500 qdisc pfifo_fast master virbr1 state DOWN group default qlen 1000
    link/ether 52:54:00:da:f8:54 brd ff:ff:ff:ff:ff:ff

现在我第一次编辑 ifcfg-eth0 文件以包含以下行:

BRIDGE=virbr1

然后我在同一文件夹中创建了一个名为 ifcfg-virbr1 的文件并将其添加到其中:

DEVICE="virbr1"
BOOTPROTO="dhcp"
IPV6INIT="yes"
IPV6_AUTOCONF="yes"
ONBOOT="yes"
TYPE="Bridge"
DELAY="0"

我重启了虚拟机,希望我的 minikube-net 现在能从路由器获得 DHCP 分配的 IP 地址,但不幸的是没有。此外,我无法再通过 ssh 进入虚拟机。

更多信息 我在 Hyper-V(嵌套虚拟化)中运行 Centos 7 vm。

您知道如何设置我的 minikube-net 以便我可以从网络外部访问它和内部内容吗?

答案1

在我看来,从外部访问 kubernetes-dashboard 的最简单方法是首先在 NodePort 上公开它,然后执行转发端口在主机上的 KVM 上(例如 8081:31504)。

默认情况下,minikube 的 kubernetes-dashboard 插件在 ClusterIP 端口类型上公开。要将其更改为 NodePort,您可以使用:

kubectl edit svc/kubernetes-dashboard -n kube-system

使用以下命令获取 NodePort IP:

kubectl get svc/kubernetes-dashboard -n kube-system -o jsonpath='{.spec.ports[0].nodePort}'

您可以通过以下方式访问仪表板:

  • 本地主机:<minikube ip>:<NodePort>
  • 远程:<host_ip>:<forwarded_port>

相关内容