CN109117249A - 一种提升存储虚拟化系统性能的方法 - Google Patents

一种提升存储虚拟化系统性能的方法 Download PDF

Info

Publication number
CN109117249A
CN109117249A CN201810845331.3A CN201810845331A CN109117249A CN 109117249 A CN109117249 A CN 109117249A CN 201810845331 A CN201810845331 A CN 201810845331A CN 109117249 A CN109117249 A CN 109117249A
Authority
CN
China
Prior art keywords
priority
virtual machine
scheduling mode
load
business
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Pending
Application number
CN201810845331.3A
Other languages
English (en)
Inventor
张月辉
崔新民
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Zhengzhou Yunhai Information Technology Co Ltd
Original Assignee
Zhengzhou Yunhai Information Technology Co Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Zhengzhou Yunhai Information Technology Co Ltd filed Critical Zhengzhou Yunhai Information Technology Co Ltd
Priority to CN201810845331.3A priority Critical patent/CN109117249A/zh
Publication of CN109117249A publication Critical patent/CN109117249A/zh
Pending legal-status Critical Current

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/455Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
    • G06F9/45533Hypervisors; Virtual machine monitors
    • G06F9/45558Hypervisor-specific management and integration aspects
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/48Program initiating; Program switching, e.g. by interrupt
    • G06F9/4806Task transfer initiation or dispatching
    • G06F9/4843Task transfer initiation or dispatching by program, e.g. task dispatcher, supervisor, operating system
    • G06F9/4881Scheduling strategies for dispatcher, e.g. round robin, multi-level priority queues
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/50Allocation of resources, e.g. of the central processing unit [CPU]
    • G06F9/5005Allocation of resources, e.g. of the central processing unit [CPU] to service a request
    • G06F9/5027Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resource being a machine, e.g. CPUs, Servers, Terminals
    • G06F9/5038Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resource being a machine, e.g. CPUs, Servers, Terminals considering the execution order of a plurality of tasks, e.g. taking priority or time dependency constraints into consideration
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/50Allocation of resources, e.g. of the central processing unit [CPU]
    • G06F9/5005Allocation of resources, e.g. of the central processing unit [CPU] to service a request
    • G06F9/5027Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resource being a machine, e.g. CPUs, Servers, Terminals
    • G06F9/505Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resource being a machine, e.g. CPUs, Servers, Terminals considering the load
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/455Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
    • G06F9/45533Hypervisors; Virtual machine monitors
    • G06F9/45558Hypervisor-specific management and integration aspects
    • G06F2009/4557Distribution of virtual machine instances; Migration and load balancing
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/455Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
    • G06F9/45533Hypervisors; Virtual machine monitors
    • G06F9/45558Hypervisor-specific management and integration aspects
    • G06F2009/45583Memory management, e.g. access or allocation

Landscapes

  • Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)

Abstract

本发明公开了一种提升存储虚拟化系统性能的方法,包括以下步骤:在存储虚拟化系统中启动多个虚拟机;根据各虚拟机运行业务的优先级设定业务优先级;定时收集各虚拟机的系统负载情况;根据各虚拟机的业务优先级和系统负载情况,计算获得各虚拟机的进程调度方式和进程优先级。本发明公开的提升存储虚拟化系统性能的方法,通过结合存储系统虚拟化系统的业务优先级、虚拟机系统负载,计算出不同虚拟机进程的调度方式和优先级增长因子,进而给虚拟机设置相对应的进程的调度方式和优先级。通过这种动态调整虚拟机进程调度方式和优先级的方法,达到提升存储虚拟化系统的整体性能。

Description

