一种IPMI服务执行方法、装置及存储介质与流程

文档序号:27103535发布日期:2021-10-27 18:00阅读:236来源:国知局
一种IPMI服务执行方法、装置及存储介质与流程
一种ipmi服务执行方法、装置及存储介质
技术领域
1.本技术涉及ipmi服务执行领域,尤其涉及一种ipmi服务执行方法、装置及存储介质。


背景技术:

2.智能平台管理接口(ipmi)是一种开放标准的硬件管理接口规格,定义了嵌入式管理子系统进行通信的特定方法。ipmi信息是通过不依赖于服务器的处理器、bios或操作系统的基板管理控制器进行交流。使用而基板管理控制器不使用操作系统进行管理,具有两个主要优点:首先,此配置允许进行带外服务器管理;其次,操作系统不必负担传输系统状态数据的任务。linux使用ipmitool命令通过ipmi能够实现监控服务器的物理健康特征,如温度、电压、风扇工作状态、电源状态等;还可以通过串口、modem以及lan等远程环境管理服务器系统。
3.但是由于ipmitool仅支持单点服务器,在应用到数据中心中大规模服务器运维场景下,需要运维人员提供批量执行任务的逻辑配合ipmitool命令来获取服务器数据。常规的调用ipmitool命令方式,运行进程占用内存多,切换进程麻烦,cpu利用率低,进程创建和销毁速度慢。上述问题导致调用ipmitool命令来获取服务器数据的过程需要耗费较长的时间。即使为了提高ipmi服务执行效率降低ipmi服务执行时间,采用多线程的方式,在线程因为等待io或网络返回数据的时候,会阻塞当前线程,切换到其它线程,这样在当前线程等待io的过程中,其它线程可以继续执行。一旦当线程数量非常多的时候,一是系统线程会占用非常多的内存空间,二是对线程进行管理需要额外的开销、影响cpu的处理能力,线程切换会导致系统用户态和内核态的转换,同样也会造成时间浪费。综上,现有技术中,ipmi服务应用在大批量设备数据采集时存在执行慢,占用资源严重的问题。


技术实现要素:

