深圳专业网站建设公司排名,好的h5网站模板,南京网站设计哪家好,台州市建设项目规划网站OpenStack 默认通过 l3-agent 创建和管理 neutron-ns-metadata-proxy#xff0c;进而与 nova-metadata-api 通信。但不是所有环境都有 l3-agent#xff0c;比如直接用物理 router 的场景。这时就需要走另一条路#xff1a;让 dhcp-agent 来创建和管理 neutron-ns-metadata-p… OpenStack 默认通过 l3-agent 创建和管理 neutron-ns-metadata-proxy进而与 nova-metadata-api 通信。但不是所有环境都有 l3-agent比如直接用物理 router 的场景。这时就需要走另一条路让 dhcp-agent 来创建和管理 neutron-ns-metadata-proxy。 打开 /etc/neutron/dhcp_agent.ini设置 force_metadata 重启 dhcp-agent 后可以看到控制节点上多了一个 neutron-ns-metadata-proxy 进程。 此进程通过 --network_id 关联到 test_net这就是 dhcp-agent 启动的 neutron-ns-metadata-proxy用于接收 test_net 网络上 instance 的 metadata 请求。每一个 network 都有一个与之对应的 neutron-ns-metadata-proxy。 重启 instance c1查看路由表。 请注意现在访问 169.254.169.254 的路由已由之前的 17.17.17.1变为 17.17.17.2。这里的 17.17.17.2 是 dhcp-agent 在test_net 上的 IP。这条路由是由 dhcp-agent 添加进去的。正是因为这条路由的存在即便 l3-agent 与 dhcp-agent 同时提供 neutron-ns-metadata-proxy 服务metadata 请求也只会发送给 dhcp-agent。 同时我们也看到dhcp-agent 已经将 IP 169.254.169.254 配置到了自己身上。也就是说c1 访问 metadata 的请求 http://169.254.169.254 实际上是发送到了 dhcp-agent 的 80 端口。而监听 80 端口的正是 dhcp-agent 启动的 neutron-ns-metadata-proxy 进程。 后面的数据流向就与 l3-agent 的场景一样了neutron-ns-metadata-proxy 将请求通过 unix domain socket 发给 neutron-metadata-agent后者再通过管理网络发给 nova-api-metadata。 到这里我们已经分别讨论了通过 l3-agent 和 dhcp-agent 访问 metadata 的实现方法。对于 169.254.169.254 l3-agent 用 iptables 规则来转发。 dhcp-agent 则是将此 IP 配置到自己的 interface 上。 不知道大家有没有这样一个疑问 nova-api-metadata 是怎么知道应该返回哪个 instance 的 metadatac1 只是向 169.254.169.254 发送了一个 http 请求nova-api-metadata 怎么就知道应该返回 c1 的 metadata 呢 下节咱们详细分析这个问题。