一种提升存储虚拟化系统性能的方法
技术领域
本发明涉及存储技术领域,尤其涉及一种提升存储虚拟化系统性能的方法。
背景技术
在存储虚拟化系统中,一台物理服务器会安装多台虚拟机,每台虚拟机分别部署各自的存储操作系统来处理用户不同的业务。多台虚拟机之间会竞争物理服务器的CPU和内存资源,每台虚拟机在不同时刻会有不同的压力负载。为了提升虚拟机的性能,目前常用的方式就是固定的给不同虚拟机分配不同的CPU和内存资源,然后根据不同虚拟机系统的业务,分别设置不同虚拟机进程的优先级。但对于常用的方式,存在以下问题:不同虚拟机的压力负载是实时变化的,如果给运行业务优先级较高的虚拟机A设置了较高的进程优先级,但是当前时刻并没有很高的压力负载,这样就会浪费系统资源。反而业务优先级较低但是存在很大压力负载的虚拟机B就不能很好的得到调度。
基于上述问题,因此,对于本领域技术人员而言,如何实现提升存储虚拟化系统性能,是亟需解决的技术问题。
发明内容
基于背景技术存在的技术问题,本发明提出了一种提升存储虚拟化系统性能的方法,通过结合存储系统虚拟化系统的业务优先级、虚拟机系统负载,计算出不同虚拟机进程的调度方式和优先级增长因子,进而给虚拟机设置相对应的进程的调度方式和优先级。通过这种动态调整虚拟机进程调度方式和优先级的方法,达到提升存储虚拟化系统的整体性能。
本发明提出的一种提升存储虚拟化系统性能的方法,包括以下步骤:
在存储虚拟化系统中启动多个虚拟机;
根据各虚拟机运行业务的优先级设定业务优先级;
定时收集各虚拟机的系统负载情况;
根据各虚拟机的业务优先级和系统负载情况,计算获得各虚拟机的进程调度方式和进程优先级。
优选地,虚拟机的系统负载情况收集方式为:系统负载信息收集单元每隔5S实时收集各虚拟机的系统负载情况。
优选地,虚拟机的系统负载情况收集方法为:通过各虚拟机执行top任务,在输出中记录load average的数值。
优选地,在存储虚拟化系统中虚拟机的数量为两个,两个虚拟机运行业务的优先级设定业务优先级business_pri1,business_pri2,两个虚拟机的系统负载sysload1和sysload2。
优选地,根据各虚拟机的业务优先级和系统负载情况,计算获得各虚拟机的进程调度方式和进程优先级,上述步骤包括定义并收集存储系统虚拟化系统的业务优先级、虚拟机系统负载类型两个参数,具体方式包括以下步骤:
虚拟机进程的调度方式分别有other和RR,分别代表低调低和高调度模式,虚拟机进程优先级范围为[0,99],数值越大代表优先级越高;
设定系统负载高低定义,系统负载数值在[0,min]区间,则定义系统负载为低负载;系统负载数值在[min,max],则定义系统负载为高负载。
优选地,根据各虚拟机的业务优先级和系统负载情况,计算获得各虚拟机的进程调度方式和进程优先级,上述步骤包括计算出不同虚拟机进程的调度方式和优先级增长因子,进而给虚拟机设置相对应的进程的调度方式和优先级;具体方式包括以下步骤:
如果sysload1和sysload2均属于低负载,则判断business_pri1和business_pri2,如果business_pri1较大,则设定VM1的进程调度方式为RR,反之则设定VM2的进程调度方式为RR,两个虚拟机的优先级均为0;
如果sysload1为低负载,sysload2为高负载,则设定VM2的进程调度方式为RR,VM2的进程优先级增长因子为+1;VM1的进程调度方式为other,VM1的优先级增长因子为-1;
如果sysload2为低负载,sysload1为高负载,则设定VM1的进程调度方式为RR,VM1的进程优先级增长因子为+1;VM2的进程调度方式为other,VM2的优先级增长因子为-1;
如果sysload1和sysload2均属于高负载,则判断business_pri1和business_pri2,如果business_pri1较大,则设定VM1的进程调度方式为RR,同时设置VM1的进程优先级增长因子为+1;同时设定VM1的进程调度方式也为RR,但是设置VM2的进程优先级增长因子为-1;
根据得到的虚拟机进程调度方式和进程优先级分别设定两个虚拟机VM1和VM2的进程调度方式和进程优先级;如果进程优先级降为0,则保持0不变。如果进程优先级增长为99,则保持99不变。
本发明中提供的一种提升存储虚拟化系统性能的方法,通过结合存储系统虚拟化系统的业务优先级、虚拟机系统负载,计算出不同虚拟机进程的调度方式和优先级增长因子,进而给虚拟机设置相对应的进程的调度方式和优先级。通过这种动态调整虚拟机进程调度方式和优先级的方法,达到提升存储虚拟化系统的整体性能。
附图说明
图1为本发明提出的一种提升存储虚拟化系统性能的方法的流程图。
具体实施方式
如图1所示,图1为本发明提出的一种提升存储虚拟化系统性能的方法的流程图。
下面结合附图和实施例对本发明进行详细的描述。
本实施例中以存储虚拟化系统中两个虚拟机为例,一种提升存储虚拟化系统性能的方法,包括以下步骤:
S1:在存储虚拟化系统中启动两个虚拟机;
S2:系统负载信息收集单元每隔5S实时收集两个虚拟机的系统负载情况,其中,收集方法为通过各虚拟机执行top任务,在输出中记录load average的数值;
S3:两个虚拟机运行业务的优先级设定业务优先级business_pri1,business_pri2,两个虚拟机的系统负载sysload1和sysload2;
S4:虚拟机进程的调度方式分别有other和RR,分别代表低调低和高调度模式,虚拟机进程优先级范围为[0,99],数值越大代表优先级越高;
S5:设定系统负载高低定义,系统负载数值在[0,min]区间,则定义系统负载为低负载;系统负载数值在[min,max],则定义系统负载为高负载;
S6:如果sysload1和sysload2均属于低负载,则判断business_pri1和business_pri2,如果business_pri1较大,则设定VM1的进程调度方式为RR,反之则设定VM2的进程调度方式为RR,两个虚拟机的优先级均为0;
S7:如果sysload1为低负载,sysload2为高负载,则设定VM2的进程调度方式为RR,VM2的进程优先级增长因子为+1;VM1的进程调度方式为other,VM1的优先级增长因子为-1;
S8:如果sysload2为低负载,sysload1为高负载,则设定VM1的进程调度方式为RR,VM1的进程优先级增长因子为+1;VM2的进程调度方式为other,VM2的优先级增长因子为-1;
S9:如果sysload1和sysload2均属于高负载,则判断business_pri1和business_pri2,如果business_pri1较大,则设定VM1的进程调度方式为RR,同时设置VM1的进程优先级增长因子为+1;同时设定VM1的进程调度方式也为RR,但是设置VM2的进程优先级增长因子为-1;
S10:根据得到的虚拟机进程调度方式和进程优先级分别设定两个虚拟机VM1和VM2的进程调度方式和进程优先级;如果进程优先级降为0,则保持0不变。如果进程优先级增长为99,则保持99不变。
以上所述,仅为本发明较佳的具体实施方式,但本发明的保护范围并不局限于此,任何熟悉本技术领域的技术人员在本发明揭露的技术范围内,根据本发明的技术方案及其发明构思加以等同替换或改变,都应涵盖在本发明的保护范围之内。

