1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
| root@t1:~# ip a
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 noprefixroute
valid_lft forever preferred_lft forever
2: ens160: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc mq state UP group default qlen 1000
link/ether 00:0c:29:f6:6f:4c brd ff:ff:ff:ff:ff:ff
altname enp3s0
inet 192.168.31.172/24 brd 192.168.31.255 scope global dynamic noprefixroute ens160
valid_lft 37588sec preferred_lft 37588sec
inet6 fd00:6868:6868::e3f/128 scope global dynamic noprefixroute
valid_lft 37590sec preferred_lft 37590sec
inet6 fd00:6868:6868:0:20c:29ff:fef6:6f4c/64 scope global noprefixroute
valid_lft forever preferred_lft forever
inet6 fe80::20c:29ff:fef6:6f4c/64 scope link noprefixroute
valid_lft forever preferred_lft forever
14: ovs-system: <BROADCAST,MULTICAST> mtu 1500 qdisc noop state DOWN group default qlen 1000
link/ether aa:61:c7:91:86:39 brd ff:ff:ff:ff:ff:ff
15: ovsbr_tenantA: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue state UNKNOWN group default qlen 1000
link/ether 8e:d4:f2:41:44:48 brd ff:ff:ff:ff:ff:ff
inet6 fe80::8cd4:f2ff:fe41:4448/64 scope link proto kernel_ll
valid_lft forever preferred_lft forever
16: ovsbr_tenantB: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue state UNKNOWN group default qlen 1000
link/ether ba:39:2b:2f:d0:45 brd ff:ff:ff:ff:ff:ff
inet6 fe80::b839:2bff:fe2f:d045/64 scope link proto kernel_ll
valid_lft forever preferred_lft forever
17: vethA1_ovs@if18: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master ovs-system state UP group default qlen 1000
link/ether ee:3f:23:f0:3e:3d brd ff:ff:ff:ff:ff:ff link-netns hostA1
inet6 fe80::ec3f:23ff:fef0:3e3d/64 scope link proto kernel_ll
valid_lft forever preferred_lft forever
19: vethA2_ovs@if20: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master ovs-system state UP group default qlen 1000
link/ether b2:67:7e:7b:cf:1e brd ff:ff:ff:ff:ff:ff link-netns hostA2
inet6 fe80::b067:7eff:fe7b:cf1e/64 scope link proto kernel_ll
valid_lft forever preferred_lft forever
21: vethB1_ovs@if22: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master ovs-system state UP group default qlen 1000
link/ether 46:31:6f:bc:84:7f brd ff:ff:ff:ff:ff:ff link-netns hostB1
inet6 fe80::4431:6fff:febc:847f/64 scope link proto kernel_ll
valid_lft forever preferred_lft forever
23: vethB2_ovs@if24: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master ovs-system state UP group default qlen 1000
link/ether 5a:bf:a3:de:60:2a brd ff:ff:ff:ff:ff:ff link-netns hostB2
inet6 fe80::58bf:a3ff:fede:602a/64 scope link proto kernel_ll
valid_lft forever preferred_lft forever
root@t1:~# sudo ovs-vsctl show
a6d87171-af75-4028-97f2-335866e29fd2
Bridge ovsbr_tenantB
Port ovsbr_tenantB
Interface ovsbr_tenantB
type: internal
Port vethB2_ovs
tag: 40
Interface vethB2_ovs
Port vethB1_ovs
tag: 30
Interface vethB1_ovs
Bridge ovsbr_tenantA
Port ovsbr_tenantA
Interface ovsbr_tenantA
type: internal
Port vethA2_ovs
tag: 20
Interface vethA2_ovs
Port vethA3_ovs
tag: 10
Interface vethA3_ovs
Port vethA1_ovs
tag: 10
Interface vethA1_ovs
ovs_version: "3.4.0-2.fc41"
root@t1:~# ovs-ofctl show ovsbr_tenantB
OFPT_FEATURES_REPLY (xid=0x2): dpid:0000ba392b2fd045
n_tables:254, n_buffers:0
capabilities: FLOW_STATS TABLE_STATS PORT_STATS QUEUE_STATS ARP_MATCH_IP
actions: output enqueue set_vlan_vid set_vlan_pcp strip_vlan mod_dl_src mod_dl_dst mod_nw_src mod_nw_dst mod_nw_tos mod_tp_src mod_tp_dst
1(vethB1_ovs): addr:46:31:6f:bc:84:7f
config: 0
state: 0
current: 10GB-FD COPPER
speed: 10000 Mbps now, 0 Mbps max
2(vethB2_ovs): addr:5a:bf:a3:de:60:2a
config: 0
state: 0
current: 10GB-FD COPPER
speed: 10000 Mbps now, 0 Mbps max
LOCAL(ovsbr_tenantB): addr:ba:39:2b:2f:d0:45
config: 0
state: 0
speed: 0 Mbps now, 0 Mbps max
OFPT_GET_CONFIG_REPLY (xid=0x4): frags=normal miss_send_len=0
root@t1:~# ovs-ofctl show ovsbr_tenantA
OFPT_FEATURES_REPLY (xid=0x2): dpid:00008ed4f2414448
n_tables:254, n_buffers:0
capabilities: FLOW_STATS TABLE_STATS PORT_STATS QUEUE_STATS ARP_MATCH_IP
actions: output enqueue set_vlan_vid set_vlan_pcp strip_vlan mod_dl_src mod_dl_dst mod_nw_src mod_nw_dst mod_nw_tos mod_tp_src mod_tp_dst
1(vethA1_ovs): addr:ee:3f:23:f0:3e:3d
config: 0
state: 0
current: 10GB-FD COPPER
speed: 10000 Mbps now, 0 Mbps max
2(vethA2_ovs): addr:b2:67:7e:7b:cf:1e
config: 0
state: 0
current: 10GB-FD COPPER
speed: 10000 Mbps now, 0 Mbps max
3(vethA3_ovs): addr:1e:59:d4:16:e2:e1
config: 0
state: 0
current: 10GB-FD COPPER
speed: 10000 Mbps now, 0 Mbps max
LOCAL(ovsbr_tenantA): addr:8e:d4:f2:41:44:48
config: 0
state: 0
speed: 0 Mbps now, 0 Mbps max
OFPT_GET_CONFIG_REPLY (xid=0x4): frags=normal miss_send_len=0
root@t1:~# sudo ip netns exec hostA1 ping -c 3 10.10.20.10
ping: connect: 网络不可达
root@t1:~# sudo ip netns exec hostB1 ping -c 3 10.10.40.10
ping: connect: 网络不可达
root@t1:~# sudo ip netns exec hostA1 ping -c 3 10.10.30.10
ping: connect: 网络不可达
root@t1:~# sudo ip netns exec hostA1 ping -c 3 10.10.10.11
PING 10.10.10.11 (10.10.10.11) 56(84) 字节的数据。
64 字节,来自 10.10.10.11: icmp_seq=1 ttl=64 时间=0.568 毫秒
^C
--- 10.10.10.11 ping 统计 ---
已发送 1 个包, 已接收 1 个包, 0% packet loss, time 0ms
rtt min/avg/max/mdev = 0.568/0.568/0.568/0.000 ms
|