CN117061486A - 回收虚拟机ip地址的方法、装置、计算机设备及介质 - Google Patents

回收虚拟机ip地址的方法、装置、计算机设备及介质 Download PDF

Info

Publication number
CN117061486A
CN117061486A CN202311160576.XA CN202311160576A CN117061486A CN 117061486 A CN117061486 A CN 117061486A CN 202311160576 A CN202311160576 A CN 202311160576A CN 117061486 A CN117061486 A CN 117061486A
Authority
CN
China
Prior art keywords
address
virtual machine
control instruction
configuration protocol
host configuration
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
CN202311160576.XA
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.)
Suzhou Inspur Intelligent Technology Co Ltd
Original Assignee
Suzhou Inspur Intelligent 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 Suzhou Inspur Intelligent Technology Co Ltd filed Critical Suzhou Inspur Intelligent Technology Co Ltd
Priority to CN202311160576.XA priority Critical patent/CN117061486A/zh
Publication of CN117061486A publication Critical patent/CN117061486A/zh
Pending legal-status Critical Current

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L61/00Network arrangements, protocols or services for addressing or naming
    • H04L61/50Address allocation
    • H04L61/5053Lease time; Renewal aspects
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L61/00Network arrangements, protocols or services for addressing or naming
    • H04L61/50Address allocation
    • H04L61/5007Internet protocol [IP] addresses
    • H04L61/5014Internet protocol [IP] addresses using dynamic host configuration protocol [DHCP] or bootstrap protocol [BOOTP]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L61/00Network arrangements, protocols or services for addressing or naming
    • H04L61/50Address allocation
    • H04L61/5061Pools of addresses
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L69/00Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
    • H04L69/22Parsing or analysis of headers
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L2101/00Indexing scheme associated with group H04L61/00
    • H04L2101/60Types of network addresses
    • H04L2101/618Details of network addresses
    • H04L2101/622Layer-2 addresses, e.g. medium access control [MAC] addresses

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Computer Security & Cryptography (AREA)
  • Small-Scale Networks (AREA)

Abstract

本发明涉及计算机技术领域,公开了回收虚拟机IP地址的方法、装置、计算机设备及介质,该方法包括:获取数据处理单元发送的第一虚拟机的第一IP地址、MAC地址以及动态主机配置协议服务器的第二IP地址;根据MAC地址,确定第一虚拟机的第一标识信息;向集群中的节点发送第一控制指令;当接收到任一节点反馈的与第一虚拟机对应的消失事件时,设置监测等待时间;当经过监测等待时间后没有收到任意节点反馈的与第一虚拟机对应的生成事件时,则确定第一虚拟机全局下线;向数据处理单元发送第二控制指令。通过该方式,可以及时回收第一虚拟机的IP地址,保证后续新的虚拟机上线后可以在DHCP地址池中获取到可用的IP地址。

Description

