VPP创建接口

网友投稿 779 2022-10-12

VPP创建接口

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 link1: 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:002: 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:ff3: 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:ff4: ethvpp@ethhost: mtu 1500 qdisc noop state DOWN mode DEFAULT group default qlen 1000link/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 upip link set dev ethhost up[root@localhost ~]# ip link set dev ethvpp up[root@localhost ~]# ip link set dev ethhost up[root@localhost ~]# ip link1: 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:002: 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:ff3: 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:ff4: 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 addr1: 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 forever2: 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 forever3: 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 forever4: 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 ethhostip addr show ethhost[root@localhost ~]# ip addr add 10.1.1.1/24 dev ethhost[root@localhost ~]# ip addr show ethhost3: 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 addr1: 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 forever2: 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 forever3: 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 forever4: 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.1PING 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 ms64 bytes from 10.1.1.1: icmp_seq=2 ttl=64 time=0.044 ms64 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 2000msrtt min/avg/max/mdev = 0.044/0.058/0.085/0.020 ms[root@localhost ~]# ping 10.1.1.2PING 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 ms64 bytes from 10.1.1.2: icmp_seq=2 ttl=64 time=0.142 ms64 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 2000msrtt 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

这不就通了吗。

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:VivienneVMM 是一个通过英特尔VT-x虚拟机管理程序实现的隐形调试框架
下一篇:VPP DPDK,不是翻墙!!
相关文章

 发表评论

暂时没有评论,来抢沙发吧~