• VPP创建接口


    上个实验中,我们发现新安装的VPP中没有接口,一般是需要像颜老师那样通过DPDK来纳管主机的接口的,但也有一种方式是创建VETH。

    在 Linux 中,有一种接口叫做“veth”,像是Windows里面的虚拟网卡,但veth设备是成对出现的,一端连接内核的协议栈,另一端相连VPP的接口。所以,也可以将“veth”接口视为具有两端(而不是一端)的接口。

    首先,在内核创建一个veth接口,一端命名为ethvpp,另一端命名为ethhost。

    [root@localhost ~]# ip link add name ethvpp type veth peer name ethhost

    [root@localhost ~]# ip link

    1: lo: mtu 65536 qdisc noqueue state UNKNOWN mode DEFAULT group default qlen 1000

        link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00

    2: ens192: mtu 1500 qdisc mq state UP mode DEFAULT group default qlen 1000

        link/ether 00:0c:29:13:d9:6c brd ff:ff:ff:ff:ff:ff

    3: ethhost@ethvpp: mtu 1500 qdisc noop state DOWN mode DEFAULT group default qlen 1000

        link/ether 02:91:21:16:e5:e9 brd ff:ff:ff:ff:ff:ff

    4: ethvpp@ethhost: mtu 1500 qdisc noop state DOWN mode DEFAULT group default qlen 1000

    link/ether 3e:35:0f:15:74:a3 brd ff:ff:ff:ff:ff:ff

    这里我们可以看到接口3和4的名称分别是ethhost@ethvpp和ethvpp@ethhost,说明两个接口是有依赖关系的。

    开启veth接口的两端。

    ip link set dev ethvpp up

    ip link set dev ethhost up

    [root@localhost ~]# ip link set dev ethvpp up

    [root@localhost ~]# ip link set dev ethhost up

    [root@localhost ~]# ip link

    1: lo: mtu 65536 qdisc noqueue state UNKNOWN mode DEFAULT group                      default qlen 1000

        link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00

    2: ens192: mtu 1500 qdisc mq state UP mode DEFAULT gr                     oup default qlen 1000

        link/ether 00:0c:29:13:d9:6c brd ff:ff:ff:ff:ff:ff

    3: ethhost@ethvpp: mtu 1500 qdisc noqueue state UP mo                     de DEFAULT group default qlen 1000

        link/ether 02:91:21:16:e5:e9 brd ff:ff:ff:ff:ff:ff

    4: ethvpp@ethhost: mtu 1500 qdisc noqueue state UP mo                     de DEFAULT group default qlen 1000

        link/ether 3e:35:0f:15:74:a3 brd ff:ff:ff:ff:ff:ff

    [root@localhost ~]# ip addr

    1: lo: 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: ens192: mtu 1500 qdisc mq state UP group default q                     len 1000

        link/ether 00:0c:29:13:d9:6c brd ff:ff:ff:ff:ff:ff

        inet 192.168.1.131/24 brd 192.168.1.255 scope global noprefixroute ens192

           valid_lft forever preferred_lft forever

        inet6 2408:8207:1918:7790:b931:4b6f:5bda:8e59/64 scope global noprefixroute dynamic                    

           valid_lft 258934sec preferred_lft 172534sec

        inet6 fe80::f797:19ba:c532:71a4/64 scope link noprefixroute

           valid_lft forever preferred_lft forever

    3: ethhost@ethvpp: mtu 1500 qdisc noqueue state UP gr                     oup default qlen 1000

        link/ether 02:91:21:16:e5:e9 brd ff:ff:ff:ff:ff:ff

        inet6 fe80::91:21ff:fe16:e5e9/64 scope link

           valid_lft forever preferred_lft forever

    4: ethvpp@ethhost: mtu 1500 qdisc noqueue state UP gr                     oup default qlen 1000

        link/ether 3e:35:0f:15:74:a3 brd ff:ff:ff:ff:ff:ff

        inet6 fe80::3c35:fff:fe15:74a3/64 scope link

           valid_lft forever preferred_lft forever

    可以看到,此时链路和接口均已经UO起来了,但是还没有地址,接下来先在内核中给ethhost分配一个IP地址。

    ip addr add 10.1.1.1/24 dev ethhost

    ip addr show ethhost

    [root@localhost ~]# ip addr add 10.1.1.1/24 dev ethhost

    [root@localhost ~]# ip addr show ethhost

    3: ethhost@ethvpp: mtu 1500 qdisc noqueue state UP group default qlen 1000

        link/ether 02:91:21:16:e5:e9 brd ff:ff:ff:ff:ff:ff

        inet 10.1.1.1/24 scope global ethhost

           valid_lft forever preferred_lft forever

        inet6 fe80::91:21ff:fe16:e5e9/64 scope link

           valid_lft forever preferred_lft forever

    使用命令vppctl进入VPP shell。

    可以看到,VPP中还是没有接口的。接下来,创建一个连接到ethvpp的主机接口。

    create host-interface name ethvpp

    可以看到,接口ethvpp创建成功,并且硬件状态是UP,但协议状态是DOWN。需要手工使能接口ethvpp。

    set interface state host-ethvpp up

    接口UP以后,再给接口分配IP地址。

    set int ip address host-ethvpp 10.1.1.2/24

    确认接口IP地址。

    然后ping测试一下。

    什么鬼,没有ping命令。再一看,好像命令少的有些可怜。

    原来是我只装了基础包的原因。

    先装一下plugins插件。

    然后重启VPP。

    再次进入VPP就有ping命令了,还多了一些其他命令。

    正好到这了,捎带看一下安装的扩展包情况。

    但是重启之后新增加的接口不见了,重新配一下吧。

    神奇不,不能ping通自己,却能ping通veth对端接口地址,查看邻居信息。

    [root@localhost ~]# ip addr

    1: lo: 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: ens192: mtu 1500 qdisc mq state UP group default qlen 1000

        link/ether 00:0c:29:13:d9:6c brd ff:ff:ff:ff:ff:ff

        inet 192.168.1.131/24 brd 192.168.1.255 scope global noprefixroute ens192

           valid_lft forever preferred_lft forever

        inet6 2408:8207:1918:7790:b931:4b6f:5bda:8e59/64 scope global noprefixroute dynamic

           valid_lft 259187sec preferred_lft 172787sec

        inet6 fe80::f797:19ba:c532:71a4/64 scope link noprefixroute

           valid_lft forever preferred_lft forever

    3: ethhost@ethvpp: mtu 1500 qdisc noqueue state UP group default qlen 1000

        link/ether 02:91:21:16:e5:e9 brd ff:ff:ff:ff:ff:ff

        inet 10.1.1.1/24 scope global ethhost

           valid_lft forever preferred_lft forever

        inet6 fe80::91:21ff:fe16:e5e9/64 scope link

           valid_lft forever preferred_lft forever

    4: ethvpp@ethhost: mtu 1500 qdisc noqueue state UP group default qlen 1000

        link/ether 3e:35:0f:15:74:a3 brd ff:ff:ff:ff:ff:ff

        inet6 fe80::3c35:fff:fe15:74a3/64 scope link

           valid_lft forever preferred_lft forever

    [root@localhost ~]# ping 10.1.1.1

    PING 10.1.1.1 (10.1.1.1) 56(84) bytes of data.

    64 bytes from 10.1.1.1: icmp_seq=1 ttl=64 time=0.085 ms

    64 bytes from 10.1.1.1: icmp_seq=2 ttl=64 time=0.044 ms

    64 bytes from 10.1.1.1: icmp_seq=3 ttl=64 time=0.047 ms

    --- 10.1.1.1 ping statistics ---

    3 packets transmitted, 3 received, 0% packet loss, time 2000ms

    rtt min/avg/max/mdev = 0.044/0.058/0.085/0.020 ms

    [root@localhost ~]# ping 10.1.1.2

    PING 10.1.1.2 (10.1.1.2) 56(84) bytes of data.

    64 bytes from 10.1.1.2: icmp_seq=1 ttl=64 time=0.197 ms

    64 bytes from 10.1.1.2: icmp_seq=2 ttl=64 time=0.142 ms

    64 bytes from 10.1.1.2: icmp_seq=3 ttl=64 time=0.136 ms

    --- 10.1.1.2 ping statistics ---

    3 packets transmitted, 3 received, 0% packet loss, time 2000ms

    rtt min/avg/max/mdev = 0.136/0.158/0.197/0.029 ms

    而在内核就简单了,两个地址都能通。

    再尝试ping一下内核的业务地址,则提示需要指定出接口,但即使带源接口仍不行。

    其实就是没有路由而已。

    增加一条路由。

    ip route add 192.168.1.0/24 via 10.1.1.1

    这不就通了吗。

  • 相关阅读:
    Connection closed by foreign host
    QScrollArea样式
    训练yolov5时出现RuntimeError: CUDA out of memory
    TensorFlow和Pytorch两种机器学习框架的比较及优缺点
    强烈 推荐 13 个 Web前端在线代码IDE
    使用人工智能聊天机器人时要注意这些!(配提问技巧)
    SkyWalking 入门教程
    未来架构:无服务器计算和容器的融合
    数字藏品和NFT的区别
    创建第一个 Cypress 应用后使用命令行 npx Cypress open 报错的原因分析
  • 原文地址:https://blog.csdn.net/gtj0617/article/details/126037120