多多色-多人伦交性欧美在线观看-多人伦精品一区二区三区视频-多色视频-免费黄色视屏网站-免费黄色在线

國內最全IT社區平臺 聯系我們 | 收藏本站
阿里云優惠2
您當前位置:首頁 > 服務器 > Nova 是如何統計 OpenStack 計算資源

Nova 是如何統計 OpenStack 計算資源

來源:程序員人生   發布時間:2015-05-05 08:32:27 閱讀次數:4612次

引言

運維的同事常常遇到這么4個問題:

  • Nova 如何統計 OpenStack 計算資源?
  • 為何 free_ram_mb, free_disk_gb 有時會是負數?
  • 即便 free_ram_mb, free_disk_gb 為負,為何虛擬機照舊能創建成功?
  • 資源不足會致使虛擬機創建失敗,但指定了 host 有時卻能創建成功?

本文以以上4個問題為切入點,結合 Kilo 版本 Nova 源碼,在默許 Hypervisor 為 Qemu-kvm 的條件下(不同 Hypervisor 的資源統計方式差別較大 ),揭開 OpenStack 統計資源和資源調度的面紗。

Nova 需統計哪些資源

云計算的本質在于將硬件資源軟件化,以到達快速按需交付的效果,最基本的計算、存儲和網絡基礎元素并沒有因此改變。就計算而言,CPU、RAM 和 DISK等照舊是必不可少的核心資源。

從源碼和數據庫相干表可以得出,Nova 統計計算節點的4類計算資源:

  • CPU: 包括 vcpus(節點物理 cpu 總線程數), vcpus_used(該節點虛擬機的 vcpu 總和)
  • RAM: 包括 memory_mb(該節點總 ram),memory_mb_used(該節點虛擬機的 ram 總和),free_ram_mb(可用 ram)
    Note: memory_mb = memory_mb_used + free_ram_mb
  • DISK:local_gb(該節點虛擬機的總可用 disk),local_gb_used(該節點虛擬機 disk 總和),free_disk_gb(可用 disk)
    Note:local_gb = local_gb_used + free_disk_gb
  • 其它:PCI 裝備、CPU 拓撲、NUMA 拓撲和 Hypervisor 等信息

本文重點關注 CPU、RAM 和 DISK 3類資源。

Nova 如何搜集資源

從 源碼 可以看出,Nova 每分鐘統計1次資源,方式以下:

  • CPU
    • vcpus: libvirt 中 get_Info()
    • vcpu_used: 通過 libvirt 中 dom.vcpus() 從而統計該節點上所有虛擬機 vcpu 總和
  • RAM
    • memory: libvirt 中 get_Info()
    • memory_mb_used:先通過 /proc/meminfo 統計可用內存, 再用總內存減去可用內存得出(資源再統計時會重新計算該值)
  • DISK
    • local_gb: os.statvfs(CONF.instances_path)
    • local_gb_used: os.statvfs(CONF.instances_path)(資源再統計時會重新計算該值)
  • 其它
    • hypervisor 相干信息:均通過 libvirt 獲得
    • PCI: libvirt 中 listDevices(‘pci’, 0)
    • NUMA: livirt 中 getCapabilities()

那末問題來了,依照上述搜集資源的方式,free_ram_mb, free_disk_gb 不可能為負數??!別急,Nova-compute 在上報資源至數據庫前,還根據該節點上的虛擬機又做了1次資源統計。

Nova 資源再統計

首先分析為何需要再次統計資源和統計哪些資源。從 源碼 可以發現,Nova 根據該節點上的虛擬機再次統計了 RAM、DISK 和 PCI 資源。

為何需再次統計 RAM 資源?以啟動1個 4G 內存的虛擬機為例,虛擬機啟動前后,對照宿主機上可用內存,發現宿主機上的 free memory 雖有所減少(本次測試減少 600 MB),卻沒有減少到 4G,如果虛擬機運行很吃內存的利用,可發現宿主機上的可用內存迅速減少 3G多。試想,以 64G 的服務器為例,假定每一個 4G 內存的虛擬機啟動后,宿主機僅減少 1G 內存,服務器可以成功創建 64 個虛擬機,但是當這些虛擬機在跑大量業務時,服務器的內存迅速不足,輕著影響虛擬機效力,重者致使虛擬機 shutdown等。除此之外,宿主機上的內存其實不是完全分給虛擬機,系統和其它利用程序也需要內存資源。因此必須重新統計 RAM 資源,統計的方式為:
free_memory = total_memory - CONF.reserved_host_memory_mb - 虛擬機理論內存總和
CONF.reserved_host_memory_mb:內存預留,比如預留給系統或其它利用
虛擬機理論內存總和:即所有虛擬機 flavor 中的內存總和

為何要重新統計 DISK 資源?緣由與 RAM 大致相同。為了節省空間, qemu-kvm 經常使用 QCOW2 格式鏡像,以創建 DISK 大小為 100G 的虛擬機為例,虛擬機創建后,其鏡像文件常常只有幾百 KB,當有大量數據寫入時磁盤時,宿主機上對應的虛擬機鏡像文件會迅速增大。而 os.statvfs 統計的是虛擬機磁盤當前使用量,其實不能反應潛伏使用量。因此必須重新統計 DISK 資源,統計的方式為:
free_disk_gb = local_gb - CONF.reserved_host_disk_mb / 1024 - 虛擬機理論磁盤總和
CONF.reserved_host_disk_mb:磁盤預留
虛擬機理論磁盤總和:即所有虛擬機 flavor 中得磁盤總和

