一起研究讨论Nova计算服务以及API、Scheduler、compute等各大组件

本文详细探讨了OpenStack Nova计算服务的核心组件,包括API、Scheduler和compute等,阐述了Scheduler的调度过程,如过滤器和权重计算,并介绍了虚拟机实例化流程、控制台接口以及Nova的Cell架构,揭示了Nova如何高效管理云环境的计算资源。
摘要由CSDN通过智能技术生成

Nova计算服务

  1. 计算服务是openstack最核心的服务之一,负责维护和管理云环境的计算资源,它在openstack项目中代号是nova。
  2. Nova自身并没有提供任何虚拟化能力,它提供计算服务,使用不同的虚拟化驱动来与底层支持的Hypervisor(虚拟机管理器)进行交互。所有的计算实例(虚拟服务器)由Nova进行生命周期的调度管理(启动、挂起、停止、删除等)
  3. Nova需要keystone、 glance、 neutron、 cinder和swift等其他服务的支持, 能与这些服务集成,实现如加密磁盘、裸金属计算实例等。

在这里插入图片描述

Nova系统架构

Nova由多个服务器进程组成,每个进程执行不同的功能

在这里插入图片描述

DB 用于数据存储的sql数据库
API 用于接收HTTP请求、转换命令、通过消息队列或HTTP与其他组件通信的nova组件
Scheduler 用于决定哪台计算节点承载实例的nova调度器
Network 管理IP转发、网桥或虚拟局域网的nova网络组件
Compute 管理虚拟机管理器与虚拟机之间通信的nova计算组件
Conductor 处理需要协调(构建虚拟机或调整虚拟机大小)的请求,或者处理对象转换

Nova组件介绍–API

  1. API是客户访问nova的http接口,它由nova-api服务实现,nova-api服务接收和响应来自最终用户的计算api请求。作openstack对外服务的最主要接,nova-api提供 了一个集中的可以查 询所有api 的端点。
  2. 所有对nova的请求都首先由nova-api处理。API提供REST标准调用服务,便于与第三方系统集成。
  3. 最终用户不会直接改送RESTful API请求,而是通过openstack命令行、dashbord和其他需要跟nova交换的组件来使用这些API。
  1. 只要跟虚拟机生命周期相关的操作,nova-api都可以响应。
  2. Nova-api对接收到的HTTP API请求做以下处理:
    ●1)检查客户端传入的参数是否合法有效
    ●2)调用nova其他服务来处理客户端HTTP请求
    ●3)格式化nova其他子服务返回结果并返回给客户端
  3. Nova- api是外部访问并使用nova提供的各种服务的唯一途径,也是客户端和nova之间的中间层。

Nove组件介绍–Scheduler

结构图
在这里插入图片描述

  1. Scheduler可译为调度器,由nova-scheduler服务实现,主要解决的是如何选择在哪个计算节点上启动实例的问题。它可以应用多种规则,如果考虑内存使用率、cpu负载率、cpu构架(intel/amd) 等多种因素,根据一定的算法,确定虚拟机实例能够运行在哪一台计算服务器上。Nova-scheduler服务会从队列中接收-一个虚拟机实例的请求,通过读取数据库的内容,从可用资源池中选择最合适的计算节点来创建新的虚拟机实例。
  2. 创建虚拟机实例时,用户会提出资源需求,如cpu,内存、磁盘各需要多少Openst
  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 6
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值