instance 怎麼獲得自己的 Metadata - 每天5分鐘玩轉 OpenStack(169)

來源:互聯網
上載者:User

標籤:openstack   教程   

要想從 nova-api-metadata 獲得 metadata,需要指定 instance 的 id。但 instance 剛啟動時無法知道自己的 id,所以 http 請求中不會有 instance id 資訊,id 是由 neutron-metadata-agent 添加進去的。針對 l3-agent 和 dhcp-agent 這兩種情況在實現細節上有所不同,下面分別討論。

l3-agent


下面是 l3-agent 參與情況下 metadata http 請求的處理流程圖。

650) this.width=650;" title="http://7xo6kd.com1.z0.glb.clouddn.com/upload-ueditor-image-20170328-1490698232601009989.png" src="http://7xo6kd.com1.z0.glb.clouddn.com/upload-ueditor-image-20170328-1490698365262089658.jpg" alt="30.png" style="border:0px;" />

大的流程為:instance -> neutron-ns-metadata-proxy -> neutron-metadata-agent -> nova-api-metadata,處理細節說明如下:

① neutron-ns-metadata-proxy 接收到請求,在轉寄給 neutron-metadata-agent 之前會將 instance ip 和 router id 添加到 http 請求的 head 中,這兩個資訊對於 l3-agent 來說很容易獲得。

② neutron-metadata-agent 接收到請求後,會查詢 instance 的 id,具體做法是:

1) 通過 router id 找到 router 串連的所有 subnet,然後篩選出 instance ip 所在的 subnet。

2)在 subnet 中找到 instance ip 對應的 port。

3)通過 port 找到對應的 instance 及其 id。

③ neutron-metadata-agent 將 instance id 添加到 http 請求的 head 中,然後轉寄給 nova-api-metadata,這樣 nova-api-metadata 就能返回指定 instance 的 metadata 了。

我們再來看 dhcp-agent 的情況。

 

dhcp-agent


650) this.width=650;" title="http://7xo6kd.com1.z0.glb.clouddn.com/upload-ueditor-image-20170328-1490698232601072527.png" src="http://7xo6kd.com1.z0.glb.clouddn.com/upload-ueditor-image-20170328-1490698365499067662.jpg" alt="31.png" style="border:0px;font-size:14.4px;vertical-align:middle;float:none;" />

① neutron-ns-metadata-proxy 在轉寄請求之前會將 instance ip 和 network id 添加到 http 請求的 head 中,這兩個資訊對於 dhcp-agent 來說很容易獲得。

② neutron-metadata-agent 接收到請求後,會查詢 instance 的 id,具體做法是:

1) 通過 network id 找到 network 所有的 subnet,然後篩選出 instance ip 所在的 subnet。

2)在 subnet 中找到 instance ip 對應的 port。

3)通過 port 找到對應的 instance 及其 id。

③ neutron-metadata-agent 將 instance id 添加到 http 請求的 head 中,然後轉寄給 nova-api-metadata,這樣 nova-api-metadata 就能返回指定 instance 的 metadata 了。

這樣,不管 instance 將請求發給 l3-agent 還是 dhcp-agent,nova-api-metadata 最終都能獲知 instance 的 id,進而返回正確的 metadata。

從擷取 metadata 的流程上看,有一步是至關重要的:instance 必須首先能夠正確擷取 DHCP IP,否則請求發送不到 169.254.169.254。但不是所有環境都會啟用 dhcp,更極端的,有些環境可能連 nova-api-metadata 服務都不會啟用。那麼 instance 還能獲得 metadata 嗎?

這就是下一節我們要討論的主題:config drive

650) this.width=650;" title="http://7xo6kd.com1.z0.glb.clouddn.com/upload-ueditor-image-20170312-1489323234694028485.png" src="http://7xo6kd.com1.z0.glb.clouddn.com/upload-ueditor-image-20170328-1490698365890052630.jpg" style="border:0px;float:none;" />


instance 怎麼獲得自己的 Metadata - 每天5分鐘玩轉 OpenStack(169)

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.