文档章节

nova-scheduler模块调度过程分析

zrz11
 zrz11
发布于 2018/11/30 18:20
字数 540
阅读 46
收藏 0

openstack在创建虚拟机或进行虚拟机的冷迁移时根据在nova.conf文件中scheduler_default_filters和scheduler_available_filters配置的过滤器,

对主机进行筛选,选择合适的目的主机。

本文根据nova M版源码分析调度不同过滤器的过程。

一、conductor服务通过rpc调用scheduler服务 SchedulerManager类的select_destinations,由此开始进入进入主机过滤阶段,

       此阶段主要目的是调用事先在nova.conf文件中配置的过滤器,选择合适的计算节点。

文件nova/scheduler/manager.py

104行,self.driver实际是在nova.conf文件中配置的FileterScheduler

二、nova/scheduler/filter_scheduler.py文件

52行,num_instances是要选择的计算节点数。

53行,self._schedule是实际的调度函数,在此函数中调度各个过滤器的函数。

三、_schedule函数

94行,加载json文件可以在json文件里配置过滤规则,现在m版json文件没起作用。

104行,在过滤之前首先要从数据库拿到所有计算节点的的当前状态。

112行,进行主机过滤

120行,拿到过滤的主机计算权重,并返回根据权重排序的列表。

四、nova/scheduler/host_manager.py文件

get_filtered_host函数中参数filter_class_names传进来的值是None,进入517分支

517行,filters是所有过滤器类名字的列表,由self._choose_host_filters函数返回

_choose_host_filters(),函数根据nova.conf文件中的scheduler_default_filters和scheduler_available_filters挑选出要使用的过滤器

self._load_filters()加载nova.conf文件中的scheduler_default_filters项,默认在nova/scheduler/filters下的全部过滤器都打开。

545行,调用nova/filters.py文件中BaseFilterHandler::get_filtered_objects,参数filters是要使用的过滤器类列表,hosts是所有的计算节点。

五、nova/filters.py文件

81行,循环调用过滤器

85行,调用过滤器类的filter_all方法,对主机进行筛选,以AvailabilityZoneFilter类说明调用关系

 

© 著作权归作者所有

zrz11
粉丝 3
博文 25
码字总数 15262
作品 0
丰台
程序员
私信 提问
Unshelve Instance 操作详解 - 每天5分钟玩转 OpenStack(39)

上一节我们 shelve instance 到 Glance,本节讨论如何通过 unshelve 操作恢复该 instance。 因为 Glance 中保存了 instance 的 image,unshelve 的过程其实就是通过该 image launch 一个新的...

CloudMAN
2016/05/27
198
0
openstack系列文章(四)

学习 openstack 的系列文章 - Nova Nova 基本概念 Nova 架构 openstack Log Nova 组件介绍 Nova 操作介绍 1. Nova 基本概念 Nova 是 openstack 最核心的服务,负责管理和维护云环境的计算资源...

行者阿难
2018/10/21
0
0
Resize Instance 操作详解 - 每天5分钟玩转 OpenStack(41)

Resize 的作用是调整 instance 的 vCPU、内存和磁盘资源。 Instance 需要多少资源是定义在 flavor 中的,resize 操作是通过为 instance 选择新的 flavor 来调整资源的分配。 有了前面对 Migr...

CloudMAN
2016/06/01
300
0
Migrate Instance 操作详解 - 每天5分钟玩转 OpenStack(40)

Migrate 操作的作用是将 instance 从当前的计算节点迁移到其他节点上。 Migrate 不要求源和目标节点必须共享存储,当然共享存储也是可以的。 Migrate 前必须满足一个条件:计算节点间需要配置...

CloudMAN
2016/05/30
244
0
看 nova-scheduler 如何选择计算节点 - 每天5分钟玩转 OpenStack(27)

本节重点介绍 nova-scheduler 的调度机制和实现方法:即解决如何选择在哪个计算节点上启动 instance 的问题。 创建 Instance 时,用户会提出资源需求,例如 CPU、内存、磁盘各需要多少。 Op...

CloudMAN
2016/04/29
416
6

没有更多内容

加载失败,请刷新页面

加载更多

聊聊spring cloud的ConsulServiceRegistry

序 本文主要研究一下spring cloud的ConsulServiceRegistry ServiceRegistry spring-cloud-commons-2.1.2.RELEASE-sources.jar!/org/springframework/cloud/client/serviceregistry/ServiceR......

go4it
昨天
1
0
Nextjs 学习 —— hooks

22

lemos
昨天
1
0
如何在spring mvc restful接口中定制化类型转换和格式化

1.痛点 最近小胖哥搞了个小程序,有几个spring mvc 接口传递了时间,时间用java 8 time 相关的api 来直接接收: 当使用根据ISO 8601格式化的参数向任何这些方法发送POST请求时,报出了如下异...

码农小胖哥
昨天
2
0
docker日志监控

日志处理机制 我们先来了解一下docker日志处理的机制,当启动一个容器的时候,它其实是docker daemon的一个子进程,docker daemon可以拿到你容器里面进程的标准输出,拿到标准输出后,它会通...

爱宝贝丶
昨天
2
0
域名已备案,但jsapi添加支付授权目录依然提示支付授权目录未通过ICP备案!!!

问题描述: 一网站域名xxx.cn已备案成功,在全国工业和信息化部(http://beian.miit.gov.cn/publish/query/indexFirst.action)查询到备案成功的,但是在微信商户平台配置jsapi添加支付授权目录...

闊苡訆涐囍醣
昨天
3
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部