回收虚拟机IP地址的方法、装置、计算机设备及介质
技术领域
本发明涉及计算机技术领域,具体涉及回收虚拟机IP地址的方法、装置、计算机设备及介质。
背景技术
在云计算领域,虚拟机的IP地址从动态主机配置协议(Dynamic HostConfiguration Protocol,简称DHCP)服务器获取,如果这个IP地址租约不到期,就算该虚拟机关机或被删除,DHCP服务器也不会把该IP实时再次分配给其他虚拟机,导致大量IP被占用。而且,被占用的IP地址将不能被新的虚拟机所获取到,这就可能造成新的虚拟机因为DHCP地址池中的所有IP已经被占用,而无法获取到可用的IP地址。
发明内容
有鉴于此,本发明提供了一种回收虚拟机IP地址的方法、装置、计算机设备及介质,以解决新的虚拟机因为DHCP地址池中的所有IP已经被占用,而无法获取到可用的IP地址的问题。
第一方面,本发明提供了一种回收虚拟机IP地址的方法,该方法由云平台执行,该方法包括:
获取数据处理单元发送的第一虚拟机的第一IP地址、MAC地址以及动态主机配置协议服务器的第二IP地址,其中,第一虚拟机为云平台对应的集群中节点配置的任一个虚拟机;
根据MAC地址,确定第一虚拟机的第一标识信息;
向集群中的节点发送第一控制指令,其中,第一控制指令中携带第一标识信息,第一控制指令用以指示集群中的节点根据第一标识信息,为第一虚拟机创建消失事件和生成事件;
当接收到任一节点反馈的与第一虚拟机对应的消失事件时,设置监测等待时间;
当经过监测等待时间后没有收到任意节点反馈的与第一虚拟机对应的生成事件时,则确定第一虚拟机全局下线;
向数据处理单元发送第二控制指令,其中,第二控制指令携带第一IP地址、MAC地址,以及第二IP地址,以便数据处理单元根据第一IP地址、MAC地址,以及第二IP地址,指示动态主机配置协议服务器回收第一IP地址。
本发明提供的一种回收虚拟机IP地址的方法,具有如下优点:
获取数据处理单元发送的第一IP地址、MAC地址,以及第二IP地址。根据MAC地址获取第一虚拟机的第一标识信息。然后向集群中的节点发送控制指令,该控制指令中携带第一标识信息,且该控制指令用以指示集群中的各节点分别为第一虚拟机创建消失事件和生成事件。当接收到任一节点反馈的与第一虚拟机对应的消失事件时,只能确定第一虚拟机已经在该节点下线。但是不能确定第一虚拟机全局下线。因此,需要设置一个监测等待时间。如果在监测等待时间段内,没有其他节点反馈的与第一虚拟机对应的生成事件,在说明确实第一虚拟机已经全局下线,那么就可以向数据处理单元发送第二控制指令,并在第二控制指令中携带第一IP地址、MAC地址,以及第二IP地址,以便数据处理单元根据第一IP地址、MAC地址,以及第二IP地址,指示动态主机配置协议服务器回收第一IP地址,用以保证后续新的虚拟机上线后可以在DHCP地址池中获取到可用的IP地址。
在一种可选的实施方式中,获取数据处理单元发送的第一虚拟机的第一IP地址、MAC地址以及动态主机配置协议服务器的第二IP地址之后,该方法还包括:
将第一虚拟机的第一标识信息加入到虚拟机监测队列。
具体的,将第一标识信息加入到虚拟机监测队列中,是方便后续对第一虚拟机进行有效监控。
在一种可选的实施方式中,该方法还包括:
当接收到任一节点反馈的与第二虚拟机对应的生成事件时,从与第二虚拟机对应的生成事件中提取第二虚拟机的第二标识信息;
将第二标识信息与虚拟机监测队列中存储的标识信息进行匹配;
当未匹配成功时,将第二虚拟机对应的生成事件删除。
具体的,当接收到任一节点反馈的与第二虚拟机对应的生成事件时,获取第二虚拟机的第二标识信息。并将第二标识信息与虚拟机监测队列中的标识信息进行匹配,如果匹配成功,则说明第二虚拟机已经在其他节点上生效,并非是全局下线。或者,当未匹配成功时,则说明第二虚拟机对应的生成事件并非是云平台所要监控的虚拟机的生成事件,则无需做任何处理,直接删除第二虚拟机对应的生成事件。
第二方面,本发明提供了一种回收虚拟机IP地址的方法,该方法由数据处理单元中配置的监听应用程序执行,该方法包括:
接收云平台下发的流表匹配规则,流表匹配规则用于匹配符合预设条件的动态主机配置协议响应报文;
向智能网卡加速引擎发送流表匹配规则;
当获取到智能网卡加速引擎发送的动态主机配置协议响应报文时,对动态主机配置协议响应报文进行解析,获取并保存第一虚拟机的第一IP地址、MAC地址,以及动态主机配置协议服务器的第二IP地址;
监测第一虚拟机在预设时间段内是否发出指示第一IP地址冲突的报文;
当监听应用程序在预设时间段内未监测到指示第一IP地址冲突的报文时,向云平台发送第一IP地址、MAC地址,以及第二IP地址;
当接收到云平台发送的控制指令,且控制指令中包括第一IP地址、MAC地址,以及第二IP地址时,根据第一IP地址、MAC地址,以及第二IP地址,生成动态主机配置协议服务器的释放报文;
将释放报文发送至目标动态主机配置协议服务器,以便目标动态主机配置协议服务器回收第一IP地址。
本发明提供的一种回收虚拟机IP地址的方法,具有如下优点:
向智能网卡加速引擎发送流表匹配规则,其中流表匹配规则用于匹配符合预设条件的动态主机配置协议响应报文。当获取到智能网卡加速引擎发送的动态主机配置协议响应报文时,对动态主机配置协议响应报文进行解析,获取并保存第一IP地址、MAC地址以及第二IP地址。检测第一虚拟机在预设时间段内是否发出指示第一IP地址冲突的报文,如果没有收到该类报文,则说明IP地址没有冲突,可以将第一IP地址、MAC地址,以及第二IP地址等通过消息通道发送至云平台,以便云平台对第一虚拟机进行监管。在接收到云平台发送的控制指令后,则根据控制指令中携带的第一IP地址、MAC地址,以及第二IP地址,生成动态主机配置协议服务器的释放报文并发送至动态主机配置协议服务器,以便动态主机配置协议服务器回收第一IP地址。
在一种可选的实施方式中,预设条件为动态主机配置协议响应报文中携带有第一IP地址、MAC地址,以及第二IP地址,且第一IP地址的字段值、MAC地址的字段值,以及第二IP地址的字段值均非空。
在一种可选的实施方式中,在预设时间段内监测到指示第一IP地址冲突的报文时,清除已保存的第一IP地址、MAC地址,以及第二IP地址。
具体的,当在预设时间段内监测到指示第一IP地址冲突的报文时,则说明第一IP地址已经被其他虚拟机占用,因此需要清除已保存的第一IP地址。
第三方面,本发明提供了一种回收虚拟机IP地址的方法,该方法由集群中的节点执行,该方法包括:
获取云平台发送的控制指令;
根据控制指令,为第一虚拟机创建消失事件和生成事件;
监测第一虚拟机的运行状态,运行状态用以确定第一虚拟机的消失事件是否生效,或确定第一虚拟机的生成事件是否生效;
将运行状态发送至云平台。
本发明提供的一种回收虚拟机IP地址的方法,具有如下优点:
获取云平台发送的控制指令,根据控制指令为第一虚拟机创建消失事件和生成事件。并且监测第一虚拟机的运行状态,其中,运行状态可以包括第一虚拟机的消失事件生效,或者第一虚拟机的生成事件生效。不管是哪一种运行状态,都需要发送至云平台。用以方便云平台根据第一虚拟机的运行状态来确定第一虚拟机何时全局下线,进而告知数据处理单元回收第一虚拟机的IP地址。
第四方面,本发明提供了一种回收虚拟机IP地址的装置,该装置包括:
获取模块,用于获取数据处理单元发送的第一虚拟机的第一IP地址、MAC地址以及动态主机配置协议服务器的第二IP地址,其中,第一虚拟机为云平台对应的集群中节点配置的任一个虚拟机;
确定模块,用于根据MAC地址,确定第一虚拟机的第一标识信息;
发送模块,用于向集群中的节点发送第一控制指令,其中,第一控制指令中携带第一标识信息,第一控制指令用以指示集群中的节点根据第一标识信息,为第一虚拟机创建消失事件和生成事件;
接收模块,用于接收任一节点反馈的与第一虚拟机对应的消失事件;
处理模块,用于当接收模块接收到任一节点反馈的与第一虚拟机对应的消失事件时,设置监测等待时间;且当经过监测等待时间后没有收到任意节点反馈的与第一虚拟机对应的生成事件时,则确定第一虚拟机全局下线;
发送模块,还用于向数据处理单元发送第二控制指令,其中,第二控制指令携带第一IP地址、MAC地址,以及第二IP地址,以便数据处理单元根据第一IP地址、MAC地址,以及第二IP地址,指示动态主机配置协议服务器回收第一IP地址。
本发明提供的一种回收虚拟机IP地址的装置,具有如下优点:
获取数据处理单元发送的第一IP地址、MAC地址,以及第二IP地址。根据MAC地址获取第一虚拟机的第一标识信息。然后向集群中的节点发送控制指令,该控制指令中携带第一标识信息,且该控制指令用以指示集群中的各节点分别为第一虚拟机创建消失事件和生成事件。当接收到任一节点反馈的与第一虚拟机对应的消失事件时,只能确定第一虚拟机已经在该节点下线。但是不能确定第一虚拟机全局下线。因此,需要设置一个监测等待时间。如果在监测等待时间段内,没有其他节点反馈的与第一虚拟机对应的生成事件,在说明确实第一虚拟机已经全局下线,那么就可以向数据处理单元发送第二控制指令,并在第二控制指令中携带第一IP地址、MAC地址,以及第二IP地址,以便数据处理单元根据第一IP地址、MAC地址,以及第二IP地址,指示动态主机配置协议服务器回收第一IP地址,用以保证后续新的虚拟机上线后可以在DHCP地址池中获取到可用的IP地址。
第五方面,本发明提供了一种回收虚拟机IP地址的装置,该装置包括:
接收模块,用于接收云平台下发的流表匹配规则,流表匹配规则用于匹配符合预设条件的动态主机配置协议响应报文;
发送模块,用于向智能网卡加速引擎发送流表匹配规则;
获取模块,用于获取智能网卡加速引擎发送的动态主机配置协议响应报文;
解析模块,用于对动态主机配置协议响应报文进行解析,获取并保存第一虚拟机的第一IP地址、MAC地址,以及动态主机配置协议服务器的第二IP地址;
监测模块,用于监测第一虚拟机在预设时间段内是否发出指示第一IP地址冲突的报文;
发送模块,还用于当监听应用程序在预设时间段内未监测到指示第一IP地址冲突的报文时,向云平台发送第一IP地址、MAC地址,以及第二IP地址;
接收模块,还用于接收云平台发送的控制指令;
处理模块,用于当确定控制指令中包括第一IP地址、MAC地址,以及第二IP地址时,根据第一IP地址、MAC地址,以及第二IP地址,生成动态主机配置协议服务器的释放报文;
发送模块,还用于将释放报文发送至目标动态主机配置协议服务器,以便目标动态主机配置协议服务器回收第一IP地址。
本发明提供的一种回收虚拟机IP地址的装置,具有如下优点:
向智能网卡加速引擎发送流表匹配规则,其中流表匹配规则用于匹配符合预设条件的动态主机配置协议响应报文。当获取到智能网卡加速引擎发送的动态主机配置协议响应报文时,对动态主机配置协议响应报文进行解析,获取并保存第一IP地址、MAC地址以及第二IP地址。检测第一虚拟机在预设时间段内是否发出指示第一IP地址冲突的报文,如果没有收到该类报文,则说明IP地址没有冲突,可以将第一IP地址、MAC地址,以及第二IP地址等通过消息通道发送至云平台,以便云平台对第一虚拟机进行监管。在接收到云平台发送的控制指令后,则根据控制指令中携带的第一IP地址、MAC地址,以及第二IP地址,生成动态主机配置协议服务器的释放报文并发送至动态主机配置协议服务器,以便动态主机配置协议服务器回收第一IP地址。
第六方面,本发明提供了一种回收虚拟机IP地址的装置,该装置包括:
获取模块,用于获取云平台发送的控制指令;
创建模块,用于根据控制指令,为第一虚拟机创建消失事件和生成事件;
监测模块,用于监测第一虚拟机的运行状态,运行状态用以确定第一虚拟机的消失事件是否生效,或确定第一虚拟机的生成事件是否生效;
发送模块,用于将运行状态发送至云平台。
本发明提供的一种回收虚拟机IP地址的装置,具有如下优点:
获取云平台发送的控制指令,根据控制指令为第一虚拟机创建消失事件和生成事件。并且监测第一虚拟机的运行状态,其中,运行状态可以包括第一虚拟机的消失事件生效,或者第一虚拟机的生成事件生效。不管是哪一种运行状态,都需要发送至云平台。用以方便云平台根据第一虚拟机的运行状态来确定第一虚拟机何时全局下线,进而告知数据处理单元回收第一虚拟机的IP地址。
第七方面,本发明提供了一种计算机设备,包括:存储器和处理器,存储器和处理器之间互相通信连接,存储器中存储有计算机指令,处理器通过执行计算机指令,从而执行上述第一方面或其对应的任一实施方式的回收虚拟机IP地址的方法。
第八方面,本发明提供了一种计算机设备,包括:存储器和处理器,存储器和处理器之间互相通信连接,存储器中存储有计算机指令,处理器通过执行计算机指令,从而执行上述第二方面或其对应的任一实施方式的回收虚拟机IP地址的方法;或者,处理器通过执行计算机指令,从而执行上述第三方面或其对应的任一实施方式的回收虚拟机IP地址的方法。
第九方面,本发明提供了一种计算机可读存储介质,该计算机可读存储介质上存储有计算机指令,计算机指令用于使云平台执行上述第一方面或其对应的任一实施方式的回收虚拟机IP地址的方法。
第十方面,本发明提供了一种计算机可读存储介质,该计算机可读存储介质上存储有计算机指令,计算机指令用于使计算机设备执行上述第二方面或其对应的任一实施方式的回收虚拟机IP地址的方法;或者,计算机指令用于使计算机设备执行上述第三方面或其对应的任一实施方式的回收虚拟机IP地址的方法。
附图说明
为了更清楚地说明本发明具体实施方式或现有技术中的技术方案,下面将对具体实施方式或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图是本发明的一些实施方式,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1是本发明提供的云计算数据应用场景中各执行主体之间的简易位置关系结构示意图;
图2是本发明实施例提供的一种回收虚拟机IP地址的方法的流程示意图;
图3是本发明实施例提供的另一种回收虚拟机IP地址的方法的流程示意图;
图4是本发明实施例提供的又一种回收虚拟机IP地址的方法的流程示意图;
图5是本发明实施例提供的一种回收虚拟机IP地址的装置结构框图;
图6是本发明实施例提供的另一种回收虚拟机IP地址的装置结构框图;
图7是本发明实施例提供的又一种回收虚拟机IP地址的装置结构框图;
图8是本发明实施例的云平台的硬件结构示意图;
图9是本发明实施例的计算机设备的硬件结构示意图。
具体实施方式
为使本发明实施例的目的、技术方案和优点更加清楚,下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
在云计算领域,虚拟机的IP地址从DHCP服务器获取,如果这个IP地址租约不到期,就算该虚拟机关机或被删除,DHCP服务器也不会把该IP实时再次分配给其他虚拟机,这就造成了大量IP被占用,新的虚拟机有可能因为DHCP地址池被耗尽而无法获取IP地址。
为解决上述问题,本发明实施例,提供了一种回收虚拟机IP地址的实施例,该方法步骤适用于一种基于云平台和集群中节点进行交互的云计算数据应用场景中。在该应用场景中包括的交互执行主体包括云平台和集群中的节点以及DHCP服务器。集群中的计算节点中配置有数据处理单元(Data Processing Unit,简称DPU)、虚拟机、OVS(openvswitch)虚拟交换机,该DPU中带有嵌入式CPU的智能网卡。智能网卡中部署有监听应用程序,监听应用程序布置于OVS虚拟交换机一侧。具体参见图1所示,图1中示意出该应用场景中各执行主体之间的简易位置关系示意图。
具体的交互过程参见如下:
步骤1、云平台下发流表匹配规则至计算节点;
步骤2、计算节点的数据处理单元中配置的监听应用程序接收云平台下发的流表匹配规则;
步骤3、监听应用程序通过TC FLOWER接口或者DPDK RTE接口直接将这些规则下发到智能网卡硬件加速引擎。
步骤4、智能网卡硬件加速引擎,对符合预设条件的动态主机配置协议响应(DHCPACK)报文进行监视。
在一个可选的实施方式中,预设条件为动态主机配置协议响应报文中携带有动态主机配置协议服务器的IP地址、虚拟机的IP地址,以及虚拟机的MAC地址,且动态主机配置协议服务器的IP地址的字段值、虚拟机的IP地址的字段值,以及虚拟机的MAC地址值均非空。
步骤5、当智能网卡硬件加速引擎确定存在符合预设条件的DHCP ACK报文时,则将符合预设条件的DHCP ACK报文镜像复制一份给监听应用程序。
而原始报文无任何内容改变,继续按原网络路径进行发送。
步骤6、监听应用层序对符合预设条件的DHCP ACK报文进行解析,提取报文中client IP地址,也即是虚拟机IP地址、DHCP服务器的IP地址,以及client MAC地址(即虚拟机MAC地址)。
步骤7、监听应用程序将虚拟机的IP地址、DHCP服务器的IP地址,以及虚拟机的MAC地址保存至本地。
步骤8、监听应用程序启动虚拟机IP有效性检测线程,监测该虚拟机在预设时间段内是否发出指示虚拟机的IP地址冲突的报文。
在一个可选的例子中,监测的是虚拟机发出的DHCP Decline报文。因为只有虚拟机的IP地址冲突的情况下,虚拟机才会向DHCP服务器发送DHCP Decline报文。
在一个可选的实施方式中,除了可以采用上述方式确定IP地址是否冲突外,还可以通过如下中的一种或多种方式确定IP地址是否冲突。例如,向待检测的IP地址发送ICMP请求。如果接收到ICMP响应,则表示IP地址存在冲突。或者,查看是否有多个设备请求同一IP地址。又或者,对局域网进行扫描,并查找是否有多个设备使用了同一IP地址等方式,具体实现方式这里不做任何限定。
步骤9、当监听应用程序在预设时间段内未监测到指示虚拟机的IP地址冲突的报文时,通过消息通道向云平台发送该虚拟机的IP地址、MAC地址,以及DHCP服务器的IP地址。
若在预设时间段内监测到指示虚拟机的IP地址冲突的报文时,监听应用程序将会清空本地保存的与虚拟机对应的相关数据,例如包括虚拟机的IP地址、DHCP服务器的IP地址,以及MAC地址等。
步骤10、云平台接收到数据处理单元中的监听应用程序通过消息通道传输的虚拟机的IP地址、MAC地址,以及DHCP服务器的IP地址。
步骤11、云平台根据MAC地址获取该虚拟机的标识信息,然后向集群中的节点发送控制指令。
其中,控制指令中携带虚拟机的标识信息,该控制指令用以指示集群中的各节点分别根据标识信息,为该虚拟机创建消失事件和生成事件;
可选的,云平台还会将虚拟机的标识信息加入到虚拟机监测队列中,用以后续云平台对虚拟机是否在线进行监控。
步骤12、集群中的任一个节点在接收到云平台发送的控制指令后,都将为该虚拟机注册两个事件。
其中,一个是生成事件,一个是消失事件。
具体而言,执行该操作的是计算节点中的Libvirt服务。其为虚拟机注册上述两个事件,实际是为虚拟机对应的qemu进程注册上述两个事件。其中,Qemu是纯软件实现的虚拟化模拟器,几乎可以模拟任何硬件设备,我们最熟悉的就是能够模拟一台能够独立运行操作系统的虚拟机,虚拟机认为自己和硬件打交道,但其实是和Qemu模拟出来的硬件打交道,Qemu将这些指令转译给真正的硬件。
步骤13、节点监测第一虚拟机的运行状态,运行状态用以确定虚拟机的消失事件是否生效,或确定虚拟机的生成事件是否生效。
具体的,当虚拟机qemu进程消失时Libvirt服务立即捕获此消失事件;亦或是,当虚拟机qemu进程出现时,计算节点的Libvirt服务立即捕获此生成事件。
步骤14、节点将运行状态发送至云平台。
步骤15、云平台在接收到任一节点反馈的与前述虚拟机对应的消失事件时,设置监测等待时间。
步骤16、当经过监测等待时间后没有收到任意节点反馈的与前述虚拟机对应的生成事件时,则确定该虚拟机全局下线。
步骤17、向数据处理单元发送控制指令,控制指令携带虚拟机的IP地址、MAC地址,以及DHCP服务器的IP地址。
步骤18、数据处理单元根据以该虚拟机的IP作为源IP去构造DHCP Release报文,发送该报文至DHCP服务器,用以通告DHCP服务器回收该虚拟机的IP地址,完成及时回收虚拟机占用的IP地址的目的,其中,在该报文中携带虚拟机的IP地址、MAC地址,以及DHCP服务器的IP地址。
步骤19、DHCP服务器根据DHCP Release报文,回收虚拟机的IP地址。
可选的,在步骤14之后,若云平台接收到的是任一节点反馈的与任一虚拟机对应的生成事件时,在还包括步骤20、云平台获取该虚拟机的标识信息。
步骤21、云平台将该虚拟机的标识信息与虚拟机监测队列中存储的标识信息进行匹配。
步骤22、当未匹配成功时,将该虚拟机对应的生成事件删除。
具体的,当虚拟机qemu进程消失时,Libvirt服务立即将此虚拟机的消失事件D1上报给云平台,由云平台在集群范围内全局监测该虚拟机是否在其他计算节点出现,此处设置一个监测等待时间T。当虚拟机qemu进程生成时,Libvirt服务立即将此虚拟机的生成事件B1上报给云平台,如果该虚拟机不在云平台的VM状态监测队列,则丢弃该生成事件B1。如果该虚拟机在云平台的VM状态监测队列,并且生成事件B1在监测等待时间T内,则云平台认为虚拟机仅仅做了热迁移或者HA,虚拟机未全局下线;如果监测等待时间T超时,云平台仍未收到该虚拟机的生成事件B1,则认为该虚拟机在此集群里是全局下线的,需要回收该虚拟机的DHCP地址。云平台通过综合判断后,如果认为在集群范围内该虚拟机下线,则通知数据处理单元中配置的监听应用程序该虚拟机已全局下线。
监听应用程序接收到云平台发出的控制指令后,确定虚拟机全局下线,监听应用程序将以该虚拟机的IP作为源IP去构造DHCP Release报文,发送该报文至DHCP服务器,通告DHCP服务器回收该虚拟机的IP地址,完成及时回收虚拟机占用的IP地址的目的。
以上,为虚拟机的IP地址被回收的整个交互流程。
在本实施例中提供了一种回收虚拟机IP地址的方法,具体参见图2所示,图2是本发明实施例提供的一种回收虚拟机IP地址的方法的流程图,该方法由云平台执行,该方法流程包括如下步骤:
步骤S201,获取数据处理单元发送的第一虚拟机的第一IP地址、MAC地址以及动态主机配置协议服务器的第二IP地址。
其中,第一虚拟机为云平台对应的集群中节点配置的任一个虚拟机。
步骤S202,根据MAC地址,确定第一虚拟机的第一标识信息。
步骤S203,向集群中的节点发送第一控制指令。
其中,第一控制指令中携带第一标识信息。第一控制指令用以指示集群中的节点根据第一标识信息,为第一虚拟机创建消失事件和生成事件。
步骤S204,当接收到任一节点反馈的与第一虚拟机对应的消失事件时,设置监测等待时间。
步骤S205,当经过监测等待时间后没有收到任意节点反馈的与第一虚拟机对应的生成事件时,则确定第一虚拟机全局下线。
在一个可选的实施方式中,除了在接收到任一节点反馈的与第一虚拟机对应的消失事件时,设置监测等待时间。并确定监测等待时间段内没有收到任一节点反馈的第一虚拟机对应的生成事件来确定第一虚拟机是否全局下线以外,还可以通过其他方式确定第一虚拟机是否全局下线。
例如,云平台可以定期发送心跳消息给第一虚拟机,并等待第一虚拟机的回复。如果在一定时间内没有收到第一虚拟机的回复,则可以判定第一虚拟机全局下线。又或者,云平台可以监测第一虚拟机的网络连接状态,如果第一虚拟机在一定时间内没有建立或维持网络连接,则可以认为第一虚拟机全局下线。再者,云平台可以监测第一虚拟机的资源利用率,比如CPU、内存等。如果第一虚拟机的资源利用率在一段时间内持续较低或者为0,则可以认为第一虚拟机全局下线。
步骤S206,向数据处理单元发送第二控制指令。
其中,第二控制指令携带第一IP地址、MAC地址,以及第二IP地址,以便数据处理单元根据第一IP地址、MAC地址,以及第二IP地址,指示动态主机配置协议服务器回收第一IP地址。
本实施例中的具体实现过程均已在前文中做了详细描述,因此这里不再过多赘述。
本实施例提供的回收虚拟机IP地址的方法,获取数据处理单元发送的第一IP地址、MAC地址,以及第二IP地址。根据MAC地址获取第一虚拟机的第一标识信息。然后向集群中的节点发送控制指令,该控制指令中携带第一标识信息,且该控制指令用以指示集群中的各节点分别为第一虚拟机创建消失事件和生成事件。当接收到任一节点反馈的与第一虚拟机对应的消失事件时,只能确定第一虚拟机已经在该节点下线。但是不能确定第一虚拟机全局下线。因此,需要设置一个监测等待时间。如果在监测等待时间段内,没有其他节点反馈的与第一虚拟机对应的生成事件,在说明确实第一虚拟机已经全局下线,那么就可以向数据处理单元发送第二控制指令,并在第二控制指令中携带第一IP地址、MAC地址,以及第二IP地址,以便数据处理单元根据第一IP地址、MAC地址,以及第二IP地址,指示动态主机配置协议服务器回收第一IP地址,用以保证后续新的虚拟机上线后可以在DHCP地址池中获取到可用的IP地址。
在一个可选的实施方式中,获取数据处理单元发送的第一虚拟机的第一IP地址、MAC地址以及动态主机配置协议服务器的第二IP地址之后,该方法还包括:
将第一虚拟机的第一标识信息加入到虚拟机监测队列。
具体的,将第一标识信息加入到虚拟机监测队列中,是方便后续对第一虚拟机进行有效监控。
在一个可选的实施方式中,该方法还包括:
当接收到任一节点反馈的与第二虚拟机对应的生成事件时,从与第二虚拟机对应的生成事件中提取第二虚拟机的第二标识信息;
将第二标识信息与虚拟机监测队列中存储的标识信息进行匹配;
当未匹配成功时,将第二虚拟机对应的生成事件删除。
具体的,当接收到任一节点反馈的与第二虚拟机对应的生成事件时,获取第二虚拟机的第二标识信息。并将第二标识信息与虚拟机监测队列中的标识信息进行匹配,如果匹配成功,则说明第二虚拟机已经在其他节点上生效,并非是全局下线。或者,当未匹配成功时,则说明第二虚拟机对应的生成事件并非是云平台所要监控的虚拟机的生成事件,则无需做任何处理,直接删除第二虚拟机对应的生成事件。
本实施例中提供了一种回收虚拟机IP地址的方法,具体参见图3所示,图3是本发明实施例提供的另一种回收虚拟机IP地址的方法的流程图,该方法由前文中所介绍的数据处理单元中配置的监听应用程序执行,参见如图3所示,该流程包括如下步骤:
步骤S301,接收云平台下发的流表匹配规则。
其中,流表匹配规则用于匹配符合预设条件的动态主机配置协议响应报文。
步骤S302,向智能网卡加速引擎发送流表匹配规则。
步骤S303,当获取到智能网卡加速引擎发送的动态主机配置协议响应报文时,对动态主机配置协议响应报文进行解析,获取并保存第一虚拟机的第一IP地址、MAC地址,以及动态主机配置协议服务器的第二IP地址。
步骤S304,监测第一虚拟机在预设时间段内是否发出指示第一IP地址冲突的报文。
步骤S305,当监听应用程序在预设时间段内未监测到指示第一IP地址冲突的报文时,向云平台发送第一IP地址、MAC地址,以及第二IP地址。
步骤S306,当接收到云平台发送的控制指令,且控制指令中包括第一IP地址、MAC地址,以及第二IP地址时,根据第一IP地址、MAC地址,以及第二IP地址,生成动态主机配置协议服务器的释放报文。
步骤S307,将释放报文发送至目标动态主机配置协议服务器,以便目标动态主机配置协议服务器回收第一IP地址。
以上方法实施步骤的具体实现过程同样已经在前文中做了详细介绍,因此这里不再过多赘述。
本发明实施例提供的一种回收虚拟机IP地址的方法,向智能网卡加速引擎发送流表匹配规则,其中流表匹配规则用于匹配符合预设条件的动态主机配置协议响应报文。当获取到智能网卡加速引擎发送的动态主机配置协议响应报文时,对动态主机配置协议响应报文进行解析,获取并保存第一IP地址、MAC地址以及第二IP地址。检测第一虚拟机在预设时间段内是否发出指示第一IP地址冲突的报文,如果没有收到该类报文,则说明IP地址没有冲突,可以将第一IP地址、MAC地址,以及第二IP地址等通过消息通道发送至云平台,以便云平台对第一虚拟机进行监管。在接收到云平台发送的控制指令后,则根据控制指令中携带的第一IP地址、MAC地址,以及第二IP地址,生成动态主机配置协议服务器的释放报文并发送至动态主机配置协议服务器,以便动态主机配置协议服务器回收第一IP地址。
在一个可选的实施方式中,预设条件为动态主机配置协议响应报文中携带有第一IP地址、MAC地址,以及第二IP地址,且第一IP地址的字段值、MAC地址的字段值,以及第二IP地址的字段值均非空。
在一个可选的实施方式中,该方法还包括:
在预设时间段内监测到指示第一IP地址冲突的报文时,清除已保存的第一IP地址、MAC地址,以及第二IP地址。
具体的,当在预设时间段内监测到指示第一IP地址冲突的报文时,则说明第一IP地址已经被其他虚拟机占用,因此需要清除已保存的第一IP地址。
在本实施例中提供了又一种回收虚拟机IP地址的方法,该方法由节点执行,具体参见图4所示,该流程包括如下步骤:
步骤S401,获取云平台发送的控制指令。
其中,控制指令用以指示为第一虚拟机创建消失事件和生成事件。
步骤S402,根据控制指令,为第一虚拟机创建消失事件和生成事件。
步骤S403,监测第一虚拟机的运行状态,运行状态用以确定第一虚拟机的消失事件是否生效,或确定第一虚拟机的生成事件是否生效。
步骤S404,将运行状态发送至云平台。
以上方法实施步骤的具体实现过程同样已经在前文中做了详细介绍,因此这里不再过多赘述。
本发明实施例提供的一种回收虚拟机IP地址的方法,获取云平台发送的控制指令,根据控制指令为第一虚拟机创建消失事件和生成事件。并且监测第一虚拟机的运行状态,其中,运行状态可以包括第一虚拟机的消失事件生效,或者第一虚拟机的生成事件生效。不管是哪一种运行状态,都需要发送至云平台。用以方便云平台根据第一虚拟机的运行状态来确定第一虚拟机何时全局下线,进而告知数据处理单元回收第一虚拟机的IP地址。
在本实施例中还提供了一种回收虚拟机IP地址的装置,该装置用于实现上述图2所对应的实施例及优选实施方式,已经进行过说明的不再赘述。如以下所使用的,术语“模块”可以实现预定功能的软件和/或硬件的组合。尽管以下实施例所描述的装置较佳地以软件来实现,但是硬件,或者软件和硬件的组合的实现也是可能并被构想的。
本实施例提供一种回收虚拟机IP地址的装置,如图5示,包括:获取模块501、确定模块502、发送模块503、接收模块504以及处理模块505。
获取模块501,用于获取数据处理单元发送的第一虚拟机的第一IP地址、MAC地址以及动态主机配置协议服务器的第二IP地址,其中,第一虚拟机为云平台对应的集群中节点配置的任一个虚拟机;
确定模块502,用于根据MAC地址,确定第一虚拟机的第一标识信息;
发送模块503,用于向集群中的节点发送第一控制指令,其中,第一控制指令中携带第一标识信息,第一控制指令用以指示集群中的节点根据第一标识信息,为第一虚拟机创建消失事件和生成事件;
接收模块504,接收任一节点反馈的与第一虚拟机对应的消失事件;
处理模块505,用于当接收模块接收到任一节点反馈的与第一虚拟机对应的消失事件时,设置监测等待时间;且当经过监测等待时间后没有收到任意节点反馈的与第一虚拟机对应的生成事件时,则确定第一虚拟机全局下线;
发送模块503,还用于向数据处理单元发送第二控制指令,其中,第二控制指令携带第一IP地址、MAC地址,以及第二IP地址,以便数据处理单元根据第一IP地址、MAC地址,以及第二IP地址,指示动态主机配置协议服务器回收第一IP地址。
在一个可选的实施方式中,处理模块505,还用于将第一虚拟机的第一标识信息加入到虚拟机监测队列。
在一个可选的实施方式中,接收模块504,还用于接收任一节点反馈的与第二虚拟机对应的生成事件;
处理模块505,还用于从与第二虚拟机对应的生成事件中提取第二虚拟机的第二标识信息;将第二标识信息与虚拟机监测队列中存储的标识信息进行匹配;当未匹配成功时,将第二虚拟机对应的生成事件删除。
本实施例中的回收虚拟机IP地址的装置是以功能模块的形式来呈现,这里的模块是指专用集成电路(Application Specific Integrated Circuit,简称ASIC),执行一个或多个软件或固定程序的处理器和存储器,和/或其他可以提供上述功能的器件。
上述各个模块和单元的更进一步的功能描述与上述对应实施例相同,在此不再赘述。
本发明实施例提供的一种回收虚拟机IP地址的装置,获取数据处理单元发送的第一IP地址、MAC地址,以及第二IP地址。根据MAC地址获取第一虚拟机的第一标识信息。然后向集群中的节点发送控制指令,该控制指令中携带第一标识信息,且该控制指令用以指示集群中的各节点分别为第一虚拟机创建消失事件和生成事件。当接收到任一节点反馈的与第一虚拟机对应的消失事件时,只能确定第一虚拟机已经在该节点下线。但是不能确定第一虚拟机全局下线。因此,需要设置一个监测等待时间。如果在监测等待时间段内,没有其他节点反馈的与第一虚拟机对应的生成事件,在说明确实第一虚拟机已经全局下线,那么就可以向数据处理单元发送第二控制指令,并在第二控制指令中携带第一IP地址、MAC地址,以及第二IP地址,以便数据处理单元根据第一IP地址、MAC地址,以及第二IP地址,指示动态主机配置协议服务器回收第一IP地址,用以保证后续新的虚拟机上线后可以在DHCP地址池中获取到可用的IP地址。
本实施例提供一种回收虚拟机IP地址的装置,如图6示,包括:接收模块601、发送模块602、获取模块603、解析模块604、监测模块605,以及处理模块606。
接收模块601,用于接收云平台下发的流表匹配规则,流表匹配规则用于匹配符合预设条件的动态主机配置协议响应报文;
发送模块602,用于向智能网卡加速引擎发送流表匹配规则;
获取模块603,用于获取智能网卡加速引擎发送的动态主机配置协议响应报文;
解析模块604,用于对动态主机配置协议响应报文进行解析,获取并保存第一虚拟机的第一IP地址、MAC地址,以及动态主机配置协议服务器的第二IP地址;
监测模块605,用于监测第一虚拟机在预设时间段内是否发出指示第一IP地址冲突的报文;
发送模块602,还用于当监听应用程序在预设时间段内未监测到指示第一IP地址冲突的报文时,向云平台发送第一IP地址、MAC地址,以及第二IP地址;
接收模块601,还用于接收云平台发送的控制指令;
处理模块606,用于当确定控制指令中包括第一IP地址、MAC地址,以及第二IP地址时,根据第一IP地址、MAC地址,以及第二IP地址,生成动态主机配置协议服务器的释放报文;
发送模块602,还用于将释放报文发送至目标动态主机配置协议服务器,以便目标动态主机配置协议服务器回收第一IP地址。
在一个可选的实施方式中,预设条件为动态主机配置协议响应报文中携带有第一IP地址、MAC地址,以及第二IP地址,且第一IP地址的字段值、MAC地址的字段值,以及第二IP地址的字段值均非空。
在一个可选的实施方式中,装置还不包括清除模块607,用于监视模块605在预设时间段内监测到指示第一IP地址冲突的报文时,清除已保存的第一IP地址、MAC地址,以及第二IP地址。
本实施例中的回收虚拟机IP地址的装置是以功能模块的形式来呈现,这里的模块是指专用集成电路(Application Specific Integrated Circuit,简称ASIC),执行一个或多个软件或固定程序的处理器和存储器,和/或其他可以提供上述功能的器件。
上述各个模块和单元的更进一步的功能描述与上述对应实施例相同,在此不再赘述。
本发明实施例提供的一种回收虚拟机IP地址的装置,向智能网卡加速引擎发送流表匹配规则,其中流表匹配规则用于匹配符合预设条件的动态主机配置协议响应报文。当获取到智能网卡加速引擎发送的动态主机配置协议响应报文时,对动态主机配置协议响应报文进行解析,获取并保存第一IP地址、MAC地址以及第二IP地址。检测第一虚拟机在预设时间段内是否发出指示第一IP地址冲突的报文,如果没有收到该类报文,则说明IP地址没有冲突,可以将第一IP地址、MAC地址,以及第二IP地址等通过消息通道发送至云平台,以便云平台对第一虚拟机进行监管。在接收到云平台发送的控制指令后,则根据控制指令中携带的第一IP地址、MAC地址,以及第二IP地址,生成动态主机配置协议服务器的释放报文并发送至动态主机配置协议服务器,以便动态主机配置协议服务器回收第一IP地址。
本实施例提供一种回收虚拟机IP地址的装置,如图7示,包括:获取模块701、创建模块702、监测模块703,以及发送模块704。
获取模块701,用于获取云平台发送的控制指令,控制指令用以指示为第一虚拟机创建消失事件和生成事件;
创建模块702,用于根据控制指令,为第一虚拟机创建消失事件和生成事件;
监测模块703,用于监测第一虚拟机的运行状态,运行状态用以确定第一虚拟机的消失事件是否生效,或确定第一虚拟机的生成事件是否生效;
发送模块704,用于将运行状态发送至云平台。
本实施例中的回收虚拟机IP地址的装置是以功能模块的形式来呈现,这里的模块是指专用集成电路(Application Specific Integrated Circuit,简称ASIC),执行一个或多个软件或固定程序的处理器和存储器,和/或其他可以提供上述功能的器件。
上述各个模块和单元的更进一步的功能描述与上述对应实施例相同,在此不再赘述。
本发明实施例提供的一种回收虚拟机IP地址的装置,获取云平台发送的控制指令,根据控制指令为第一虚拟机创建消失事件和生成事件。并且监测第一虚拟机的运行状态,其中,运行状态可以包括第一虚拟机的消失事件生效,或者第一虚拟机的生成事件生效。不管是哪一种运行状态,都需要发送至云平台。用以方便云平台根据第一虚拟机的运行状态来确定第一虚拟机何时全局下线,进而告知数据处理单元回收第一虚拟机的IP地址。
本发明实施例还提供一种云平台,具有上述图5所示的回收虚拟机IP地址的装置。
请参阅图8,图8是本发明可选实施例提供的一种云平台的结构示意图,如图8所示,该云平台包括:一个或多个处理器10、存储器20,以及用于连接各部件的接口,包括高速接口和低速接口。各个部件利用不同的总线互相通信连接,并且可以被安装在公共主板上或者根据需要以其它方式安装。处理器可以对在计算机设备内执行的指令进行处理,包括存储在存储器中或者存储器上以在外部输入/输出装置(诸如,耦合至接口的显示设备)上显示GUI的图形信息的指令。在一些可选的实施方式中,若需要,可以将多个处理器和/或多条总线与多个存储器和多个存储器一起使用。同样,可以连接多个计算机设备,各个设备提供部分必要的操作(例如,作为服务器阵列、一组刀片式服务器、或者多处理器系统)。图8中以一个处理器810为例。
处理器810可以是中央处理器,网络处理器或其组合。其中,处理器810还可以进一步包括硬件芯片。上述硬件芯片可以是专用集成电路,可编程逻辑器件或其组合。上述可编程逻辑器件可以是复杂可编程逻辑器件,现场可编程逻辑门阵列,通用阵列逻辑或其任意组合。
其中,存储器820存储有可由至少一个处理器810执行的指令,以使至少一个处理器810执行实现上述实施例示出的方法。
存储器820可以包括存储程序区和存储数据区,其中,存储程序区可存储操作系统、至少一个功能所需要的应用程序;存储数据区可存储根据一种小程序落地页的展现的计算机设备的使用所创建的数据等。此外,存储器820可以包括高速随机存取存储器,还可以包括非瞬时存储器,例如至少一个磁盘存储器件、闪存器件、或其他非瞬时固态存储器件。在一些可选的实施方式中,存储器820可选包括相对于处理器810远程设置的存储器,这些远程存储器可以通过网络连接至该计算机设备。上述网络的实例包括但不限于互联网、企业内部网、局域网、移动通信网及其组合。
存储器820可以包括易失性存储器,例如,随机存取存储器;存储器也可以包括非易失性存储器,例如,快闪存储器,硬盘或固态硬盘;存储器820还可以包括上述种类的存储器的组合。
该计算机设备还包括输入装置830和输出装置840。处理器810、存储器820、输入装置830和输出装置840可以通过总线或者其他方式连接,图8中以通过总线连接为例。
输入装置830可接收输入的数字或字符信息,以及产生与该计算机设备的用户设置以及功能控制有关的键信号输入,例如触摸屏、小键盘、鼠标、轨迹板、触摸板、指示杆、一个或者多个鼠标按钮、轨迹球、操纵杆等。输出装置840可以包括显示设备、辅助照明装置(例如,LED)和触觉反馈装置(例如,振动电机)等。上述显示设备包括但不限于液晶显示器,发光二极管,显示器和等离子体显示器。在一些可选的实施方式中,显示设备可以是触摸屏。
本发明实施例还提供一种计算机设备,具有上述图6或图7所示的回收虚拟机IP地址的装置。
请参阅图9,图9是本发明可选实施例提供的一种计算机设备的结构示意图,如图9所示,该计算机设备包括:一个或多个处理器910、存储器920,以及用于连接各部件的接口,包括高速接口和低速接口。各个部件利用不同的总线互相通信连接,并且可以被安装在公共主板上或者根据需要以其它方式安装。处理器可以对在计算机设备内执行的指令进行处理,包括存储在存储器中或者存储器上以在外部输入/输出装置(诸如,耦合至接口的显示设备)上显示GUI的图形信息的指令。在一些可选的实施方式中,若需要,可以将多个处理器和/或多条总线与多个存储器和多个存储器一起使用。同样,可以连接多个计算机设备,各个设备提供部分必要的操作(例如,作为服务器阵列、一组刀片式服务器、或者多处理器系统)。图9中以一个处理器910为例。
处理器910可以是中央处理器,网络处理器或其组合。其中,处理器910还可以进一步包括硬件芯片。上述硬件芯片可以是专用集成电路,可编程逻辑器件或其组合。上述可编程逻辑器件可以是复杂可编程逻辑器件,现场可编程逻辑门阵列,通用阵列逻辑或其任意组合。
其中,存储器920存储有可由至少一个处理器910执行的指令,以使至少一个处理器910执行实现上述实施例示出的方法。
存储器920可以包括存储程序区和存储数据区,其中,存储程序区可存储操作系统、至少一个功能所需要的应用程序;存储数据区可存储根据一种小程序落地页的展现的计算机设备的使用所创建的数据等。此外,存储器920可以包括高速随机存取存储器,还可以包括非瞬时存储器,例如至少一个磁盘存储器件、闪存器件、或其他非瞬时固态存储器件。在一些可选的实施方式中,存储器920可选包括相对于处理器910远程设置的存储器,这些远程存储器可以通过网络连接至该计算机设备。上述网络的实例包括但不限于互联网、企业内部网、局域网、移动通信网及其组合。
存储器920可以包括易失性存储器,例如,随机存取存储器;存储器也可以包括非易失性存储器,例如,快闪存储器,硬盘或固态硬盘;存储器920还可以包括上述种类的存储器的组合。
该计算机设备还包括输入装置930和输出装置940。处理器910、存储器920、输入装置930和输出装置940可以通过总线或者其他方式连接,图9中以通过总线连接为例。
输入装置930可接收输入的数字或字符信息,以及产生与该计算机设备的用户设置以及功能控制有关的键信号输入,例如触摸屏、小键盘、鼠标、轨迹板、触摸板、指示杆、一个或者多个鼠标按钮、轨迹球、操纵杆等。输出装置940可以包括显示设备、辅助照明装置(例如,LED)和触觉反馈装置(例如,振动电机)等。上述显示设备包括但不限于液晶显示器,发光二极管,显示器和等离子体显示器。在一些可选的实施方式中,显示设备可以是触摸屏。
本发明实施例还提供了一种计算机可读存储介质,上述根据本发明实施例的方法可在硬件、固件中实现,或者被实现为可记录在存储介质,或者被实现通过网络下载的原始存储在远程存储介质或非暂时机器可读存储介质中并将被存储在本地存储介质中的计算机代码,从而在此描述的方法可被存储在使用通用计算机、专用处理器或者可编程或专用硬件的存储介质上的这样的软件处理。其中,存储介质可为磁碟、光盘、只读存储记忆体、随机存储记忆体、快闪存储器、硬盘或固态硬盘等;进一步地,存储介质还可以包括上述种类的存储器的组合。可以理解,计算机、处理器、微处理器控制器或可编程硬件包括可存储或接收软件或计算机代码的存储组件,当软件或计算机代码被计算机、处理器或硬件访问且执行时,实现上述实施例示出的方法。
虽然结合附图描述了本发明的实施例,但是本领域技术人员可以在不脱离本发明的精神和范围的情况下做出各种修改和变型,这样的修改和变型均落入由所附权利要求所限定的范围之内。