當允許資源超配(見下節)時,采取上述統計方式就有可能出現 free_ram_mb, free_disk_gb 為負。

資源超配與調度

即便 free_ram_mb 或 free_disk_gb 為負,虛擬機照舊有可能創建成功。事實上,當 nova-scheduler 在調度進程中,某些 filter 允許資源超配,比如 CPU、RAM 和 DISK 等 filter,它們默許的超配比為:

  • CPU: CONF.cpu_allocation_ratio = 16
  • RAM: CONF.ram_allocation_ratio = 1.5
  • DISK: CONF.disk_allocation_ratio = 1.0

以 ram_filter 為例,在根據 RAM 過濾宿主機時,過濾的原則為:
memory_limit = total_memory * ram_allocation_ratio
used_memory = total_memory - free_memory
memory_limit - used_memory < flavor[‘ram’],表示內存不足,過濾該宿主機;否則保存該宿主機。

相干代碼以下(稍有精簡):

def host_passes(self, host_state, instance_type): """Only return hosts with sufficient available RAM.""" requested_ram = instance_type['memory_mb'] free_ram_mb = host_state.free_ram_mb total_usable_ram_mb = host_state.total_usable_ram_mb memory_mb_limit = total_usable_ram_mb * CONF.ram_allocation_ratio used_ram_mb = total_usable_ram_mb - free_ram_mb usable_ram = memory_mb_limit - used_ram_mb if not usable_ram >= requested_ram: LOG.debug("host does not have requested_ram") return False

宿主機 RAM 和 DISK 的使用率常常要小于虛擬機理論使用的 RAM 和 DISK,在剩余資源充足的條件下,libvirt 將成功創建虛擬機。

隨想:內存和磁盤超配雖然能提供更多數量的虛擬機,當該宿主機上大量虛擬機的負載都很高時,輕著影響虛擬機性能,重則引發 qemu-kvm 相干進程被殺,即虛擬機被關機。因此對線上穩定性要求高的業務,建議不要超配 RAM 和 DISK,但可適當超配 CPU。建議這幾個參數設置為:

  • CPU: CONF.cpu_allocation_ratio = 4
  • RAM: CONF.ram_allocation_ratio = 1.0
  • DISK: CONF.disk_allocation_ratio = 1.0
  • RAM-Reserve: CONF.reserved_host_memory_mb = 2048
  • DISK-Reserve: CONF.reserved_host_disk_mb = 20480

指定 host 創建虛擬機

本節用于回答問題4,當所有宿主機的資源使用過量,即超越限定的超配值時(total_resource * allocation_ratio),nova-scheduler 將過濾這些宿主機,若未找到符合要求的宿主機,虛擬機創建失敗。

創建虛擬機的 API 支持指定 host 創建虛擬機,指定 host 時,nova-scheduler 采取特別的處理方式:不再判斷該 host 上的資源是不是滿足需求,而是直接將要求發給該 host 上的 nova-compute。
相干代碼以下(稍有精簡):

def get_filtered_hosts(self, hosts, filter_properties, filter_class_names=None, index=0): """Filter hosts and return only ones passing all filters.""" ... if ignore_hosts or force_hosts or force_nodes: ... if force_hosts or force_nodes: # NOTE(deva): Skip filters when forcing host or node if name_to_cls_map: return name_to_cls_map.values() return self.filter_handler.get_filtered_objects()

當該 host 上實際可用資源時滿足要求時,libvirt 照舊能成功創建虛擬機。

最后,以1圖總結本文內容
這里寫圖片描述

生活不易,碼農辛苦
如果您覺得本網站對您的學習有所幫助,可以手機掃描二維碼進行捐贈
程序員人生
------分隔線----------------------------

上一篇 JPA EntitManager進階

下一篇 微商時代

分享到:
------分隔線----------------------------
關閉
程序員人生
主站蜘蛛池模板: 欧美人与性动交α欧美精品 | 911久久| 亚洲欧美一区二区三区图片 | www.九色| 亚洲欧美综合图片 | 亚洲人成图片欧美人成图片 | 伊人久久亚洲精品一区 | 日本特级全黄一级毛片 | 亚洲一区二区在线视频 | 红豆视频在线观看日本 | 伊人久久91 | 性做久久久久久久久浪潮 | 成人免费的性色视频 | 波多野结衣手机视频一区 | 老外一级毛片免费看 | 国产精品久久久久久久成人午夜 | 免费国产高清精品一区在线 | 国产成人高清 | 国产毛片毛片精品天天看 | 美女伊人网 | 日本在线观看不卡免费视频 | 国产精品自在线拍国产 | 一二三四视频免费观看在线看 | 国产精品久久久久乳精品爆 | 亚洲福利视频一区 | 国产欧美高清 | 国内精品不卡一区二区三区 | 亚洲天堂网址 | 国产午夜精品久久理论片小说 | 成在线人免费视频一区二区三区 | 毛片免费毛片一级jjj毛片 | 性猛交xxxxx按摩中国 | 亚洲伊人久久大香线蕉综合图片 | 黄色淫片 | 欧美性生活视频免费播放网址大全观看 | 日本高清www视频在线观看 | 女人18一级特级毛片免费看 | 亚洲成aⅴ人片在线影院八 亚洲成aⅴ人在线观看 | 欧美另类极品 | 亚洲欧美一二三区 | 青青国产成人精品视频 |