本公开涉及计算机应用技术领域,尤其涉及一种服务器热更新方法、装置、设备和存储介质。
背景技术:
任意线上服务被发布后,均会存在后台程序bug修复或功能特性更新等需求,现有方案通常采用以下两种方式对服务器进行更新:
方案一:利用npm(nodepackagemanager,节点包管理器)库中的chokidar(一种监听文件变化的插件)监控监听服务文件的变化,更新服务文件并重启服务进程。该方案的缺陷在于:服务器重启造成服务掉线、中断,而且有的功能较为庞大的服务器重启耗费较长,导致重启成本较高。
方案二:基于方案一对服务文件进行监控,并通过向上回溯的方式确定出存在依赖关系的功能模块(即文件模块),然后利用新的功能模块整体替换旧的功能模块,实现功能模块的动态重新加载。该方案的缺陷在于:实现上较为复杂,并且不支持修改已经实例化的内存对象。
然而,在服务器更新过程中,将内存中的旧数据同步修改为最新的逻辑或者最新的属性,也是非常必要的。
技术实现要素:
为了解决上述技术问题或者至少部分地解决上述技术问题,本公开实施例提供了一种服务器热更新方法、装置、设备和存储介质。
第一方面,本公开实施例提供了一种服务器热更新方法,包括:
确定服务器内存中的待更新对象;
获取与所述待更新对象对应的热更代码文件,并将所述热更代码文件存储至所述服务器;其中,所述热更代码文件中包括所述待更新对象更新后的目标内容;
基于热更指令,将所述热更代码文件加载至所述服务器的进程空间并执行所述热更代码文件,以利用所述目标内容更新所述待更新对象在所述服务器内存中的原始内容。
第二方面,本公开实施例还提供了一种服务器热更新装置,包括:
待更新对象确定模块,用于确定服务器内存中的待更新对象;
热更代码文件获取模块,用于获取与所述待更新对象对应的热更代码文件,并将所述热更代码文件存储至所述服务器;其中,所述热更代码文件中包括所述待更新对象更新后的目标内容;
内存更新模块,用于基于热更指令,将所述热更代码文件加载至所述服务器的进程空间并执行所述热更代码文件,以利用所述目标内容更新所述待更新对象在所述服务器内存中的原始内容。
第三方面,本公开实施例还提供了一种电子设备,包括存储器和处理器,其中:所述存储器中存储有计算机程序,当所述计算机程序被所述处理器执行时,使得所述电子设备实现本公开实施例提供的任一服务器热更新方法。
第四方面,本公开实施例还提供了一种计算机可读存储介质,所述存储介质中存储有计算机程序,当所述计算机程序被计算设备执行时,使得所述计算设备实现本公开实施例提供的任一服务器热更新方法。
本公开实施例提供的技术方案与现有技术相比至少具有如下优点:在本公开实施例中,通过将与待更新对象对应的热更代码文件加载至服务器的进程空间并执行热更代码文件,以利用热更代码文件中的目标内容更新待更新对象在服务器内存中的原始内容,在不需要服务器重启、不需要重新加载具有依赖关系的功能模块的基础上,实现了对服务器内存中待更新对象的更新,并且,基于该服务器提供服务支持的应用服务不会发生中断,用户完全无感知。
附图说明
此处的附图被并入说明书中并构成本说明书的一部分,示出了符合本公开的实施例,并与说明书一起用于解释本公开的原理。
为了更清楚地说明本公开实施例或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,对于本领域普通技术人员而言,在不付出创造性劳动性的前提下,还可以根据这些附图获得其他的附图。
图1为本公开实施例提供的一种服务器热更新方法的流程图;
图2为本公开实施例提供的一种服务器热更新架构的示意图;
图3为本公开实施例提供的一种服务器热更新装置的结构示意图;
图4为本公开实施例提供的一种电子设备的结构示意图。
具体实施方式
为了能够更清楚地理解本公开的上述目的、特征和优点,下面将对本公开的方案进行进一步描述。需要说明的是,在不冲突的情况下,本公开的实施例及实施例中的特征可以相互组合。
在下面的描述中阐述了很多具体细节以便于充分理解本公开,但本公开还可以采用其他不同于在此描述的方式来实施;显然,说明书中的实施例只是本公开的一部分实施例,而不是全部的实施例。
图1为本公开实施例提供的一种服务器热更新方法的流程图,可以适用于对服务器进行热更新的情况,该方法可以由服务器热更新装置执行,该装置可以采用软件和/或硬件实现,并可集成在任意具有计算能力的电子设备上,例如服务器等。
如图1所示,本公开实施例提供的服务器热更新方法可以包括:
s101、确定服务器内存中的待更新对象。
其中,待更新对象包括变量和/或函数,并与服务器更新需求(例如程序bug修复或者特定功能更新等)有关,示例性的,可以利用预先设定的监测程序对已经加载至服务器内存中的待更新对象进行监测。
s102、获取与待更新对象对应的热更代码文件,并将热更代码文件存储至服务器;其中,热更代码文件中包括待更新对象更新后的目标内容。
热更代码文件是开发人员根据服务器更新需求,预先为待更新对象构建的热更补丁文件,其中包括了待更新对象更新后的目标内容,例如与服务器内存中预设变量对应的新属性,与服务器内存中预设函数(或称为方法)对应的新逻辑等。热更代码文件构建完成后,部署至服务器中。
s103、基于热更指令,将热更代码文件加载至服务器的进程空间并执行热更代码文件,以利用目标内容更新待更新对象在服务器内存中的原始内容。
热更指令可以由开发人员触发,服务器基于热更指令,在服务器进程空间中执行热更代码文件,并通过变量名或者函数名匹配,直接实现对内存中属性类数据或者代码逻辑的修改,本方案的可控性与目的性更强,并且更新粒度更为细化。服务器内存中变量或函数对应的内容被更新后,服务器可以基于更新后的内容进行任务执行。
在本公开实施例中,通过将与待更新对象对应的热更代码文件加载至服务器的进程空间并执行热更代码文件,以利用热更代码文件中的目标内容更新待更新对象在服务器内存中的原始内容,在不需要服务器重启、不需要重新加载具有依赖关系的功能模块的基础上,实现了对服务器内存中待更新对象的更新,并且,基于该服务器提供服务支持的应用服务不会发生中断,用户完全无感知。
在上述技术方案的基础上,将热更代码文件加载至服务器的进程空间并执行热更代码文件,包括:
通过远程调用(remoteprocedurecall,rpc)的方式,将热更代码文件加载至服务器的进程空间并执行热更代码文件;其中,热更代码文件包括hotfix热更代码文件。
其中,hotfix是针对某一个具体的系统漏洞或安全问题而发布的专门解决该漏洞或安全问题的代码程序,能以补丁的形式完成动态修复。
进一步的,如果待更新对象为函数,则执行热更代码文件,包括:利用hotfix热更代码文件中的hotfixclassmethod类函数,对服务器内存中函数的原始内容进行更新,更新操作可以包括修改函数逻辑、替换或者覆盖原有函数等。其中,classmethod类函数可以直接通过调用类名或方法名(即函数名)的方式,将与待更新函数对应的新逻辑对服务器内存中的函数进行更新,在实现上更为便捷、高效。
图2为本公开实施例提供的一种服务器热更新架构的示意图,用于对本公开实施例的技术方案进行示例性说明。
此外,本公开实施例对多种程序语言均具有适用性,例如,采用本公开实施例的技术方案,可以在服务器内存中修改、替换node.js(javascript、typescript)原型链或属性,实现服务器的热更新;或者,可以在服务器内存中修改、替换lua(一种轻量小巧的脚本语言,用标准c语言编写)元表或属性,实现服务器的热更新。
并且,本公开实施例提供的技术方案还可以包括:在服务器更新过程中,为待更新对象在服务器内存中的原始内容添加标记并保留该原始内容,例如在服务器中进行备份存储或者继续存储在服务器内存中,以使根据该标记将待更新对象还原至该原始内容,即本公开实施例在服务器更新过程中,不会对内存中变量或函数的原始内容进行丢弃,支持随时将服务器内存中的变量或函数进行还原,避免服务器更新后不可逆的现象。
图3为本公开实施例提供的一种服务器热更新装置的结构示意图,该装置可以采用软件和/或硬件实现,并可集成在任意具有计算能力的电子设备上,例如服务器等。
如图3所示,本公开实施例提供的服务器热更新装置300可以包括待更新对象确定模块301、热更代码文件获取模块302和内存更新模块303,其中:
待更新对象确定模块301,用于确定服务器内存中的待更新对象;
热更代码文件获取模块302,用于获取与待更新对象对应的热更代码文件,并将热更代码文件存储至服务器;其中,热更代码文件中包括待更新对象更新后的目标内容;
内存更新模块303,用于基于热更指令,将热更代码文件加载至服务器的进程空间并执行热更代码文件,以利用目标内容更新待更新对象在服务器内存中的原始内容。
可选的,待更新对象包括变量或函数。
可选的,内存更新模块303具体用于:
基于热更指令,通过远程调用的方式,将热更代码文件加载至服务器的进程空间并执行热更代码文件;其中,热更代码文件包括hotfix热更代码文件。
可选的,如果待更新对象为函数,则内存更新模块303包括:
函数更新单元,用于利用hotfix热更代码文件中的hotfixclassmethod类函数,对服务器内存中函数的原始内容进行更新。
本公开实施例所提供的服务器热更新装置可执行本公开实施例所提供的任意服务器热更新方法,具备执行方法相应的功能模块和有益效果。本公开装置实施例中未详尽描述的内容可以参考本公开任意方法实施例中的描述。
图4为本公开实施例提供的一种电子设备的结构示意图,用于对实现本公开实施例提供的服务器热更新方法的电子设备进行示例性说明。本公开实施例中的电子设备可以包括但不限于诸如移动电话、笔记本电脑、数字广播接收器、pda(个人数字助理)、pad(平板电脑)、pmp(便携式多媒体播放器)、车载终端(例如车载导航终端)等等的移动终端以及诸如数字tv、台式计算机、智能家居设备、可穿戴电子设备、服务器等等的固定终端。图4示出的电子设备仅仅是一个示例,不应对本公开实施例的功能和占用范围带来任何限制。
如图4所示,电子设备400包括一个或多个处理器401和存储器402。
处理器401可以是中央处理单元(cpu)或者具有数据处理能力和/或指令执行能力的其他形式的处理单元,并且可以控制电子设备400中的其他组件以执行期望的功能。
存储器402可以包括一个或多个计算机程序产品,计算机程序产品可以包括各种形式的计算机可读存储介质,例如易失性存储器和/或非易失性存储器。易失性存储器例如可以包括随机存取存储器(ram)和/或高速缓冲存储器(cache)等。非易失性存储器例如可以包括只读存储器(rom)、硬盘、闪存等。在计算机可读存储介质上可以存储一个或多个计算机程序指令,处理器401可以运行程序指令,以实现本公开实施例提供的服务器热更新方法,还可以实现其他期望的功能。在计算机可读存储介质中还可以存储诸如输入信号、信号分量、噪声分量等各种内容。
其中,本公开实施例提供的服务器热更新方法可以包括:确定服务器内存中的待更新对象;获取与所述待更新对象对应的热更代码文件,并将所述热更代码文件存储至所述服务器;其中,所述热更代码文件中包括所述待更新对象更新后的目标内容;基于热更指令,将所述热更代码文件加载至所述服务器的进程空间并执行所述热更代码文件,以利用所述目标内容更新所述待更新对象在所述服务器内存中的原始内容。应当理解,电子设备400还可以执行本公开方法实施例提供的其他可选实施方案。
在一个示例中,电子设备400还可以包括:输入装置403和输出装置404,这些组件通过总线系统和/或其他形式的连接机构(未示出)互连。
此外,该输入装置403还可以包括例如键盘、鼠标等等。
该输出装置404可以向外部输出各种信息,包括确定出的距离信息、方向信息等。该输出装置404可以包括例如显示器、扬声器、打印机、以及通信网络及其所连接的远程输出设备等等。
当然,为了简化,图4中仅示出了该电子设备400中与本公开有关的组件中的一些,省略了诸如总线、输入/输出接口等等的组件。除此之外,根据具体应用情况,电子设备400还可以包括任何其他适当的组件。
除了上述方法和设备以外,本公开的实施例还可以是计算机程序产品,其包括计算机程序指令,计算机程序指令在被处理器运行时使得计算设备实现本公开实施例所提供的任意服务器热更新方法。
计算机程序产品可以以一种或多种程序设计语言的任意组合来编写用于执行本公开实施例操作的程序代码,程序设计语言包括面向对象的程序设计语言,诸如java、c 等,还包括常规的过程式程序设计语言,诸如“c”语言或类似的程序设计语言。程序代码可以完全地在用户电子设备上执行、部分地在用户电子设备上执行、作为一个独立的软件包执行、部分在用户电子设备上且部分在远程电子设备上执行、或者完全在远程电子设备上执行。
此外,本公开实施例还可以提供一种计算机可读存储介质,其上存储有计算机程序指令,计算机程序指令在被处理器运行时使得计算设备实现本公开实施例所提供的任意服务器热更新方法。
其中,本公开实施例提供的服务器热更新方法可以包括:确定服务器内存中的待更新对象;获取与所述待更新对象对应的热更代码文件,并将所述热更代码文件存储至所述服务器;其中,所述热更代码文件中包括所述待更新对象更新后的目标内容;基于热更指令,将所述热更代码文件加载至所述服务器的进程空间并执行所述热更代码文件,以利用所述目标内容更新所述待更新对象在所述服务器内存中的原始内容。应当理解,计算机程序指令在被处理器运行时,还可以使得处理器执行本公开方法实施例提供的其他可选实施方案。
计算机可读存储介质可以采用一个或多个可读介质的任意组合。可读介质可以是可读信号介质或者可读存储介质。可读存储介质例如可以包括但不限于电、磁、光、电磁、红外线、或半导体的系统、装置或器件,或者任意以上的组合。可读存储介质的更具体的例子(非穷举的列表)包括:具有一个或多个导线的电连接、便携式盘、硬盘、随机存取存储器(ram)、只读存储器(rom)、可擦式可编程只读存储器(eprom或闪存)、光纤、便携式紧凑盘只读存储器(cd-rom)、光存储器件、磁存储器件、或者上述的任意合适的组合。
需要说明的是,在本文中,诸如“第一”和“第二”等之类的关系术语仅仅用来将一个实体或者操作与另一个实体或操作区分开来,而不一定要求或者暗示这些实体或操作之间存在任何这种实际的关系或者顺序。而且,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者设备所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括要素的过程、方法、物品或者设备中还存在另外的相同要素。
以上仅是本公开的具体实施方式,使本领域技术人员能够理解或实现本公开。对这些实施例的多种修改对本领域的技术人员来说将是显而易见的,本文中所定义的一般原理可以在不脱离本公开的精神或范围的情况下,在其它实施例中实现。因此,本公开将不会被限制于本文的这些实施例,而是要符合与本文所公开的原理和新颖特点相一致的最宽的范围。
1.一种服务器热更新方法,其特征在于,包括:
确定服务器内存中的待更新对象;
获取与所述待更新对象对应的热更代码文件,并将所述热更代码文件存储至所述服务器;其中,所述热更代码文件中包括所述待更新对象更新后的目标内容;
基于热更指令,将所述热更代码文件加载至所述服务器的进程空间并执行所述热更代码文件,以利用所述目标内容更新所述待更新对象在所述服务器内存中的原始内容。
2.根据权利要求1所述的方法,其特征在于,所述待更新对象包括变量和/或函数。
3.根据权利要求1或2所述的方法,其特征在于,所述将所述热更代码文件加载至所述服务器的进程空间并执行所述热更代码文件,包括:
通过远程调用的方式,将所述热更代码文件加载至所述服务器的进程空间并执行所述热更代码文件;其中,所述热更代码文件包括hotfix热更代码文件。
4.根据权利要求3所述的方法,其特征在于,如果所述待更新对象为函数,则所述执行所述热更代码文件,包括:
利用所述hotfix热更代码文件中的hotfixclassmethod类函数,对所述服务器内存中函数的原始内容进行更新。
5.一种服务器热更新装置,其特征在于,包括:
待更新对象确定模块,用于确定服务器内存中的待更新对象;
热更代码文件获取模块,用于获取与所述待更新对象对应的热更代码文件,并将所述热更代码文件存储至所述服务器;其中,所述热更代码文件中包括所述待更新对象更新后的目标内容;
内存更新模块,用于基于热更指令,将所述热更代码文件加载至所述服务器的进程空间并执行所述热更代码文件,以利用所述目标内容更新所述待更新对象在所述服务器内存中的原始内容。
6.根据权利要求5所述的装置,其特征在于,所述待更新对象包括变量或函数。
7.根据权利要求5或6所述的装置,其特征在于,所述内存更新模块具体用于:
基于所述热更指令,通过远程调用的方式,将所述热更代码文件加载至所述服务器的进程空间并执行所述热更代码文件;其中,所述热更代码文件包括hotfix热更代码文件。
8.根据权利要求7所述的装置,其特征在于,如果所述待更新对象为函数,则所述内存更新模块包括:
函数更新单元,用于利用所述hotfix热更代码文件中的hotfixclassmethod类函数,对所述服务器内存中函数的原始内容进行更新。
9.一种电子设备,其特征在于,包括存储器和处理器,其中:
所述存储器中存储有计算机程序,当所述计算机程序被所述处理器执行时,使得所述电子设备实现权利要求1-4中任一项所述的服务器热更新方法。
10.一种计算机可读存储介质,其特征在于,所述存储介质中存储有计算机程序,当所述计算机程序被计算设备执行时,使得所述计算设备实现权利要求1-4中任一项所述的服务器热更新方法。
技术总结