Claims (14)

1.一种回收虚拟机IP地址的方法,其特征在于,所述方法由云平台执行,所述方法包括:
获取数据处理单元发送的第一虚拟机的第一IP地址、MAC地址以及动态主机配置协议服务器的第二IP地址,其中,所述第一虚拟机为云平台对应的集群中节点配置的任一个虚拟机;
根据所述MAC地址,确定所述第一虚拟机的第一标识信息;
向所述集群中的节点发送第一控制指令,其中,所述第一控制指令中携带所述第一标识信息,所述第一控制指令用以指示所述集群中的节点根据所述第一标识信息,为所述第一虚拟机创建消失事件和生成事件;
当接收到任一所述节点反馈的与所述第一虚拟机对应的消失事件时,设置监测等待时间;
当经过所述监测等待时间后没有收到任意节点反馈的与所述第一虚拟机对应的生成事件时,则确定所述第一虚拟机全局下线;
向所述数据处理单元发送第二控制指令,其中,所述第二控制指令携带所述第一IP地址、所述MAC地址,以及所述第二IP地址,以便所述数据处理单元根据所述第一IP地址、所述MAC地址,以及所述第二IP地址,指示动态主机配置协议服务器回收所述第一IP地址。
2.根据权利要求1所述的方法,其特征在于,所述获取数据处理单元发送的第一虚拟机的第一IP地址、MAC地址以及动态主机配置协议服务器的第二IP地址之后,所述方法还包括:
将所述第一虚拟机的第一标识信息加入到虚拟机监测队列。
3.根据权利要求2所述的方法,其特征在于,所述方法还包括:
当接收到任一所述节点反馈的与第二虚拟机对应的生成事件时,从与所述第二虚拟机对应的生成事件中提取所述第二虚拟机的第二标识信息;
将所述第二标识信息与所述虚拟机监测队列中存储的标识信息进行匹配;
当未匹配成功时,将所述第二虚拟机对应的生成事件删除。
4.一种回收虚拟机IP地址的方法,其特征在于,所述方法由数据处理单元中配置的监听应用程序执行,所述方法包括:
接收云平台下发的流表匹配规则,所述流表匹配规则用于匹配符合预设条件的动态主机配置协议响应报文;
向智能网卡加速引擎发送所述流表匹配规则;
当获取到所述智能网卡加速引擎发送的所述动态主机配置协议响应报文时,对所述动态主机配置协议响应报文进行解析,获取并保存第一虚拟机的第一IP地址、MAC地址,以及动态主机配置协议服务器的第二IP地址;
监测所述第一虚拟机在预设时间段内是否发出指示所述第一IP地址冲突的报文;
当所述监听应用程序在所述预设时间段内未监测到指示所述第一IP地址冲突的报文时,向云平台发送所述第一IP地址、所述MAC地址,以及所述第二IP地址;
当接收到所述云平台发送的控制指令,且所述控制指令中包括所述第一IP地址、所述MAC地址,以及所述第二IP地址时,根据所述第一IP地址、所述MAC地址,以及所述第二IP地址,生成动态主机配置协议服务器的释放报文;
将所述释放报文发送至目标动态主机配置协议服务器,以便所述目标动态主机配置协议服务器回收所述第一IP地址。
5.根据权利要求4所述的方法,其特征在于,所述预设条件为所述动态主机配置协议响应报文中携带有所述第一IP地址、所述MAC地址,以及所述第二IP地址,且所述第一IP地址的字段值、所述MAC地址的字段值,以及所述第二IP地址的字段值均非空。
6.根据权利要求4或5所述的方法,其特征在于,所述方法还包括:
在所述预设时间段内监测到指示所述第一IP地址冲突的报文时,清除已保存的所述第一IP地址、所述MAC地址,以及所述第二IP地址。
7.一种回收虚拟机IP地址的方法,其特征在于,所述方法由集群中的节点执行,所述方法包括:
获取云平台发送的控制指令;
根据所述控制指令,为第一虚拟机创建消失事件和生成事件;
监测所述第一虚拟机的运行状态,所述运行状态用以确定所述第一虚拟机的消失事件是否生效,或确定所述第一虚拟机的生成事件是否生效;
将所述运行状态发送至所述云平台。
8.一种回收虚拟机IP地址的装置,其特征在于,所述装置包括:
获取模块,用于获取数据处理单元发送的第一虚拟机的第一IP地址、MAC地址以及动态主机配置协议服务器的第二IP地址,其中,所述第一虚拟机为云平台对应的集群中节点配置的任一个虚拟机;
确定模块,用于根据所述MAC地址,确定所述第一虚拟机的第一标识信息;
发送模块,用于向所述集群中的节点发送第一控制指令,其中,所述第一控制指令中携带所述第一标识信息,所述第一控制指令用以指示所述集群中的节点根据所述第一标识信息,为所述第一虚拟机创建消失事件和生成事件;
接收模块,用于接收任一所述节点反馈的与所述第一虚拟机对应的消失事件;
处理模块,用于当所述接收模块接收到任一所述节点反馈的与所述第一虚拟机对应的消失事件时,设置监测等待时间;且当经过所述监测等待时间后没有收到任意节点反馈的与所述第一虚拟机对应的生成事件时,则确定所述第一虚拟机全局下线;
所述发送模块,还用于向所述数据处理单元发送第二控制指令,其中,所述第二控制指令携带所述第一IP地址、所述MAC地址,以及所述第二IP地址,以便所述数据处理单元根据所述第一IP地址、所述MAC地址,以及所述第二IP地址,指示动态主机配置协议服务器回收所述第一IP地址。
9.一种回收虚拟机IP地址的装置,其特征在于,所述装置包括:
接收模块,用于接收云平台下发的流表匹配规则,所述流表匹配规则用于匹配符合预设条件的动态主机配置协议响应报文;
发送模块,用于向智能网卡加速引擎发送所述流表匹配规则;
获取模块,用于获取所述智能网卡加速引擎发送的所述动态主机配置协议响应报文;
解析模块,用于对所述动态主机配置协议响应报文进行解析,获取并保存第一虚拟机的第一IP地址、MAC地址,以及动态主机配置协议服务器的第二IP地址;
监测模块,用于监测所述第一虚拟机在预设时间段内是否发出指示所述第一IP地址冲突的报文;
所述发送模块,还用于当监听应用程序在所述预设时间段内未监测到指示所述第一IP地址冲突的报文时,向云平台发送所述第一IP地址、所述MAC地址,以及所述第二IP地址;
所述接收模块,还用于接收所述云平台发送的控制指令;
处理模块,用于当确定所述控制指令中包括所述第一IP地址、所述MAC地址,以及所述第二IP地址时,根据所述第一IP地址、所述MAC地址,以及所述第二IP地址,生成动态主机配置协议服务器的释放报文;
所述发送模块,还用于将所述释放报文发送至目标动态主机配置协议服务器,以便所述目标动态主机配置协议服务器回收所述第一IP地址。
10.一种回收虚拟机IP地址的装置,其特征在于,所述装置包括:
获取模块,用于获取云平台发送的控制指令;
创建模块,用于根据所述控制指令,为第一虚拟机创建消失事件和生成事件;
监测模块,用于监测所述第一虚拟机的运行状态,所述运行状态用以确定所述第一虚拟机的消失事件是否生效,或确定所述第一虚拟机的生成事件是否生效;
发送模块,用于将所述运行状态发送至所述云平台。
11.一种云平台,其特征在于,包括:
存储器和处理器,所述存储器和所述处理器之间互相通信连接,所述存储器中存储有计算机指令,所述处理器通过执行所述计算机指令,从而执行权利要求1至3中任一项所述的回收虚拟机IP地址的方法。
12.一种计算机设备,其特征在于,包括:
存储器和处理器,所述存储器和所述处理器之间互相通信连接,所述存储器中存储有计算机指令,所述处理器通过执行所述计算机指令,从而执行权利要求4至6中任一项所述的回收虚拟机IP地址的方法;或者,执行权利要求7所述的回收虚拟机IP地址的方法。
13.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质上存储有计算机指令,所述计算机指令用于使云平台执行权利要求1至3中任一项所述的回收虚拟机IP地址的方法。
14.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质上存储有计算机指令,所述计算机指令用于使计算机设备执行权利要求4至6中任一项所述的回收虚拟机IP地址的方法;或者,所述计算机指令用于使计算机设备执行权利要求7所述的回收虚拟机IP地址的方法。
CN202311160576.XA 2023-09-08 2023-09-08 回收虚拟机ip地址的方法、装置、计算机设备及介质 Pending CN117061486A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202311160576.XA CN117061486A (zh) 2023-09-08 2023-09-08 回收虚拟机ip地址的方法、装置、计算机设备及介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202311160576.XA CN117061486A (zh) 2023-09-08 2023-09-08 回收虚拟机ip地址的方法、装置、计算机设备及介质

