云计算Openstack 虚拟机调度策略

OpenStack的虚拟机调度策略是一个复杂而灵活的系统,它主要由两种调度器实现:FilterScheduler(过滤调度器)和ChanceScheduler(随机调度器)。以下是对这两种调度器及其调度策略的详细解释:

一、FilterScheduler(过滤调度器)

FilterScheduler是OpenStack默认的调度器,它实现了基于主机过滤(filtering)和权值计算(weighing)的调度算法。

  1. 主机过滤(filtering)
    • FilterScheduler通过一系列过滤器(filters)来筛选满足虚拟机需求的计算节点。这些过滤器包括但不限于:
      • RetryFilter:刷掉之前已经调度过的节点,避免重复调度。
      • AvailabilityZoneFilter:根据可用域(Availability Zone)来筛选计算节点,提高容灾性和隔离服务。
      • RamFilter:根据可用内存来筛选计算节点,确保虚拟机有足够的内存资源。
      • DiskFilter:根据磁盘空间来筛选计算节点,确保虚拟机有足够的磁盘资源。
      • ComputeFilter:确保只有nova-compute服务正常工作的计算节点才能被调度。
      • ComputeCapabilitiesFilter:根据计算节点的特性(如架构类型)来筛选。
      • ImagePropertiesFilter:根据所选镜像的属性(如Hypervisor类型)来筛选匹配的计算节点。
      • ServerGroupAntiAffinityFilter:尽量将虚拟机分散部署到不同的计算节点上。
      • ServerGroupAffinityFilter:尽量将虚拟机部署到同一个计算节点上。
        过滤器可以通过配置文件(如nova.conf)进行自定义和扩展,以满足不同的业务需求。
  2. 权值计算(weighing)
    • 在通过过滤器筛选后,FilterScheduler会根据一系列权重计算器(weighers)来计算剩余计算节点的权重值。
    • 权重计算器包括但不限于:
      • RAMWeigher:根据可用的RAM大小来决定计算节点的权重。
      • DiskWeigher:根据可用的磁盘大小来进行权值分配。
      • MetricsWeigher:通过主机的不同参数度量来决定主机的权值。
      • IoOpsWeigher:通过主机的IO负载来进行权重计算,默认选择负载最小的主机。
      • ServerGroupSoftAffinityWeigher:通过同一个主机组中运行的实例数进行权重计算。
    • 最终,FilterScheduler会选择权重值最高的计算节点来创建虚拟机实例。

二、ChanceScheduler(随机调度器)

ChanceScheduler是一个基于随机算法来选择可用主机的简单调度引擎。它不从任何资源审查的角度进行调度决策,而是从所有正常运行nova-compute服务的节点中随机选择一个来创建实例。这种调度策略在实际生产环境中基本上不会用到,因为它不提供资源优化和负载均衡等高级功能。

三、调度过程

  1. 获取所有主机的信息,并根据调度请求中的要求(如忽略某些主机或只调度到某些主机上)来筛选候选主机。
  2. 将筛选后的主机列表依次通过配置的所有过滤器的处理函数,过滤掉不满足相应条件的主机。
  3. 对过滤后剩余的主机列表根据配置的权重计算器进行排序,选择权重值最高的主机作为虚拟机的部署目标。

四、错误排查与监控

在OpenStack的虚拟机调度过程中,可能会出现调度失败的情况。这时,管理员需要查看相关的日志文件(如nova-conductor和nova-scheduler的日志)来排查问题。此外,OpenStack还提供了一些工具和项目(如Watcher和Congress)来帮助监控和优化云资源的使用情况。

五、配置

在OpenStack中,虚拟机的调度策略可以通过Nova组件进行配置和定制。以下是一些常见的调度策略及其配置方法:

  1. CPU过滤:确保虚拟机调度到具有特定CPU特性(例如:Intel VT或AMD-V)的主机上。
[scheduler]
allowed_filters=nova.filters.all_filters
weight_classes=nova.scheduler.filters.spice.host_cpu_weight_obj.HostCPUWeight
  1. 主机集群过滤:根据虚拟机请求的特定主机集群进行调度。
[filter_scheduler]
host_aggregate_filters=nova.filters.host_aggregate_filters.AggregateHostFilter
  1. 权重调度:通过定义权重类来调整主机选择,例如,可以根据CPU或内存资源的使用情况来调整权重。
[defaults]
scheduler_default_weights=ComputeWeight=1.0
  1. 分区调度:在多个分区(如多个数据中心)之间调度实例。
[scheduler]
driver=nova.scheduler.filter_scheduler.FilterScheduler
  1. 可用性区域:在特定的可用性区域内调度虚拟机以保护数据免受单点故障影响。
