0

我有多个network namespaces Linux服务器定义:如何通过网络适配器查找Linux名称空间?

# ip netns list 
qdhcp-7dedbd4e-2265-4aa2-baac-add4e341dd18 
qdhcp-851379ba-1d51-4e45-8e50-b756e81c0949 
qdhcp-a19927c5-83b4-4bb4-a8b8-f21fdb5e004b 
qdhcp-b94605ff-b0e2-4cfe-a95e-3dd10208a5fb 
... ... 

每个命名空间包含一个或多个虚拟网络适配器 - 在这种情况下,这是一个TAP设备:

# ip netns exec qdhcp-7dedbd4e-2265-4aa2-baac-add4e341dd18 ip route 
192.168.168.0/24 dev tapda4018ab-b7 proto kernel scope link src 192.168.168.2 
169.254.0.0/16 dev tapda4018ab-b7 proto kernel scope link src 169.254.169.254 
default via 192.168.168.1 dev tapda4018ab-b7 

现在,让我们说,我知道适配器的名称 - tapda4018ab-b7 - 但我不知道它所属的名称空间。有没有一种方法可以查看它,而无需逐个检查命名空间?有没有一个通用的Linux命令来做到这一点?或者至少OpenStack Neutron特定的命令?

回答

0

根据这名男子页http://man7.org/linux/man-pages/man8/ip-netns.8.html你可以运行在所有的命名空间exec命令,但我测试了一个Ubuntu值得信赖的服务器上,它不会接受“- 所有”作为参数。所以我知道得到这样的信息的唯一方法是通过一个小的bash脚本。我做了一个我的脚本技能是相当基本的,可以肯定得到改善,但它会做的工作:

#!/bin/bash 
i=$(ip netns list | wc -l) 
counter=1 
while [ $counter -le $i ]; do 
    ns=$(ip netns | head -$counter | tail -1) 
    ip netns exec $ns ip route | grep $1 | grep proto 
    let counter=counter+1 
done 

然后,您可以使用作为唯一的参数水龙头装置启动脚本中波纹管的例子:

[email protected]:~# ./list_all_namespace tap8164117b-e3 
5.5.5.0/25 dev tap8164117b-e3 proto kernel scope link src 5.5.5.3 

如果你没有提供参数,它会给你一个错误。

1

如果我正确理解Neutron(如果我的唯一经验是Kilo/2015.1.2的玩具安装非常有限),那么您应该能够通过中子数据库来跟踪您的网络,重新寻找

我相信你的抽头接口将使用它所关联的端口uuid的前5个八位字节(10个字符)来命名,而qdhcp netns使用它的网络uuid,所以你应该能够使用neutron CLI来追踪正确的命名空间。

您应该能够找到中子端口,用于水龙头接口:

$ neutron port-list | grep "da4018ab-b7" 
| da4018ab-b7xx-xxxx-xxxx-xxxxxxxxxxxx | | fa:16:xx:xx:xx:xx | {"subnet_id": ... 

其中“da4018ab-B7”被拉出“tapda4018ab-B7”的。然后,您可以使用完整的端口UUID:

$ neutron port-show da4018ab-b7xx-xxxx-xxxx-xxxxxxxxxxxx 

从口出现结果的NETWORK_ID应该让你找出netns(qdhcp- NETWORK_ID)含tapda4018ab-B7。

你应该能够使用类似的逻辑来追踪qg接口(它可能会在默认netns中的桥接器上显示),但在这种情况下,它是拥有端口的device_id,它为您提供qrouter- device_id你想要的净额。

0

您可以使用此脚本。与作为参数提供的TAP接口

[email protected]$ cat get_dhcp_namespace.sh 

#!/bin/bash 

interface=$1 
id=${interface:3} 

port_id=$(neutron port-list | grep $id | awk -F'|' '{print $2}' | tr -d ' ') 
net_id=$(neutron port-show $port_id | grep network_id | awk -F'|' '{print $3}' | tr -d ' ') 
echo "DHCP namespace is: qdhcp-$net_id" 

运行此 - :保存为get_dhcp_namespace.sh。不要忘记获取keystonerc/openstackrc/credentials文件。

[email protected]$ ./get_dhcp_namespace.sh tapda4018ab-b7 
qdhcp-bd39f45d-b45c-4e08-ab74-85c0b1180aea 
相关问题