Publications (1)

Publication Number Publication Date
CN117061486A true CN117061486A (zh) 2023-11-14

Family

ID=88660882

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202311160576.XA Pending CN117061486A (zh) 2023-09-08 2023-09-08 回收虚拟机ip地址的方法、装置、计算机设备及介质

Country Status (1)

Country Link
CN (1) CN117061486A (zh)

Similar Documents

Publication Publication Date Title
JP2021521528A (ja) タスク処理方法、装置及びシステム
EP2891977A1 (en) Method, system and device for managing virtual machine software in cloud environment
US10452469B2 (en) Server performance correction using remote server actions
US9122793B2 (en) Distributed debugging of an application in a distributed computing environment
JP2009519523A (ja) 仮想データ・センタ複合体内のターゲット仮想オペレーティング・システムのパフォーマンスをモニタするための方法、システム、およびコンピュータ・プログラム
CN107666493B (zh) 一种数据库配置方法及其设备
CN110635944A (zh) 一种集群网络配置方法、装置及电子设备和存储介质
US10067862B2 (en) Tracking asynchronous entry points for an application
CN111913884A (zh) 分布式测试方法、装置、设备、系统和可读存储介质
CN107665141B (zh) 一种数据库配置方法及其设备
CN111176577B (zh) 分布式块存储服务命令处理方法、装置、设备及介质
CN111309574A (zh) 信息处理方法、装置及设备
JP2014035744A (ja) 検証管理装置、検証管理方法および検証管理プログラム
CN117608825A (zh) 基于多云管理平台的资源管理方法和相关设备
CN112037332A (zh) 浏览器的显示校验方法、装置、计算机设备和存储介质
CN105955838A (zh) 一种系统死机的原因查看方法及装置
CN113765712B (zh) 服务器管理方法、装置、电子设备及可读存储介质
US20150256446A1 (en) Method and apparatus for relaying commands
CN112968927B (zh) 日志提取方法、日志提取装置、存储介质及电子设备
CN112235300B (zh) 云虚拟网络漏洞检测方法、系统、装置及电子设备
US9317354B2 (en) Dynamically determining an external systems management application to report system errors
CN111966471A (zh) 访问方法、装置、电子设备及计算机存储介质
JP2015064872A (ja) 監視システム、システム及び監視方法
CN117061486A (zh) 回收虚拟机ip地址的方法、装置、计算机设备及介质
CN114115189A (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