博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
用 namspace 隔离 DHCP 服务 - 每天5分钟玩转 OpenStack(90)
阅读量:7132 次
发布时间:2019-06-28

本文共 1362 字,大约阅读时间需要 4 分钟。

hot3.png

Neutron 通过 dnsmasq 提供 DHCP 服务,而 dnsmasq 如何独立的为每个 network 服务呢?

答案是通过 Linux Network Namespace 隔离,本节将详细讨论。

在二层网络上,VLAN 可以将一个物理交换机分割成几个独立的虚拟交换机。 类似地,在三层网络上,Linux network namespace 可以将一个物理三层网络分割成几个独立的虚拟三层网络。

每个 namespace 都有自己独立的网络栈,包括 route table,firewall rule,network interface device 等。

Neutron 通过 namespace 为每个 network 提供独立的 DHCP 和路由服务,从而允许租户创建重叠的网络。

如果没有 namespace,网络就不能重叠,这样就失去了很多灵活性。

每个 dnsmasq 进程都位于独立的 namespace, 命名为 qdhcp-<network id>,例如 flat_net,我们有:

ip netns list 命令列出所有的 namespace。 qdhcp-f153b42f-c3a1-4b6c-8865-c09b5b2aa274 就是 flat_net 的 namespace。

其实,宿主机本身也有一个 namespace,叫 root namespace,拥有所有物理和虚拟 interface device。 物理 interface 只能位于 root namespace。

新创建的 namespace 默认只有一个 loopback device。 管理员可以将虚拟 interface,例如 bridge,tap 等设备添加到某个 namespace。

对于 flat_net 的 DHCP 设备 tap19a0ed3d-fe,需要将其放到 namespace qdhcp-f153b42f-c3a1-4b6c-8865-c09b5b2aa274 中,但这样会带来一个问题: tap19a0ed3d-fe 将无法直接与 root namespace 中的 bridge 设备 brqf153b42f-c3 连接。

Neutron 使用 veth pair 解决了这个问题

veth pair 是一种成对出现的特殊网络设备,它们象一根虚拟的网线,可用于连接两个 namespace。向 veth pair 一端输入数据,在另一端就能读到此数据。

tap19a0ed3d-fe 与 ns-19a0ed3d-fe 就是一对 veth pair,它们将 qdhcp-f153b42f-c3a1-4b6c-8865-c09b5b2aa274 连接到 brqf153b42f-c3。如下图所示:

可以通过 ip netns exec <network namespace name> <command> 管理 namespace。 例如查看 ns-19a0ed3d-fe 的配置:

理解了 namespace,下一节我们分析 instance 从 dnsmasq 获取 IP 的详细过程。

 

blob.png

转载于:https://my.oschina.net/u/2397560/blog/750477

你可能感兴趣的文章
length
查看>>
graphviz hello world
查看>>
机器学习实战1-1 KNN电影分类遇到的问题
查看>>
[Aaronyang] 写给自己的WPF4.5 笔记21 [3d课 2/4]
查看>>
[ SDOI 2011 ] 打地鼠
查看>>
[ Luogu 3398 ] 仓鼠找sugar
查看>>
iOS多线程之6.GCD的其他用法
查看>>
第十 线程与锁
查看>>
NFS共享服务挂载时出现“access denied by server while mounting”的解决方法
查看>>
VMWare Tools Centos 安装
查看>>
网络编程 - 简单的socket例子
查看>>
2012年11月-.Net学习笔记-表单-(更新中)
查看>>
端口号
查看>>
Spring MVC 处理静态资源文件
查看>>
毕向东_Java基础视频教程第19天_IO流(01~05)
查看>>
MySQL遇到的一个卡库问题及对update的学习
查看>>
无法启动OracleOraDb10g_home1TNSListener解决办法
查看>>
C# IP地址去掉端口号
查看>>
poj1797 最短路
查看>>
poj3259 最短路判环
查看>>