[filter_scheduler]
scheduler_available_filters=nova.scheduler.filters.standard_filters.AvailabilityZoneFilter
  1. 主机选择:根据特定条件选择主机,例如,最小内存空闲量。
[scheduler]
driver=nova.scheduler.host_manager.HostManager

这些策略可以通过修改nova.conf文件并重启相关服务来生效。根据具体需求,可以通过编写自定义的过滤器或权重类来扩展调度器的功能。

六、自定义过滤器

在OpenStack中,虚拟机调度策略可以通过自定义filter和weigher来实现,以满足不同的业务需求。

1、自定义filter

  1. 作用:
    • 自定义filter允许用户根据特定的条件或规则来筛选计算节点,从而确保虚拟机被调度到满足需求的主机上。
  2. 实现方式:
    • 用户可以通过编写自定义的Python代码来实现filter,并将其添加到OpenStack的调度器中。
    • 自定义filter需要实现特定的接口和函数,以便与OpenStack的调度框架进行集成。
  3. 示例:自定义Filter样例:TagFilter
  • 目的:
    筛选具有特定标签的计算节点。

  • 实现步骤:

    • 创建一个新的Python文件,例如tag_filter.py。
    • 在文件中导入必要的模块,并实现TagFilter类。
    • TagFilter类需要继承自OpenStack的HostFilter类,并实现host_passes方法。
    • 在host_passes方法中,编写逻辑来检查计算节点是否具有指定的标签。
  • 示例代码:

from nova.scheduler.filters import HostFilter  
from nova import objects  class TagFilter(HostFilter):  """Filter hosts by a specific tag."""  def __init__(self):  self.required_tag = 'my_custom_tag'  # 设置所需的标签  def host_passes(self, host_state, filter_properties):  """Check if the host has the required tag."""  # 获取计算节点的元数据  metadata = host_state.host_summary['nova-compute'].get('metadata', {})  # 检查标签是否存在  if self.required_tag in metadata and metadata[self.required_tag] == 'true':  return True  return False
  • 配置:
    • 将tag_filter.py文件放置在OpenStack的调度器插件目录中。
    • 在OpenStack的配置文件(如nova.conf)中,添加自定义filter到scheduler_available_filters和scheduler_default_filters中。
[scheduler]  
scheduler_available_filters = ... ,nova.scheduler.filters.tag_filter.TagFilter  
scheduler_default_filters = ... ,TagFilter

2、自定义weigher

  1. 作用:
    • 自定义weigher允许用户根据特定的权重计算规则来对计算节点进行排序,从而选择最优的计算节点来部署虚拟机。
  2. 实现方式:
    • 用户可以通过编写自定义的Python代码来实现weigher,并将其添加到OpenStack的调度器中。
    • 自定义weigher需要实现特定的接口和函数,以便与OpenStack的调度框架进行集成。
  3. 示例:自定义Weigher样例:CpuUsageWeigher
  • 目的:
    根据计算节点的CPU使用率进行排序,选择CPU使用率较低的计算节点。

  • 实现步骤:

    • 创建一个新的Python文件,例如cpu_usage_weigher.py。
    • 在文件中导入必要的模块,并实现CpuUsageWeigher类。
    • CpuUsageWeigher类需要继承自OpenStack的Weigher类,并实现weigh_objects方法。
    • 在weigh_objects方法中,编写逻辑来计算每个计算节点的CPU使用率,并根据使用率进行排序。
  • 示例代码:

from nova.scheduler.weighers import Weigher  
from nova import objects  class CpuUsageWeigher(Weigher):  """Weigh hosts by CPU usage."""  def weigh_objects(self, hosts, filter_properties):  """Weigh the hosts by CPU usage."""  weighed_hosts = []  for host in hosts:  # 假设host_state有一个方法或属性可以获取CPU使用率  cpu_usage = host.host_summary['nova-compute'].get('cpu_usage', 100)  # 默认值为100%  # 计算权重,这里简单地使用100 - cpu_usage作为权重值  weight = 100 - cpu_usage  weighed_host = objects.HostState(host=host, weight=weight)  weighed_hosts.append(weighed_host)  # 根据权重值进行排序  weighed_hosts.sort(key=lambda x: x.weight, reverse=True)  return weighed_hosts

注意:上述代码中的cpu_usage获取方式仅为示例,实际实现中需要根据OpenStack的具体实现和计算节点的监控数据来获取CPU使用率。

  • 配置:
    • 将cpu_usage_weigher.py文件放置在OpenStack的调度器插件目录中。
    • 在OpenStack的配置文件(如nova.conf)中,添加自定义weigher到scheduler_weight_classes中。
[scheduler]  
scheduler_weight_classes = ... ,nova.scheduler.weighers.cpu_usage_weigher.CpuUsageWeigher

