真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

Launch和ShutOff操作是怎樣的

Launch和Shut Off操作是怎樣的,針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。

為吳川等地區(qū)用戶提供了全套網(wǎng)頁設計制作服務,及吳川網(wǎng)站建設行業(yè)解決方案。主營業(yè)務為成都網(wǎng)站制作、網(wǎng)站建設、吳川網(wǎng)站設計,以傳統(tǒng)方式定制建設網(wǎng)站,并提供域名空間備案等一條龍服務,秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務。我們深信只要達到每一位用戶的要求,就會得到認可,從而選擇與我們長期合作。這樣,我們也可以走得更遠!

Launch和Shut Off操作是怎樣的

分析 instance launch 和 shut off 操作,以及如何在日志中快速定位有用信息的技巧。

Launch

Launch instance 應該算 Nova 最重要的操作。

仔細研究 lanuch 操作能夠幫助我們充分理解 Nova 各個子服務的協(xié)調(diào)配合和運行機制。

前面我們已經(jīng)以 launch 操作為例詳細討論了各個 nova-* 子服務。 這里不再贅述,只是再回顧一下流程。

Launch和Shut Off操作是怎樣的

  1. 客戶(可以是 OpenStack 最終用戶,也可以是其他程序)向 API(nova-api)發(fā)送請求:“幫我創(chuàng)建一個 Instance”

  2. API對請求做一些必要處理后,向 Messaging(RabbitMQ)發(fā)送了一條消息:“讓 Scheduler 創(chuàng)建一個 Instance”

  3. Scheduler(nova-scheduler)從 Messaging 獲取到 API 發(fā)給它的消息,然后執(zhí)行調(diào)度算法,從若干計算節(jié)點中選出節(jié)點 A

  4. Scheduler 向 Messaging 發(fā)送了一條消息:“在計算節(jié)點 A 上創(chuàng)建這個 Instance”

  5. 計算節(jié)點 A 的 Compute(nova-compute)從 Messaging 中獲取到 Scheduler 發(fā)給它的消息,然后通過本節(jié)點的 Hypervisor Driver 創(chuàng)建 Instance。

  6. 在 Instance 創(chuàng)建的過程中,Compute 如果需要查詢或更新數(shù)據(jù)庫信息,會通過 Messaging 向 Conductor(nova-conductor)發(fā)送消息,Conductor 負責數(shù)據(jù)庫訪問。

Shut Off

下面是 shut off instance 的流程圖

Launch和Shut Off操作是怎樣的

  1. 向 nova-api 發(fā)送請求

  2. nova-api 發(fā)送消息

  3. nova-compute 執(zhí)行操作

下面我們詳細討論每一個步驟。

向 nova-api 發(fā)送請求

客戶(可以是 OpenStack 最終用戶,也可以是其他程序)向 API(nova-api)發(fā)送請求:“幫我關閉這個 Instance”

Launch和Shut Off操作是怎樣的

查看日志 /opt/stack/logs/n-api.log

Launch和Shut Off操作是怎樣的

對于如何在日志文件中快速查找到有用的信息這里多聊幾句。 對于初學者,這不是一件容易的事情,因為日志里條目和內(nèi)容很多,特別是 debug 選項打開之后,容易讓人眼花繚亂,無從下手。

這里給大家?guī)讉€小竅門:

  1. 先確定大的范圍,比如在操作之前用 tail -f 打印日志文件,這樣需要查看的日志肯定在操作之后的打印輸出的這些內(nèi)容里。 另外也可以通過時間戳來確定需要的日志范圍。

  2. 利用 “代碼模塊” 快速定位有用的信息。 nova-* 子服務都有自己特定的代碼模塊:
    nova-api
    nova.api.openstack.compute.servers
    nova.compute.api
    nova.api.openstack.wsgi

    nova-compute
    nova.compute.manager
    nova.virt.libvirt.*

    nova-scheduler
    nova.scheduler.*

  3. 利用 Request ID 查找相關的日志信息。 在上面的日志中個,我們可以利用 “req-1758b389-a2d0-44cc-a95a-6f75e4dc07fd” 這個 Request ID 快速定位 n-api.log 中相與 shut off 操作的其他日志條目。 需要補充說明的是,Request ID 是跨日志文件的,這一個特性能幫助我們在其他子服務的日志文件中找到相關信息,我們后面馬上將會看到這個技巧的應用。

nova-api 發(fā)送消息

nova-api 向 Messaging(RabbitMQ)發(fā)送了一條消息:“關閉這個 Instance” nova-api 沒有將發(fā)送消息的操作記錄到日志中,不過我們可以通過查看源代碼來驗證。 一提到源代碼,大家可能以為要大海撈針了。其實很簡單,上面日志已經(jīng)清楚地告訴我們需要查看的源代碼在 /opt/stack/nova/nova/compute/api.py 的 1977 行,方法是 force_stop。

Launch和Shut Off操作是怎樣的

force_stop 方法最后調(diào)用的是對象 self.compute_rpcapi 的 stop_instance 方法。 在 OpenStack 源碼中,以 xxx_rpcapi 命名的對象,表示的就是 xxx 的消息隊列。 xxx_rpcapi.yyy() 方法則表示向 xxx 的消息隊列發(fā)送 yyy 操作的消息。

所以 self.compute_rpcapi.stop_instance() 的作用就是向 RabbitMQ 上 nova-compute 的消息隊列里發(fā)送一條 stop instance 的消息。

這里補充說明一下: 關閉 instance 的前提是 instance 當前已經(jīng)在某個計算節(jié)點上運行,所以這里不需要 nova-scheduler 再幫我們挑選合適的節(jié)點,這個跟 launch 操作不同。

nova-compute 執(zhí)行操作

查看計算節(jié)點上的日志 /opt/stack/logs/n-cpu.log

Launch和Shut Off操作是怎樣的

這里我們利用了 Request ID “req-1758b389-a2d0-44cc-a95a-6f75e4dc07fd” 在 n-cpu.log 中快速定位到 nova-compute 關閉 instance 的日志條目。

分析某個操作時,我們首先要理清該操作的內(nèi)部流程,然后再到相應的節(jié)點上去查看日志。 例如shut off 的流程為:

  1. 向 nova-api 發(fā)送請求

  2. nova-api 發(fā)送消息

  3. nova-compute 執(zhí)行操作

1,2 兩個步驟是在控制節(jié)點上執(zhí)行的,查看 nova-api 的日志。 第 3 步是在計算節(jié)點上執(zhí)行的,查看 nova-compute 的日志。

關于Launch和Shut Off操作是怎樣的問題的解答就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注創(chuàng)新互聯(lián)行業(yè)資訊頻道了解更多相關知識。


本文名稱:Launch和ShutOff操作是怎樣的
當前鏈接:http://weahome.cn/article/ipiejd.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部