Claims (6)

1.一种提升存储虚拟化系统性能的方法,其特征在于,包括以下步骤:
在存储虚拟化系统中启动多个虚拟机;
根据各虚拟机运行业务的优先级设定业务优先级;
定时收集各虚拟机的系统负载情况;
根据各虚拟机的业务优先级和系统负载情况,计算获得各虚拟机的进程调度方式和进程优先级。
2.根据权利要求1所述的提升存储虚拟化系统性能的方法,其特征在于,虚拟机的系统负载情况收集方式为:系统负载信息收集单元每隔5S实时收集各虚拟机的系统负载情况。
3.根据权利要求1所述的提升存储虚拟化系统性能的方法,其特征在于,虚拟机的系统负载情况收集方法为:通过各虚拟机执行top任务,在输出中记录load average的数值。
4.根据权利要求1所述的提升存储虚拟化系统性能的方法,其特征在于,在存储虚拟化系统中虚拟机的数量为两个,两个虚拟机运行业务的优先级设定业务优先级business_pri1,business_pri2,两个虚拟机的系统负载sysload1和sysload2。
5.根据权利要求4所述的提升存储虚拟化系统性能的方法,其特征在于,根据各虚拟机的业务优先级和系统负载情况,计算获得各虚拟机的进程调度方式和进程优先级,上述步骤包括定义并收集存储系统虚拟化系统的业务优先级、虚拟机系统负载类型两个参数,具体方式包括以下步骤:
虚拟机进程的调度方式分别有other和RR,分别代表低调低和高调度模式,虚拟机进程优先级范围为[0,99],数值越大代表优先级越高;
设定系统负载高低定义,系统负载数值在[0,min]区间,则定义系统负载为低负载;系统负载数值在[min,max],则定义系统负载为高负载。
6.根据权利要求4所述的提升存储虚拟化系统性能的方法,其特征在于,根据各虚拟机的业务优先级和系统负载情况,计算获得各虚拟机的进程调度方式和进程优先级,上述步骤包括计算出不同虚拟机进程的调度方式和优先级增长因子,进而给虚拟机设置相对应的进程的调度方式和优先级;具体方式包括以下步骤:
如果sysload1和sysload2均属于低负载,则判断business_pri1和business_pri2,如果business_pri1较大,则设定VM1的进程调度方式为RR,反之则设定VM2的进程调度方式为RR,两个虚拟机的优先级均为0;
如果sysload1为低负载,sysload2为高负载,则设定VM2的进程调度方式为RR,VM2的进程优先级增长因子为+1;VM1的进程调度方式为other,VM1的优先级增长因子为-1;
如果sysload2为低负载,sysload1为高负载,则设定VM1的进程调度方式为RR,VM1的进程优先级增长因子为+1;VM2的进程调度方式为other,VM2的优先级增长因子为-1;
如果sysload1和sysload2均属于高负载,则判断business_pri1和business_pri2,如果business_pri1较大,则设定VM1的进程调度方式为RR,同时设置VM1的进程优先级增长因子为+1;同时设定VM1的进程调度方式也为RR,但是设置VM2的进程优先级增长因子为-1;
根据得到的虚拟机进程调度方式和进程优先级分别设定两个虚拟机VM1和VM2的进程调度方式和进程优先级;如果进程优先级降为0,则保持0不变。如果进程优先级增长为99,则保持99不变。
CN201810845331.3A 2018-07-27 2018-07-27 一种提升存储虚拟化系统性能的方法 Pending CN109117249A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201810845331.3A CN109117249A (zh) 2018-07-27 2018-07-27 一种提升存储虚拟化系统性能的方法

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201810845331.3A CN109117249A (zh) 2018-07-27 2018-07-27 一种提升存储虚拟化系统性能的方法