3、配置和使用自定义调度策略

  1. 配置自定义filter和weigher:
    • 在OpenStack的配置文件(如nova.conf)中,用户需要指定自定义filter和weigher的路径和名称。
    • 通过修改scheduler_available_filters和scheduler_weight_classes配置选项,将自定义filter和weigher添加到可用的filter和weigher列表中。
  2. 使用自定义调度策略:
    • 在创建虚拟机时,用户可以通过指定特定的flavor或其他参数来触发自定义调度策略的执行。
    • OpenStack的调度器会根据配置的自定义filter和weigher来筛选和排序计算节点,并最终选择最优的计算节点来部署虚拟机。

4、注意事项

  1. 兼容性:
    • 自定义filter和weigher需要与OpenStack的版本和架构兼容,以确保其能够正确运行和集成。
  2. 性能:
    • 自定义filter和weigher的执行效率会影响虚拟机的调度速度和性能。因此,在实现自定义调度策略时,需要关注其性能表现并进行优化。
  3. 安全性:
    • 自定义filter和weigher需要保证安全性,避免引入潜在的安全漏洞或风险。
      综上所述,OpenStack提供了灵活的虚拟机自定义调度策略,允许用户根据特定的需求和条件来筛选和排序计算节点。通过配置和使用自定义filter和weigher,用户可以实现对虚拟机调度过程的精细控制和优化。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/466224.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

汽修行业员工培训SOP的智能化搭建

汽修行业正经历着技术革新和服务模式的双重变革,员工的专业培训变得尤为重要。智能化的员工培训标准操作程序(SOP)在线知识库不仅能够提升培训效率,还能确保服务质量和作业安全。本文将探讨汽修行业如何智能化地搭建员工培训的SOP…

还在担心Mac卸载不干净?XApp帮你干净完成卸载

Mac的卸载机制非常独特,虽然将app拖拽到废纸篓也能够完成卸载,但是会有很多的文件残留,那么如何卸载干净非常重要 XApp,免费的Mac卸载工具,有着强大的垃圾检测机制,检测出更深层的垃圾,卸载更干…

游戏测试之浅谈测试思维

一、游戏测试与软件测试的区别 1、测试目标 软件测试:主要目标是确保软件在功能、性能、安全性等方面达到预期质量标准。关注点主要是软件的正确性、稳定性、安全性和效率。 游戏测试:不仅关注游戏的功能性和稳定性,还要关注游戏的体验性、平…

为什么Uptime+Kuma本地部署与远程使用是网站监控新选择?

文章目录 前言1.关于Uptime Kuma2.安装Docker3.本地部署Uptime Kuma4.使用Uptime Kuma5.cpolar内网穿透工具安装6.创建远程连接公网地址7.固定Uptime Kuma公网地址 前言 本篇文章介绍如何在本地部署Uptime Kuma,并结合cpolar内网穿透实现公网远程访问。 说起网站相…

使用Python创建自助抢单插件的完整指南

✅作者简介:2022年博客新星 第八。热爱国学的Java后端开发者,修心和技术同步精进。 🍎个人主页:Java Fans的博客 🍊个人信条:不迁怒,不贰过。小知识,大智慧。 💞当前专栏…

【论文解读】Med-BERT: 用于疾病预测的大规模结构化电子健康记录的预训练情境化嵌入

【论文解读】Med-BERT: 用于疾病预测的大规模结构化电子健康记录的预训练情境化嵌入 Med-BERT:pretrained contextualized embeddings on large-scale structured electronic health records for disease prediction ​ ​ 摘要:基于电子健康记录(EHR)的深度学习(DL)预…

MinGW-w64_10.0.0 + GCC12_x86_64-12.2.0-release-posix-seh-msvcrt-rt_v10-rev2.zip

主题:mingw-w64安装 以及 matlab适配mingw-w64,g,gcc 无套路直接下载mingw-w64 for matlab 通过百度网盘分享的文件: MinGW-w64_10.0.0 GCC12_x86_64-12.2.0-release-posix-seh-msvcrt-rt_v10-rev2.zip 链接:https…

一文了解git TAG

Git标签(Tag)用于为 Git 历史中的特定提交打上标记,通常用于标识重要的节点,比如发布版本。标签让开发者可以很方便地对特定版本进行引用,且不会随时间变动。Git 中的标签分为两种:轻量标签和附注标签。 …

xrc的比赛

先看考试题&#xff0c;附加题最后再写 T1 首先看到是求逆序对为奇数的子串&#xff0c;发现只需要贪心 贪心发现求长度为2的逆序对最优&#xff0c;所以时间复杂度为 O ( n ) O(n) O(n)的贪心就能过了 #include<bits/stdc.h> using namespace std; int read() {int x…