4.为了解决上述技术问题或者至少部分地解决上述技术问题,本技术提供一种ipmi服务执行方法、装置及存储介质。
5.第一方面,本技术提供了一种ipmi服务执行方法,包括,
6.s1,用户配置需要带外执行的命令来构建ipmi任务;
7.s2,根据采集端负载自适应配置线程池一定数量的线程;
8.s3,利用线程资源构建协程池,根据ipmi任务创建设定数量的协程并放入协程池,实现将所述ipmi任务分配给线程;
9.s4,通过调度器根据协程优先级和状态调度协程执行ipmi任务,协程完成ipmi任务后协程池回收和销毁该协程;
10.s5,线程完成后进入空闲,cpu切换下一个线程执行,给空闲线程分配ipmi任务,直至将全部ipmi任务执行完;
11.s6,实时监听各个ipmi任务的返回值,整理为json格式,返回给用户。
12.更进一步地,配置若干与服务器连接的连接信息,其中所述连接信息包括数据中心服务器的ip地址、用户名以及密码,配置的ip地址、用户名和密码按设定的格式排列、以便通过ipmi接口与服务器的基板管理控制器连接。
13.更进一步地,按如下公式自适应配置线程池线程数量:
14.线程池线程数量=(线程io响应时间/线程cpu时间+1)
×
cpu数量。
15.更进一步地,构建ipmi任务时,为每个ipmi任务配置与ipmi任务本身重要程度相关联的重要程度参数;在将ipmi任务分配给线程后,统计该线程下全部ipmi任务重要程度参数的平均值,根据重要程度参数的平均值大小确定cpu执行线程的次序。
16.更进一步地,协程状态包括运行中、阻塞、等待以及可运行,其中,
17.运行中为协程使用cpu资源执行ipmi任务;
18.当运行中的协程因io延迟以及异步等待导致停滞时,协程处于阻塞;
19.协程阻塞时,协程主动放弃cpu占用,返回协程池,协程进入等待;
20.当等待的协程条件满足可继续运行时,协程进入可运行,另外新加入到协程池的协程也为可运行。
21.更进一步地,为协程配置表示优先级的变量,初始化优先级的变量等于重要程度参数,每当协程停滞返回协程池,变量值加设定的步进量。
22.更进一步地,通过调度器根据协程优先级和状态调度协程执行ipmi任务包括:
23.监测运行中的协程是否陷入阻塞;
24.如果陷入阻塞,调度器比较协程池处于可运行状态协程的优先级;
25.调度器调取优先级值最大的可运行的协程执行ipmi任务。
26.更进一步地,封装ipmitool,利用ipmitool的指令配置需要带外执行的命令。
27.第二方面,本技术提供一种实现ipmi服务执行方法的装置,包括处理单元、存储单元、总线单元、接口单元、输入单元以及显示单元,所述总线单元电性连接处理单元、存储单元、接口单元、输入单元以及显示单元;
28.所述存储单元存储至少一条指令,所述处理单元执行所述指令实现所述ipmi服务执行方法;
29.所述接口单元用于与数字中心服务器连接;
30.所述输入单元用于配置连接信息与需要带外执行的命令;
31.所述显示单元用于显示与用户的交互信息以及ipmi任务的返回值。
32.第三方面本技术提供一种用于ipmi服务执行的存储介质,所述存储介质存储至少一条指令,执行所述指令实现所述ipmi服务执行方法。
33.本技术实施例提供的上述技术方案与现有技术相比具有如下优点:
34.本技术根据协程阻塞的次数更新协程的优先级,并利用优先级以及协程的状态来在发生协程阻塞时有效的调度协程到cpu运行。完全通过用户态调度器进行调度,无需系统在用户态和内核态之间来回切换,调度时间更快,使得执行ipmi任务的效率提高。
35.本技术利用线程资源构建协程池,协程池配置协程来处理ipmi任务,由于协程对于cpu来说是不可见的,协程的切换无需cpu从用户态切换到内核态在切换到用户态,协程的切换速度更快。协程阻塞切换协程,使得线程不会阻塞持续运行。本技术仅仅在cpu执行完线程后按顺序执行下一个线程才进行线程切换,直至执行完全部配置的ipmi任务,相比
现有通过线程来执行ipmi指令在发生线程阻塞后即切换线程的方式,利用更快地协程切换取代线程切换,大大减少线程之间来回切换次数,从而节约了时间,使得处理ipmi任务更快,效率更高。
36.本技术通过配置需要带外执行的命令来构建ipmi任务,并根据ipmi任务构建协程,从而突破现有ipmitool工具单点服务的限制,能够应用在多服务器节点。
37.本技术构建线程池提供线程由cpu选择执行,空闲线程分配ipmi任务,实现ipmi任务分配与执行的异步,通过线程池保证cpu资源的充分利用。而且cpu根据线程中重要程度参数的平均值选取执行的线程,可以优先处理重要ipmi任务相对多的线程。
附图说明
38.此处的附图被并入说明书中并构成本说明书的一部分,示出了符合本发明的实施例,并与说明书一起用于解释本发明的原理。
39.为了更清楚地说明本发明实施例或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,对于本领域普通技术人员而言,在不付出创造性劳动性的前提下,还可以根据这些附图获得其他的附图。
40.图1为本实施例提供的一种ipmi服务执行方法示意图;
41.图2为本实施例提供的一种ipmi服务执行方法示意图;
42.图3为本实施例提供的第一种实现ipmi服务执行方法的装置架构图;
43.图4为本实施例提供的第二种实现ipmi服务执行方法的装置架构图;
44.图5为本实施例提供的第三种实现ipmi服务执行方法的装置架构图。
具体实施方式
45.为使本技术实施例的目的、技术方案和优点更加清楚,下面将结合本技术实施例中的附图,对本技术实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例是本技术的一部分实施例,而不是全部的实施例。基于本技术中的实施例,本领域普通技术人员在没有做出创造性劳动的前提下所获得的所有其他实施例,都属于本技术保护的范围。
46.需要说明的是,在本文中,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者设备所固有的要素。在没有更多限制的情况下,由语句“包括一个
……”
限定的要素,并不排除在包括所述要素的过程、方法、物品或者设备中还存在另外的相同要素。
47.本技术旨在利用协程实现cpu并行执行ipmi任务,减少以线程执行ipmi任务的方式造成cpu切换线程耗时耗资源的情况,对于linux系统,现有由线程实现并发执行ipmi任务的过程如下:
48.(1)cpu在运行线程时处于用户模式,cpu运行的线程阻塞即停止线程,并切换至内核模式,由内核接管cpu控制权。
49.(2)内核记录下当前cpu和内存的状态信息,当前cpu和内存的状态信息在恢复被停止的线程时需要用到。
50.(3)内核准备执行下一个下程,从准备就绪的线程中选择一个执行。
51.(4)内核为新线程准备cpu和内存。
52.(5)内核将cpu切换至用户模式,将cpu控制权移交给新线程。
53.根据上述描述的线程执行ipmi任务并发过程,每次进行线程切换都会涉及cpu内核态和用户态的切换,造成大量的时间浪费。而且阻塞频繁,内核记录下被阻塞的线程的状态信息多,会占用大量的资源。
54.耗时耗资源的情况在对大规模应用服务器的数据中心通过ipmi进行数据采集的过程中更加明显。数据中心服务器数量多,ipmi任务线程与服务器通信会更加频繁,遇到的通信延迟或者异步等待情况更多,造成的线程阻塞以及线程切换频繁,导致耗时耗资源情况更加严重,ipmi服务执行速度慢,效率低。
55.实施例1
56.为解决上述问题,本实施例提供一种ipmi服务执行方法,应用在数据中心服务器和采集端,通过配置若干与数据中心服务器连接的连接信息,其中所述连接信息包括数据中心服务器的ip地址、用户名以及密码,配置的ip地址、用户名和密码按设定的格式排列保存于登录文件中,采集端获取登录文件的内容解析处ip地址、用户名以及密码连接到服务器,服务器通过创建session的方式保存采集端的登录信息。
57.参阅图1所示,本技术ipmi服务执行方法具体过程包括:
58.s1,用户在采集端配置需要带外执行的命令来构建ipmi任务。具体实施过程中,用户根据信息采集需要配置需要带外执行的命令来构建ipmi任务,本技术封装ipmitool,带外执行的命令使用ipmitool命令构建。具体实施过程中,一种可行的用户在采集端配置需要带外执行的命令来构建ipmi任务方式是:设置一个ipmi任务配置文件,在所述ipmi任务配置文件中保存利用ipmitool命令编辑的带外执行命令。通过采集端的命令行、vi工具来编辑所述ipmi任务配置文件实现ipmi任务输入。具体实施过程中,一种可行的用户在采集端配置需要带外执行的命令来构建ipmi任务方式是:提供一种图形化的ipmi任务配置程序,该程序采集采集端连接的服务器的名称,并将服务器展示给用户,提供图形化的选择按键,用户通过选择按键从采集的服务器中选择至少一个作为ipmi任务的目标服务器;该程序提供ipmitool命令的图形化按钮,通过图形化按钮输入相应的ipmitool命令形成外带执行指令,将目标服务器与带外执行指令搭配形成ipmi任务写入到所述ipmi任务配置文件。ipmitool命令图形化按钮提供常用的ipmitool命令输入,包括:raw、lan、chassis、event、bmc、sdr、sensor、fru、sel、sol、user、channel、session、shell、exec、set。用户选择图形化按钮时,触发提示框,该提示框显示该图形化按钮所输入的ipmitool命令的含义及用法。通过图形化的ipmi任务配置程序配置所述ipmi任务配置文件的内容以帮助与ipmitool接触不多的用户构建ipmi任务。
59.具体实施过程中,在构建ipmi任务时,为每个ipmi任务配置一个重要程度属性,给重要程度属性赋予不同大小的非负数值表示ipmi任务的重要程度,数值越大,表示该ipmi任务越重要。
60.s2,根据采集端负载来自适应配置线程池的线程数量。按如下公式自适应配置线程池线程数量:线程池线程数量=(线程io响应时间/线程cpu时间+1)
×
cpu数量。采集端cpu执行线程池中的线程,每个cpu同一时刻执行一个所述线程。具体实施过程中,为线程池中的线程定义一个空闲时间阈值,当线程池中的空闲时,统计线程池中线程的空闲持续时
间,如果所述空闲持续时间到达所述空闲时间阈值,线程池杀死并回收线程。ipmi任务执行后期,会逐渐出现线程空闲,线程池杀死并回收线程,造成线程池线程数量减少,后续有任务追加时,按线程池线程数量=(线程io响应时间/线程cpu时间+1)
×
cpu数量补足线程。
61.s3,利用线程资源构建协程池,根据分配的ipmi任务创建设定数量协程并放入协程池实现ipmi任务的分配;在分配ipmi任务过程中,为相应的协程初始优选级,初始优先级继承所述重要程度属性,并配置协程的状态为可运行。根据ipmi任务的分配情况计算每个线程的重要程度属性的平均值,即用每个线程中ipmi任务总的中场程度属性除以总ipmi任务数量。在cpu执行完一个线程后,比较线程池中线程重要程度属性的平均值的大小,取重要程度平均值最大的作为cpu下一执行的线程,其中空闲线程重要程度属性值指定为0。
62.s4,通过调度器根据协程优先级和状态调度协程执行ipmi任务,协程完成ipmi任务后协程池回收和销毁该协程。
63.具体实施过程中,协程状态包括运行中、阻塞、等待以及可运行,其中,运行中为协程使用cpu资源执行ipmi任务;当运行中的协程因io延迟以及异步等待导致停滞时,协程需等待条件满足才能执行,此时协程处于阻塞;协程阻塞时,协程主动放弃cpu占用,返回协程池,协程进入等待;当等待的协程条件满足可继续运行时,协程记进入可运行;另外刚进入协程池的协程其状态同样为可运行。
64.协程的初始优先级继承所述重要程度属性。随着协程运行,状态转变过程中,每次协程陷入阻塞时,更新优先级,使优先级数值在现有基础上加一。
65.当cpu中运行中的协程发生阻塞时,向调度器发送协程阻塞通知,所述调度器接收到阻塞通知后确定该cpu发生协程阻塞,所述调度器比较协程池中处于可运行状态协程的优先级值;调度器调取优先级值最大的可运行的协程到该cpu执行ipmi任务。
66.本技术的调度器属于用户层面,其调度过程完全由用户层控制,与采用线程并发的方式对比,无需内核参与调度过程,无需cpu进行内核态与用户态的切换,因此本技术采用协程切换实现并发能节约大量的时间,提高ipmi任务执行效率。调度器调取优先级值最大的可运行的协程执行ipmi任务。一方面初始优先级继承重要程度属性,重要的任务可以被优先执行,另一方面,协程被阻塞次数增多会增加优先级,阻塞次数多说明与服务器通信次数多,则协程占用资源更多,优先处理这种通信次数多占用资源多的协程能够尽快执行完占用资源多的协程,避免协程切换过程中持续占用更多的资源。
67.协程完成ipmi任务后协程池回收和销毁该协程。当协程池中的协程全部完成ipmi任务后协程池回收全部的资源,线程空闲。
68.s5,线程完成后进入空闲,cpu切换下一个线程执行,空闲线程的协程池放入根据ipmi任务创建的新的协程,等待cpu来执行,直至全部ipmi任务执行完。
69.由于本技术通过协程实现并发,并发过程无需线程参与,因此线程的切换仅仅是cpu执行完线程才发生切换,相比现有线程执行ipmi任务时发生阻塞切换线程,可以大大减少线程切换次数。本技术通过线程池的配置实现ipmi任务分配和执行的异步,保证线程执行过程中cpu不会闲置,从而能够充分利用cpu的计算资源。
70.具体实施过程中,一种可行的cpu选择下一个线程方式为:
71.统计线程池中全部线程所分配的全部ipmi任务的重要程度参数的平均值;
72.比较线程池中线程的重要程度参数平均值的大小;
73.确定重要程度参数平均值最大的线程为cpu执行的下一个线程。
74.从而实现一个线程ipmi任务的重要程度参数平均值越高,则控制cpu越先执行该线程。通过优先执行重要程度参数平均值高的线程可以优先执行相对重要的ipmi任务。
75.s6,实时监听各个ipmi任务的返回值,并将返回值整理为json格式,返回给用户。
76.实施例2
77.参阅图2所示,实施例2提供另一种应用在数据中心服务器与采集端的ipmi服务执行的方法:
78.用户在采集端配置需要带外执行的命令来构建ipmi任务,ipmi任务配置重要程度参数属性;
79.根据重要程度参数属性排序ipmi任务形成ipmi任务队列;
80.根据采集端负载来自适应配置线程池一定数量的线程;
81.利用线程资源构建协程池,根据ipmi任务队列中ipmi任务排序依次创建设定数量的协程并放入协程池;
82.通过调度器根据协程优先级和状态调度协程执行ipmi任务;
83.线程完成后进入空闲,cpu切换下一个线程执行,给空闲线程分配ipmi任务,直至将全部ipmi任务执行完;
84.实时监听各个ipmi任务的返回值,整理为json格式,返回给用户。
85.与实施例1相比区别在于,实施例2增加构建ipmi任务队列的过程。具体的,根据实施例1中ipmi任务的重要程度参数由大到小对ipmi任务进行排序。根据排列顺序构建一个ipmi任务队列,在分配任务时,依照ipmi任务队列中ipmi任务的排序将ipmi任务分配给线程。
86.实施例2先将ipmi任务根据重要程度参数排序,再按排列先后分配给线程,ipmi任务队列、线程选择与调度器配合确保重要的ipmi任务优先执行。
87.实施例3
88.参阅图3所示,本技术提供第一种实现ipmi服务执行方法的装置,包括连接模块,连接模块用于根据服务器ip地址、用户名、密码连接服务器;
89.任务配置模块,任务配置模块用于根据用户本地输入的带外执行命令构建ipmi任务;
90.线程池创建模块,线程池创建模块用于创建线程池,并给自适应给线程池配置一定数量的线程;
91.任务分配模块,任务分配模块用于根据ipmi任务创建协程分配到线程的协程池;
92.执行模块,执行模块用于执行协程池中的协程完成相应的ipmi任务;
93.第一调度模块,第一调度模块用于在执行模块执行协程阻塞时调度协程切换;
94.第二调度模块,第二调度模块用于执行模块执行完线程后调度切换线程;
95.数据处理模块,数据处理模块监听ipmi任务返回值并整理为json格式返回给用户。
96.实施例4
97.参阅图4所示,本技术实施例提供第二种实现ipmi服务执行方法的装置,实施例4与实施例3区别在于,实施例4的连接模块既连接服务器又连接客户端;实施例4的任务配置
模块,任务配置模块用于根据用户本地输入的带外执行命令或从客户端输入的带外执行命令构建ipmi任务;实施例4的数据处理模块将json格式的数据返回给客户端。通过实施例4一种实现ipmi服务执行方法的装置,实现客户端对数据中心服务器进行ipmi数据采集。客户端可以设置在异地,可以应用在异地分工。
98.实施例5
99.参阅图5所示,本技术实施例提供第三种实现ipmi服务执行方法的装置,实施例5与实施例4相比区别在于,配置账户认证授权模块,所述账户认证授权模块用于配置注册账号信息,在账号信息与数据中心之间建立映射关系,并根据客户端登录的账号控制客户端访问相应的数据中心。实施例5实现客户端对数据中心服务器进行ipmi数据采集的基础上,根据客户端登录的账号来确定客户端的访问权限,限制不同用户访问不同的数据中心。
100.实施例6
101.本技术实施例提供一种用于ipmi服务执行的存储介质,所述存储介质存储至少一条指令,执行所述指令实现实施例1或实施例2的ipmi服务执行方法。
102.本技术根据协程阻塞的次数更新协程的优先级,并利用优先级以及协程的状态来在发生协程阻塞时有效的调度协程到cpu运行。完全通过用户态调度器进行调度,无需系统在用户态和内核态之间来回切换,调度时间更快,使得执行ipmi任务的效率提高。
103.本技术利用线程资源构建协程池,协程池配置协程来处理ipmi任务,由于协程对于cpu来说是不可见的,协程的切换无需cpu从用户态切换到内核态在切换到用户态,协程的切换速度更快。协程阻塞切换协程,使得线程不会阻塞持续运行。本技术仅仅在cpu执行完线程后按顺序执行下一个线程才进行线程切换,直至执行完全部配置的ipmi任务,相比现有通过线程来执行ipmi指令在发生线程阻塞后即切换线程的方式,利用更快地协程切换取代线程切换,大大减少线程之间来回切换次数,从而节约了时间,使得处理ipmi任务更快,效率更高。
104.本技术通过配置需要带外执行的命令来构建ipmi任务,并根据ipmi任务构建协程,从而突破现有ipmitool工具单点服务的限制,能够应用在多服务器节点。
105.本技术构建线程池提供线程由cpu选择执行,空闲线程分配ipmi任务,实现ipmi任务分配与执行的异步,通过线程池保证cpu资源的充分利用。而且cpu根据线程中重要程度参数的平均值选取执行的线程,可以优先处理重要ipmi任务相对多的线程。
106.在本发明所提供的实施例中,应该理解到,所揭露的装置和方法,可以通过其它的方式实现。例如,以上所描述的装置实施例仅仅是示意性的,例如,所述单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,例如多个单元或组件可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通信连接可以是通过一些接口,装置或单元的间接耦合或通信连接,可以是电性,机械或其它的形式。
107.所述作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部单元来实现本实施例方案的目的。
108.另外,在本发明各个实施例中的各功能单元可以集成在一个处理单元中,也可以
是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中。上述集成的单元既可以采用硬件的形式实现,也可以采用软件功能单元的形式实现。
109.所述集成的单元如果以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分或者该技术方案的全部或部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质中,包括若干指令用以使得一台计算机设备(可以是个人计算机,服务器,或者网络设备等)执行本发明各个实施例所述方法的全部或部分步骤。而前述的存储介质包括:u盘、移动硬盘、只读存储器(read

only memory,rom)、随机存取存储器(random access memory,ram)、磁碟或者光盘等各种可以存储程序代码的介质。
110.以上所述仅是本发明的具体实施方式,使本领域技术人员能够理解或实现本发明。对这些实施例的多种修改对本领域的技术人员来说将是显而易见的,本文中所定义的一般原理可以在不脱离本发明的精神或范围的情况下,在其它实施例中实现。因此,本发明将不会被限制于本文所示的这些实施例,而是要符合与本文所申请的原理和新颖特点相一致的最宽的范围。
当前第1页1 2 
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1