Publications (1)

Publication Number Publication Date
CN109117249A true CN109117249A (zh) 2019-01-01

Family

ID=64862330

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201810845331.3A Pending CN109117249A (zh) 2018-07-27 2018-07-27 一种提升存储虚拟化系统性能的方法

Country Status (1)

Country Link
CN (1) CN109117249A (zh)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN110297691A (zh) * 2019-07-03 2019-10-01 四川长虹电器股份有限公司 一种优化Android系统ART虚拟机内存管理的方法

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101894047A (zh) * 2010-06-24 2010-11-24 北京航空航天大学 一种基于内核虚拟机调度策略的实现方法
US20120030407A1 (en) * 2008-06-11 2012-02-02 Vmware, Inc. System and method for improving memory locality of virtual machines
CN102378962A (zh) * 2009-03-31 2012-03-14 微软公司 基于优先级的系统负载水平管理
CN103870341A (zh) * 2014-03-12 2014-06-18 汉柏科技有限公司 一种调整虚拟机资源的方法和系统
CN104484220A (zh) * 2014-11-28 2015-04-01 杭州华为数字技术有限公司 虚拟化集群的动态资源调度的方法及装置

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20120030407A1 (en) * 2008-06-11 2012-02-02 Vmware, Inc. System and method for improving memory locality of virtual machines
CN102378962A (zh) * 2009-03-31 2012-03-14 微软公司 基于优先级的系统负载水平管理
CN101894047A (zh) * 2010-06-24 2010-11-24 北京航空航天大学 一种基于内核虚拟机调度策略的实现方法
CN103870341A (zh) * 2014-03-12 2014-06-18 汉柏科技有限公司 一种调整虚拟机资源的方法和系统
CN104484220A (zh) * 2014-11-28 2015-04-01 杭州华为数字技术有限公司 虚拟化集群的动态资源调度的方法及装置

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN110297691A (zh) * 2019-07-03 2019-10-01 四川长虹电器股份有限公司 一种优化Android系统ART虚拟机内存管理的方法

Similar Documents

Publication Publication Date Title
WO2020206705A1 (zh) 一种基于集群节点负载状态预测的作业调度方法
CN103475538B (zh) 一种基于多接口的自适应的云服务测试方法
CN103699433B (zh) 一种于Hadoop平台中动态调整任务数目的方法及系统
CN103605574A (zh) 一种服务器集群中的虚拟机资源调度方法及系统
CN102968344A (zh) 一种多虚拟机迁移调度的方法
CN111399986A (zh) Pod资源配额配置方法及装置
CN103823714A (zh) 一种基于虚拟化下NUMA节点内存QoS的调节方法及装置
CN105607952B (zh) 一种虚拟化资源的调度方法及装置
CN110347515B (zh) 一种适合边缘计算环境的资源优化分配方法
CN106201693B (zh) 一种虚拟化环境中的调度方法及系统
CN108770017A (zh) 一种无线资源动态均衡方法及系统、计算机程序
CN109117249A (zh) 一种提升存储虚拟化系统性能的方法
CN107220108A (zh) 一种实现云数据中心负载均衡的方法和系统
CN102567113A (zh) 前台程序的调配系统及实现方法
CN106445636A (zh) 一种paas平台下的动态资源调度算法
CN101510228A (zh) 产品stl模型非均匀精简方法
CN114580919A (zh) 多场景两阶段需求响应资源优化调度方法、装置及设备
CN103383654B (zh) 调节mapper在多核上执行的方法及装置
CN107370783A (zh) 一种云计算集群资源的调度方法及装置
CN111552569B (zh) 系统资源调度方法、装置及存储介质
CN110084507B (zh) 云计算环境下分级感知的科学工作流调度优化方法
CN103647823A (zh) 一种云计算操作系统下的存储资源调度方法
CN103685541B (zh) IaaS云系统运行速率动态控制装置、系统及方法
CN110275895A (zh) 一种缺失交通数据的填充设备、装置及方法
CN109144693A (zh) 一种功率自适应任务调度方法及系统

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination
RJ01 Rejection of invention patent application after publication
RJ01 Rejection of invention patent application after publication

Application publication date: 20190101