少儿编程教育的多维度对比:软件类、硬件类与软硬件结合课程的选择

随着少儿编程教育的不断发展&#xff0c;市场上涌现出多种类型的编程课程&#xff0c;主要分为软件类课程、硬件类课程和软硬件结合类课程。三种课程各有特色&#xff0c;针对不同的编程对象和教学目标。本文将从多个维度深入对比这三类课程的特点、教学目的和学习难点&#xf…

雷池社区版7.1新版本自定义NGINX配置分析

简单介绍雷池&#xff0c;是一款简单好用, 效果突出的 Web 应用防火墙(WAF)&#xff0c;可以保护 Web 服务不受黑客攻击。 雷池通过阻断流向 Web 服务的恶意 HTTP 流量来保护 Web 服务。雷池作为反向代理接入网络&#xff0c;通过在 Web 服务前部署雷池&#xff0c;可在 Web 服…

【原创】java+ssm+mysql收纳培训网系统设计与实现

个人主页&#xff1a;程序猿小小杨 个人简介&#xff1a;从事开发多年&#xff0c;Java、Php、Python、前端开发均有涉猎 博客内容&#xff1a;Java项目实战、项目演示、技术分享 文末有作者名片&#xff0c;希望和大家一起共同进步&#xff0c;你只管努力&#xff0c;剩下的交…

这款神器,运维绝杀 !!!

项目简介 CrowdSec 是一款开源的、基于社区协作的网络安全防护工具&#xff0c;它通过分析和共享IP信誉数据来对抗恶意行为。该软件不仅支持IPv6&#xff0c;而且相较于传统的Python实现&#xff0c;其采用Go语言编写&#xff0c;运行速度提升了60倍。CrowdSec 利用Grok模式解析…

推荐一款业内领先的建模工具:SAP PowerDesigner

SAP PowerDesigner是一款业内领先的建模工具&#xff0c;帮助您改进商务智能&#xff0c;打造更卓越的信息架构。通过该软件的元数据管理功能&#xff0c;可以构建关键信息资产的 360 度全方位视图&#xff0c;从而使数据管理、BI、数据集成和数据整合工作大获裨益。其分析功能…

Linux(CentOS)运行 jar 包

1、在本地终端运行&#xff0c;关闭终端&#xff0c;程序就会终止 java -jar tlias-0.0.1-SNAPSHOT.jar 发送请求&#xff0c;成功 关闭终端&#xff08;程序也会终止&#xff09; 发送请求&#xff0c;失败 2、在远程终端运行&#xff0c;关闭终端&#xff0c;程序就会终止 …

【JS学习】08. web API-事件进阶

Web APIs - 第3天 进一步学习 事件进阶&#xff0c;实现更多交互的网页特效&#xff0c;结合事件流的特征优化事件执行的效率 掌握阻止事件冒泡的方法理解事件委托的实现原理 事件流 事件流是对事件执行过程的描述&#xff0c;了解事件的执行过程有助于加深对事件的理解&…

Docker + Jenkins + gitee 实现CICD环境搭建

目录 前言 关于Jenkins 安装Jenkins docker中运行Jenkins注意事项 通过容器中的Jenkins&#xff0c;把服务打包到docker进行部署 启动Jenkins 创建第一个任务 前言 CI/CD&#xff08;持续集成和持续交付/持续部署&#xff09;&#xff0c;它可以实现自动化的构建、测试和部署…

150道MySQL高频面试题,学完吊打面试官--关于索引的五道大厂面试题,跳槽面试很重要

前言 本专栏为150道MySQL大厂高频面试题讲解分析&#xff0c;这些面试题都是通过MySQL8.0官方文档和阿里巴巴官方手册还有一些大厂面试官提供的资料。 MySQL应用广泛&#xff0c;在多个开发语言中都处于重要地位&#xff0c;所以最好都要掌握MySQL的精华面试题&#xff0c;这也…

在培训班学网络安全有用吗

在当今数字化时代&#xff0c;网络安全问题日益凸显&#xff0c;成为了企业和个人关注的焦点。随着对网络安全人才需求的不断增长&#xff0c;各种网络安全培训班也如雨后春笋般涌现。然而&#xff0c;在培训班学网络安全真的有用吗? 一、网络安全的重要性与挑战 1. 信息时代的…

SQL Server 2008 R2 详细安装教程及错误解决教程

SQL Server 2008 R2 详细安装教程及错误解决教程 文章目录 SQL Server 2008 R2 详细安装教程及错误解决教程1.装载或解压ISO文件2. 运行setup程序3. 下载并安装.NET Framework3.54.选择全新安装或向现有安装添加功能5.输入秘钥同意条款6.选择安装类型7.设置角色8.功能选择9.实例…