1

我正在创建 ryu 应用程序来推送和弹出 mpls 标签。这是 ovs(2.3.1 版)交换机 s1 上的流条目:

root@ubuntu:~# sudo ovs-ofctl -O  OpenFlow14 dump-flows s1
OFPST_FLOW reply (OF1.4) (xid=0x2):
 cookie=0x0, duration=190.991s, table=0, n_packets=123, n_bytes=21852, priority=0 actions=CONTROLLER:65535
 cookie=0x0, duration=190.991s, table=0, n_packets=0, n_bytes=0, priority=10,mpls,in_port=2,mpls_label=80 actions=pop_mpls:0x0800,output:1
 cookie=0x0, duration=190.991s, table=0, n_packets=152, n_bytes=14896, priority=10,ip,in_port=1 actions=push_mpls:0x8847,set_field:80->mpls_label,output:2

任何人都知道为什么即使流条目匹配也不转发数据包。因为如果我打开 Wireshark 并查看 s1-eth2 以检查 mpls 标头,则没有检测到具有 mpls 标头或 ethertype = 0x8847 的数据包。

我在 s1-eth2 看到的只有数据包是 ICMPv6(路由器请求消息)、DHCP 和 MDNS。它们中的任何一个都与我从主机 1 发送到 h2 的 ping 无关。我的拓扑:h1-s1-s2-h2

我的代码有错误还是 ovs 或 openflow_v1.4 ryu 中的错误?

谢谢。

4

3 回答 3

0

2.4 分支中推送的 MPLS 固定很少,您可以在 master 或分支 2.4 上尝试吗?

于 2015-07-25T04:26:24.693 回答
0

您是否处理 ARP 请求和 ARP 回复?

处理 ARP 数据包的两种方法:

  1. 保持流表不变,ARP 数据包被转发到控制器。让控制器处理 ARP。
  2. 改变流表。

添加最后一个

root@ubuntu:~# sudo ovs-ofctl -O  OpenFlow14 dump-flows s1
OFPST_FLOW reply (OF1.4) (xid=0x2):
cookie=0x0, duration=190.991s, table=0, n_packets=123, n_bytes=21852, priority=0 actions=CONTROLLER:65535
cookie=0x0, duration=190.991s, table=0, n_packets=0, n_bytes=0, priority=10,mpls,in_port=2,mpls_label=80 actions=pop_mpls:0x0800,output:1
cookie=0x0, duration=190.991s, table=0, n_packets=152, n_bytes=14896, priority=10,ip,in_port=1 actions=push_mpls:0x8847,set_field:80->mpls_label,output:2
cookie=0x0, duration=190.991s, table=0, n_packets=152, n_bytes=14896, priority=10,arp,in_port=1 actions=push_mpls:0x8847,set_field:80->mpls_label,output:2
于 2016-09-21T01:40:48.450 回答
0

适用于 OvS 2.5.1 中堆栈中的最多 2 个标签。Ryu 应用程序中可能有错误。你可以发布代码吗?

MPLS 标头堆栈的大小限制为 3。在数据包上推送超过 3 个 MPLS 标头会导致数据包无法在 Open vSwitch 中转发。

sudo mn --topo single,2 --switch ovsk
mininet> h1 ping h2

在 s1 上安装了一组最小的流条目:

sudo ovs-ofctl -O OpenFlow13 add-flow s1 in_port=1,actions=push_mpls:0x8847,push_mpls:0x8847,push_mpls:0x8847,push_mpls:0x8847,output:2
sudo ovs-ofctl -O OpenFlow13 add-flow s1 in_port=2,actions=push_mpls:0x8847,push_mpls:0x8847,push_mpls:0x8847,push_mpls:0x8847,output:1

流条目正确匹配。 sudo ovs-ofctl -O OpenFlow13 dump-flows s1 | grep -o "n_packets=\w*" 然而没有数据包离开 s1 确认 sudo tcpdump -ni s1-eth2

于 2016-12-13T08:30:54.163 回答