CN104899057B - 软件模块的更新方法和装置 - Google Patents
软件模块的更新方法和装置 Download PDFInfo
- Publication number
- CN104899057B CN104899057B CN201510240885.7A CN201510240885A CN104899057B CN 104899057 B CN104899057 B CN 104899057B CN 201510240885 A CN201510240885 A CN 201510240885A CN 104899057 B CN104899057 B CN 104899057B
- Authority
- CN
- China
- Prior art keywords
- software module
- module
- thread
- request
- update
- 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.)
- Active
Links
Abstract
本发明提出一种软件模块的更新方法和装置,该软件模块的更新方法包括对已加载的软件模块的多个访问请求进行序列化处理,得到序列化后的请求队列,其中,所述多个访问请求包括用于指示对所述软件模块进行更新的更新请求;由单一的线程依次从所述序列化后的请求队列中读取访问请求;当读取的访问请求是所述更新请求时,由所述单一的线程卸载所述软件模块,并重新加载更新后的所述软件模块。该方法可以实现软件模块的热更新。
Description
技术领域
本发明涉及信息技术领域,尤其涉及一种软件模块的更新方法和装置。
背景技术
软件设计会将功能模块化,不同功能分别由不同模块实现,使得模块之间减少耦合,减少出错的几率。软件运行时,由宿主进程将软件模块加载到内存,对软件模块的功能进行调用。软件模块更新是重新加载新版本的软件模块,替换旧版本的软件模块。
软件模块的热更新是指不需要重启宿主进程,完成软件模块的更新。
现有技术中,宿主进程中可以存在多个线程同时访问加载的软件模块,为了保证安全卸载,在软件模块更新时,需要重启宿主进程,重新加载新版本的软件模块。由于需要重启宿主进程,也就不能实现软件模块的热更新。
发明内容
本发明旨在至少在一定程度上解决相关技术中的技术问题之一。
为此,本发明的一个目的在于提出一种软件模块的更新方法,该方法可以实现软件模块的热更新。
本发明的另一个目的在于提出一种软件模块的更新装置。
为达到上述目的,本发明第一方面实施例提出的软件模块的更新方法,包括:对已加载的软件模块的多个访问请求进行序列化处理,得到序列化后的请求队列,其中,所述多个访问请求包括用于指示对所述软件模块进行更新的更新请求;由单一的线程依次从所述序列化后的请求队列中读取访问请求;当读取的访问请求是所述更新请求时,由所述单一的线程卸载所述软件模块,并重新加载更新后的所述软件模块。
可选的,所述已加载的软件模块是从宿主进程之外的预设位置加载的。
可选的,所述对已加载的软件模块的多个访问请求进行序列化处理,包括:将所述对已加载的软件模块的多个访问请求,依次排列放入预设的缓存位置。
可选的,还包括:接收所述宿主进程内的第一线程发送的更新请求,所述第一线程发送的更新请求是所述第一线程接收到所述宿主进程之外的升级模块发送的更新请求后发送的,所述升级模块发送的更新请求是所述升级模块对所述软件模块进行更新并保存到所述预设位置后发送的。
可选的,所述访问请求还包括所述宿主进程内的第二线程对所述软件模块的访问请求,所述单一的线程是第三线程,所述第一线程,所述第二线程和所述第三线程互不相同。
本发明第一方面实施例提出的软件模块的更新方法,通过对软件模块的多个访问请求进行序列化处理,得到序列化后的请求队列,并由单一的线程依次从序列化后的请求队列中读取访问请求,可以保证在卸载软件模块时不存在其他线程访问该软件模块,由于不会存在多个线程同时访问加载的软件模块,可以在不重启宿主进程的情况下完成软件模块的更新,从而实现软件模块的热更新。
为达到上述目的,本发明第二方面实施例提出的软件模块的更新装置,包括:管理模块,用于对已加载的软件模块的多个访问请求进行序列化处理,得到序列化后的请求队列,其中,所述多个访问请求包括用于指示对所述软件模块进行更新的更新请求;读取模块,用于由单一的线程依次从所述序列化后的请求队列中读取访问请求;处理模块,用于当读取的访问请求是所述更新请求时,由所述单一的线程卸载所述软件模块,并重新加载更新后的所述软件模块。
可选的,还包括:加载模块,用于从宿主进程之外的预设位置加载所述软件模块。
可选的,所述管理模块具体用于:将所述对已加载的软件模块的多个访问请求,依次排列放入预设的缓存位置。
可选的,还包括:接收模块,用于接收所述宿主进程内的第一线程发送的更新请求,所述第一线程发送的更新请求是所述第一线程接收到所述宿主进程之外的升级模块发送的更新请求后发送的,所述升级模块发送的更新请求是所述升级模块对所述软件模块进行更新并保存到所述预设位置后发送的。
可选的,所述访问请求还包括所述宿主进程内的第二线程对所述软件模块的访问请求,所述单一的线程是第三线程,所述第一线程,所述第二线程和所述第三线程互不相同。
本发明第二方面实施例提出的软件模块的更新装置,通过对软件模块的多个访问请求进行序列化处理,得到序列化后的请求队列,并由单一的线程依次从序列化后的请求队列中读取访问请求,可以保证在卸载软件模块时不存在其他线程访问该软件模块,由于不会存在多个线程同时访问加载的软件模块,可以在不重启宿主进程的情况下完成软件模块的更新,从而实现软件模块的热更新。
为达到上述目的,本发明第三方面实施例提出的客户端设备,包括:壳体、处理器、存储器、电路板和电源电路,其中,电路板安置在壳体围成的空间内部,处理器和存储器设置在电路板上;电源电路,用于为客户端设备的各个电路或器件供电;存储器用于存储可执行程序代码;处理器通过读取存储器中存储的可执行程序代码来运行与可执行程序代码对应的程序,以用于执行:对已加载的软件模块的多个访问请求进行序列化处理,得到序列化后的请求队列,其中,所述多个访问请求包括用于指示对所述软件模块进行更新的更新请求;由单一的线程依次从所述序列化后的请求队列中读取访问请求;当读取的访问请求是所述更新请求时,由所述单一的线程卸载所述软件模块,并重新加载更新后的所述软件模块。
可选的,所述已加载的软件模块是从宿主进程之外的预设位置加载的。
可选的,所述对已加载的软件模块的多个访问请求进行序列化处理,包括:将所述对已加载的软件模块的多个访问请求,依次排列放入预设的缓存位置。
可选的,还包括:接收所述宿主进程内的第一线程发送的更新请求,所述第一线程发送的更新请求是所述第一线程接收到所述宿主进程之外的升级模块发送的更新请求后发送的,所述升级模块发送的更新请求是所述升级模块对所述软件模块进行更新并保存到所述预设位置后发送的。
可选的,所述访问请求还包括所述宿主进程内的第二线程对所述软件模块的访问请求,所述单一的线程是第三线程,所述第一线程,所述第二线程和所述第三线程互不相同。
本发明第三方面实施例提出的客户端设备,通过对软件模块的多个访问请求进行序列化处理,得到序列化后的请求队列,并由单一的线程依次从序列化后的请求队列中读取访问请求,可以保证在卸载软件模块时不存在其他线程访问该软件模块,由于不会存在多个线程同时访问加载的软件模块,可以在不重启宿主进程的情况下完成软件模块的更新,从而实现软件模块的热更新。
本发明附加的方面和优点将在下面的描述中部分给出,部分将从下面的描述中变得明显,或通过本发明的实践了解到。
附图说明
本发明上述的和/或附加的方面和优点从下面结合附图对实施例的描述中将变得明显和容易理解,其中:
图1是本发明一实施例提出的软件模块的更新方法的流程示意图;
图2是相关技术中软件模块的更新方法示意图;
图3是本发明实施例中软件模块的更新方法示意图;
图4是本发明另一实施例提出的软件模块的更新装置的结构示意图;
图5是本发明另一实施例提出的软件模块的更新装置的结构示意图。
具体实施方式
下面详细描述本发明的实施例,所述实施例的示例在附图中示出,其中自始至终相同或类似的标号表示相同或类似的元件或具有相同或类似功能的元件。下面通过参考附图描述的实施例是示例性的,仅用于解释本发明,而不能理解为对本发明的限制。相反,本发明的实施例包括落入所附加权利要求书的精神和内涵范围内的所有变化、修改和等同物。
图1是本发明一实施例提出的软件模块的更新方法的流程示意图,该方法包括:
S11:对已加载的软件模块的多个访问请求进行序列化处理,得到序列化后的请求队列,其中,所述多个访问请求包括用于指示对所述软件模块进行更新的更新请求。
可选的,所述已加载的软件模块是从宿主进程之外的预设位置加载的。
一般软件设计都会将功能模块化,不同功能分别由不同软件模块实现。
在软件运行时,宿主进程可以将软件模块加载到内存中,以调用软件模块实现相应功能。其中,宿主进程也可以称为主进程,加载的软件模块可以具体是指不同版本的模块文件。
软件模块可以进行更新。
初始时,宿主进程可以从宿主进程之外的预设位置加载初始的软件模块。
相关技术中,参见图2,软件模块的更新流程可以包括:
S21:宿主进程(HostProcess)加载软件模块(Target.dll),其中,初始加载的软件模块可以是旧版本的软件模块。
其中,宿主进程加载到内存中的软件模块可以用模块映像(Target Image)表示。
S22:宿主进程中的多个线程可以同时访问加载的软件模块。
例如,参见图2,宿主进程中包含线程_1(thread_1)和线程_2(thread_2),这两个线程可以同时访问加载到内存的软件模块(Target Image)。
S23:当需要升级软件模块时,升级模块(Update Module)将软件模块由旧版本更新到新版本。
S24:升级模块向宿主进程发送通知消息,通知宿主进程重新加载更新后的软件模块。
当宿主进程接收到升级模块的通知消息后,宿主进程弹出弹窗,提示用户重启宿主进程以更新软件模块。
由上述方案可知,相关技术中,宿主进程加载软件模块后,宿主进程中的多个线程会同时访问该软件模块,也就是使得软件模块是多线程访问。在多线程访问时,如果需要更新该软件模块就会出现不能保证当前没有线程访问该软件模块,为了保证安全避免崩溃,需要重启宿主进程加载更新后的软件模块,也就不能对该软件模块进行热更新。
热更新是指不重启宿主进程,即可以直接加载升级后的软件模块。
而本实施例中,为了实现软件模块的热更新,可以将对软件模块的访问请求进行统一管理,使得访问所述软件模块的线程是单一的。
在统一管理时采用序列化的方式。
可选的,所述对已加载的软件模块的多个访问请求进行序列化处理,包括:
将所述对已加载的软件模块的多个访问请求,依次排列放入预设的缓存位置。
例如,多个访问请求包括:第一访问请求,第二访问请求和第三访问请求,则在序列化时,可以将第一访问请求,第二访问请求和第三访问请求按顺序(如访问请求产生的时间顺序)依次放入缓存中,使得这些访问请求是一一按序排列的,从而得到序列化后的访问请求队列。
S12:由单一的线程依次从所述序列化后的请求队列中读取访问请求。
具体的,参见图3,本实施例中可以在宿主进程中设置热更新模块管理器(HotModuleMgr),热更新模块管理器对访问请求进行统一管理。
其中,在统一管理时,可以将对所述软件模块的访问请求进行序列化并缓存,并由单一的线程执行所述访问请求。
例如,参见图3,宿主进程中不同线程的访问请求可以分别用线程_1(thread_1),线程_2(thread_2)和线程_3(thread_3)表示,热更新模块管理器可以对thread_1,thread_2和thread_3进行序列化并缓存,并由单一的线程thread_dedicated依次执行各个访问请求。S13:当读取的访问请求是所述更新请求时,由所述单一的线程卸载所述软件模块,并重新加载更新后的所述软件模块。
其中,当需要更新时,宿主进程会接收到更新请求,由于更新请求也是一种对软件模块的访问请求,因此热更新模块将该更新请求缓存到序列化队列中,当热更新模块执行到该更新请求后,可以由单一线程执行该更新请求,在执行该更新请求时,卸载更新前的软件模块,并重新加载更新后的软件模块。由于访问软件模块的线程是单一的,因此在卸载软件模块时可以保证没有其他线程访问该软件模块,保证卸载安全,从而实现软件模块的热更新。
本实施例通过对软件模块的多个访问请求进行序列化处理,得到序列化后的请求队列,并由单一的线程依次从序列化后的请求队列中读取访问请求,可以保证在卸载软件模块时不存在其他线程访问该软件模块,由于不会存在多个线程同时访问加载的软件模块,可以在不重启宿主进程的情况下完成软件模块的更新,从而实现软件模块的热更新。
图3是本发明另一实施例提出的软件模块的更新方法的流程示意图,本实施例可以在宿主进程中设置热更新模块管理器,本实施例包括:
S31:宿主进程加载更新前的软件模块。
例如,在宿主进程中设置热更新模块管理器(HotModuleMgr),由热更新模块管理器加载(load)软件模块(Target.dll),软件模块被加载到内存后可以称为模块映像(Target Image)。
S32:热更新模块管理器将宿主进程中不同线程的访问请求序列化并缓存。
例如,参见图3,宿主进程中可以包括线程_1(thread_1),线程_2(thread_2)和线程_3(thread_3),这两个线程要获取(access)加载的软件模块的功能,则热更新模块管理器可以对thread_1和thread_2进行序列化并缓存。
S33:由单一线程依次执行各个访问请求。
例如,热更新模块管理器采用单一线程thread_dedicated访问(access)加载的软件模块。
S34:在需要升级时,升级模块对软件模块进行升级处理。
例如,升级模块(Update Module)用新版本的模块文件替换旧版本的模块文件,实现模块升级(update)。
S35:升级模块通知宿主进程更新软件模块。
例如,升级模块向宿主进程发送通知消息,通知升级软件模块(notify update)。
S36:宿主进程内预设的一个线程向热更新模块管理器发送更新请求。
其中,获取加载的软件模块的功能的请求对应的线程可以称为第一线程,热更新模块管理器的访问加载的软件模块的线程可以称为第二线程,发送更新请求的线程可以称为第三线程。
例如,参见图3,第一线程包括线程1_和线程_2,热更新管理模块访问加载的软件模块的单一线程(thread_dedicated)是第二线程,第三线程是宿主进程内与第一线程和第二线程不同的线程,例如线程_3(thread_3),由第三线程发送更新请求,以通知热更新模块管理器更新加载的模块(notify target update)。
另外,由于热更新模块管理器对访问请求进行序列化,因此,线程_3发送的更新请求也被热更新模块管理器进行排序。
热更新模块管理器可以对访问请求序列化后,可以得到排序后的队列。
S37:热更新模块管理器依次执行队列中的访问请求,当执行到更新请求时,升级加载的软件模块。
例如,队列中依次包括线程_1的获取请求,线程_2的获取请求以及线程_3的更新请求,则执行到更新请求后,热更新模块管理器可以重新加载(reload)软件模块,实现软件模块更新。
本实施例中,由于仅有thread_dedicated单一线程访问加载的软件模块,因此其在卸载模块时可确保没有其他线程访问该软件模块,实现软件模块的热更新。
本实施例通过对软件模块的访问进行统一管理使得访问软件模块的线程是单一的,可以保证在卸载软件模块时不存在其他线程访问该软件模块,从而实现软件模块的热更新。本实施例通过热更新,使得更新的模块可以立即生效,使新功能的部署方便快捷,尤其针对某些缺陷的修复更新,不必等到进程重启,使得补救措施可以立即得到应用,最大程度保证了用户的利益和安全。
图4是本发明另一实施例提出的软件模块的更新装置的结构示意图,该装置40包括管理模块41、读取模块42以及处理模块43。
管理模块41,用于对已加载的软件模块的多个访问请求进行序列化处理,得到序列化后的请求队列,其中,所述多个访问请求包括用于指示对所述软件模块进行更新的更新请求;
参见图5,另一实施例中,该装置40还包括:
加载模块44,用于从宿主进程之外的预设位置加载所述软件模块。
一般软件设计都会将功能模块化,不同功能分别由不同软件模块实现。
在软件运行时,宿主进程可以将软件模块加载到内存中,以调用软件模块实现相应功能。其中,宿主进程也可以称为主进程,加载的软件模块可以具体是指不同版本的模块文件。
软件模块可以进行更新。
初始时,宿主进程可以从宿主进程之外的预设位置加载初始的软件模块。
可选的,所述管理模块41具体用于:
将所述对已加载的软件模块的多个访问请求,依次排列放入预设的缓存位置。
例如,多个访问请求包括:第一访问请求,第二访问请求和第三访问请求,则在序列化时,可以将第一访问请求,第二访问请求和第三访问请求按顺序(如访问请求产生的时间顺序)依次放入缓存中,使得这些访问请求是一一按序排列的,从而得到序列化后的访问请求队列。
读取模块42,用于由单一的线程依次从所述序列化后的请求队列中读取访问请求;
具体的,参见图3,本实施例中可以在宿主进程中设置热更新模块管理器(HotModuleMgr),热更新模块管理器对访问请求进行统一管理。
其中,在统一管理时,可以将对所述软件模块的访问请求进行序列化并缓存,并由单一的线程执行所述访问请求。
例如,参见图3,宿主进程中不同线程的访问请求可以分别用线程_1(thread_1),线程_2(thread_2)和线程_3(thread_3)表示,热更新模块管理器可以对thread_1,thread_2和thread_3进行序列化并缓存,并由单一的线程thread_dedicated依次执行各个访问请求。
处理模块43,用于当读取的访问请求是所述更新请求时,由所述单一的线程卸载所述软件模块,并重新加载更新后的所述软件模块。
其中,当需要更新时,宿主进程会接收到更新请求,由于更新请求也是一种对软件模块的访问请求,因此热更新模块将该更新请求缓存到序列化队列中,当热更新模块执行到该更新请求后,可以由单一线程执行该更新请求,在执行该更新请求时,卸载更新前的软件模块,并重新加载更新后的软件模块。由于访问软件模块的线程是单一的,因此在卸载软件模块时可以保证没有其他线程访问该软件模块,保证卸载安全,从而实现软件模块的热更新。
另一实施例中,参见图5,该装置40还包括:
接收模块45,用于接收所述宿主进程内的第一线程发送的更新请求,所述第一线程发送的更新请求是所述第一线程接收到所述宿主进程之外的升级模块发送的更新请求后发送的,所述升级模块发送的更新请求是所述升级模块对所述软件模块进行更新并保存到所述预设位置后发送的。
可选的,所述访问请求还包括所述宿主进程内的第二线程对所述软件模块的访问请求,所述单一的线程是第三线程,所述第一线程,所述第二线程和所述第三线程互不相同。
本实施例通过对软件模块的多个访问请求进行序列化处理,得到序列化后的请求队列,并由单一的线程依次从序列化后的请求队列中读取访问请求,可以保证在卸载软件模块时不存在其他线程访问该软件模块,由于不会存在多个线程同时访问加载的软件模块,可以在不重启宿主进程的情况下完成软件模块的更新,从而实现软件模块的热更新。
本发明实施例还提供了一种客户端设备,该客户端设备包括壳体、处理器、存储器、电路板和电源电路,其中,电路板安置在壳体围成的空间内部,处理器和存储器设置在电路板上;电源电路,用于为客户端设备的各个电路或器件供电;存储器用于存储可执行程序代码;处理器通过读取存储器中存储的可执行程序代码来运行与可执行程序代码对应的程序,以用于执行:
S11’:对已加载的软件模块的多个访问请求进行序列化处理,得到序列化后的请求队列,其中,所述多个访问请求包括用于指示对所述软件模块进行更新的更新请求。
可选的,所述已加载的软件模块是从宿主进程之外的预设位置加载的。
一般软件设计都会将功能模块化,不同功能分别由不同软件模块实现。
在软件运行时,宿主进程可以将软件模块加载到内存中,以调用软件模块实现相应功能。其中,宿主进程也可以称为主进程,加载的软件模块可以具体是指不同版本的模块文件。
软件模块可以进行更新。
初始时,宿主进程可以从宿主进程之外的预设位置加载初始的软件模块。
本实施例中,为了实现软件模块的热更新,可以将对软件模块的访问请求进行统一管理,使得访问所述软件模块的线程是单一的。
在统一管理时采用序列化的方式。
可选的,所述对已加载的软件模块的多个访问请求进行序列化处理,包括:
将所述对已加载的软件模块的多个访问请求,依次排列放入预设的缓存位置。
例如,多个访问请求包括:第一访问请求,第二访问请求和第三访问请求,则在序列化时,可以将第一访问请求,第二访问请求和第三访问请求按顺序(如访问请求产生的时间顺序)依次放入缓存中,使得这些访问请求是一一按序排列的,从而得到序列化后的访问请求队列。
S12’:由单一的线程依次从所述序列化后的请求队列中读取访问请求。
具体的,参见图3,本实施例中可以在宿主进程中设置热更新模块管理器(HotModuleMgr),热更新模块管理器对访问请求进行统一管理。
其中,在统一管理时,可以将对所述软件模块的访问请求进行序列化并缓存,并由单一的线程执行所述访问请求。
例如,参见图3,宿主进程中不同线程的访问请求可以分别用线程_1(thread_1),线程_2(thread_2)和线程_3(thread_3)表示,热更新模块管理器可以对thread_1,thread_2和thread_3进行序列化并缓存,并由单一的线程thread_dedicated依次执行各个访问请求。
S13’:当读取的访问请求是所述更新请求时,由所述单一的线程卸载所述软件模块,并重新加载更新后的所述软件模块。
其中,当需要更新时,宿主进程会接收到更新请求,由于更新请求也是一种对软件模块的访问请求,因此热更新模块将该更新请求缓存到序列化队列中,当热更新模块执行到该更新请求后,可以由单一线程执行该更新请求,在执行该更新请求时,卸载更新前的软件模块,并重新加载更新后的软件模块。由于访问软件模块的线程是单一的,因此在卸载软件模块时可以保证没有其他线程访问该软件模块,保证卸载安全,从而实现软件模块的热更新。
本实施例通过对软件模块的多个访问请求进行序列化处理,得到序列化后的请求队列,并由单一的线程依次从序列化后的请求队列中读取访问请求,可以保证在卸载软件模块时不存在其他线程访问该软件模块,由于不会存在多个线程同时访问加载的软件模块,可以在不重启宿主进程的情况下完成软件模块的更新,从而实现软件模块的热更新。
另一实施例中,处理器通过读取存储器中存储的可执行程序代码来运行与可执行程序代码对应的程序,以用于执行:
S41’:宿主进程加载更新前的软件模块。
例如,在宿主进程中设置热更新模块管理器(HotModuleMgr),由热更新模块管理器加载(load)软件模块(Target.dll),软件模块被加载到内存后可以称为模块映像(Target Image)。
S42’:热更新模块管理器将宿主进程中不同线程的访问请求序列化并缓存。
例如,参见图3,宿主进程中可以包括线程_1(thread_1),线程_2(thread_2)和线程_3(thread_3),这两个线程要获取(access)加载的软件模块的功能,则热更新模块管理器可以对thread_1和thread_2进行序列化并缓存。
S43’:由单一线程依次执行各个访问请求。
例如,热更新模块管理器采用单一线程thread_dedicated访问(access)加载的软件模块。
S44’:在需要升级时,升级模块对软件模块进行升级处理。
例如,升级模块(Update Module)用新版本的模块文件替换旧版本的模块文件,实现模块升级(update)。
S45’:升级模块通知宿主进程更新软件模块。
例如,升级模块向宿主进程发送通知消息,通知升级软件模块(notify update)。
S46’:宿主进程内预设的一个线程向热更新模块管理器发送更新请求。
其中,获取加载的软件模块的功能的请求对应的线程可以称为第一线程,热更新模块管理器的访问加载的软件模块的线程可以称为第二线程,发送更新请求的线程可以称为第三线程。
例如,参见图3,第一线程包括线程1_和线程_2,热更新管理模块访问加载的软件模块的单一线程(thread_dedicated)是第二线程,第三线程是宿主进程内与第一线程和第二线程不同的线程,例如线程_3(thread_3),由第三线程发送更新请求,以通知热更新模块管理器更新加载的模块(notify target update)。
另外,由于热更新模块管理器对访问请求进行序列化,因此,线程_3发送的更新请求也被热更新模块管理器进行排序。
热更新模块管理器可以对访问请求序列化后,可以得到排序后的队列。
S47’:热更新模块管理器依次执行队列中的访问请求,当执行到更新请求时,升级加载的软件模块。
例如,队列中依次包括线程_1的获取请求,线程_2的获取请求以及线程_3的更新请求,则执行到更新请求后,热更新模块管理器可以重新加载(reload)软件模块,实现软件模块更新。
本实施例中,由于仅有thread_dedicated单一线程访问加载的软件模块,因此其在卸载模块时可确保没有其他线程访问该软件模块,实现软件模块的热更新。
本实施例通过对软件模块的访问进行统一管理使得访问软件模块的线程是单一的,可以保证在卸载软件模块时不存在其他线程访问该软件模块,从而实现软件模块的热更新。本实施例通过热更新,使得更新的模块可以立即生效,使新功能的部署方便快捷,尤其针对某些缺陷的修复更新,不必等到进程重启,使得补救措施可以立即得到应用,最大程度保证了用户的利益和安全。
需要说明的是,在本发明的描述中,术语“第一”、“第二”等仅用于描述目的,而不能理解为指示或暗示相对重要性。此外,在本发明的描述中,除非另有说明,“多个”的含义是两个或两个以上。
流程图中或在此以其他方式描述的任何过程或方法描述可以被理解为,表示包括一个或更多个用于实现特定逻辑功能或过程的步骤的可执行指令的代码的模块、片段或部分,并且本发明的优选实施方式的范围包括另外的实现,其中可以不按所示出或讨论的顺序,包括根据所涉及的功能按基本同时的方式或按相反的顺序,来执行功能,这应被本发明的实施例所属技术领域的技术人员所理解。
应当理解,本发明的各部分可以用硬件、软件、固件或它们的组合来实现。在上述实施方式中,多个步骤或方法可以用存储在存储器中且由合适的指令执行系统执行的软件或固件来实现。例如,如果用硬件来实现,和在另一实施方式中一样,可用本领域公知的下列技术中的任一项或他们的组合来实现:具有用于对数据信号实现逻辑功能的逻辑门电路的离散逻辑电路,具有合适的组合逻辑门电路的专用集成电路,可编程门阵列(PGA),现场可编程门阵列(FPGA)等。
本技术领域的普通技术人员可以理解实现上述实施例方法携带的全部或部分步骤是可以通过程序来指令相关的硬件完成,所述的程序可以存储于一种计算机可读存储介质中,该程序在执行时,包括方法实施例的步骤之一或其组合。
此外,在本发明各个实施例中的各功能单元可以集成在一个处理模块中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个模块中。上述集成的模块既可以采用硬件的形式实现,也可以采用软件功能模块的形式实现。所述集成的模块如果以软件功能模块的形式实现并作为独立的产品销售或使用时,也可以存储在一个计算机可读取存储介质中。
上述提到的存储介质可以是只读存储器,磁盘或光盘等。
在本说明书的描述中,参考术语“一个实施例”、“一些实施例”、“示例”、“具体示例”、或“一些示例”等的描述意指结合该实施例或示例描述的具体特征、结构、材料或者特点包含于本发明的至少一个实施例或示例中。在本说明书中,对上述术语的示意性表述不一定指的是相同的实施例或示例。而且,描述的具体特征、结构、材料或者特点可以在任何的一个或多个实施例或示例中以合适的方式结合。
尽管上面已经示出和描述了本发明的实施例,可以理解的是,上述实施例是示例性的,不能理解为对本发明的限制,本领域的普通技术人员在本发明的范围内可以对上述实施例进行变化、修改、替换和变型。
Claims (10)
1.一种软件模块的更新方法,其特征在于,包括:
加载更新前的软件模块;对已加载的软件模块的多个访问请求进行序列化处理,得到序列化后的请求队列,其中,所述多个访问请求包括用于指示对所述软件模块进行更新的更新请求和获取软件模块的功能的获取请求,所述多个访问请求是从不同的线程接收的;
由单一的线程依次从所述序列化后的请求队列中读取访问请求;
当读取的访问请求是所述更新请求时,由所述单一的线程卸载所述软件模块,并重新加载更新后的所述软件模块,其中,所述更新后的软件模块,是在需要升级时,由宿主进程之外的升级模块对所述软件模块进行更新并保存在预设位置的。
2.根据权利要求1所述的方法,其特征在于,所述已加载的软件模块是从宿主进程之外的预设位置加载的。
3.根据权利要求1所述的方法,其特征在于,所述对已加载的软件模块的多个访问请求进行序列化处理,包括:
将所述对已加载的软件模块的多个访问请求,依次排列放入预设的缓存位置。
4.根据权利要求1所述的方法,其特征在于,所述更新请求是指所述宿主进程内的第一线程发送的更新请求,所述第一线程发送的更新请求是所述第一线程接收到所述宿主进程之外的升级模块发送的更新请求后发送的,所述升级模块发送的更新请求是所述升级模块对所述软件模块进行更新并保存到预设位置后发送的。
5.根据权利要求4所述的方法,其特征在于,所述访问请求还包括所述宿主进程内的第二线程对所述软件模块的访问请求,所述单一的线程是第三线程,所述第一线程,所述第二线程和所述第三线程互不相同。
6.一种软件模块的更新装置,其特征在于,包括:
加载模块,用于加载更新前的软件模块;
管理模块,用于对已加载的软件模块的多个访问请求进行序列化处理,得到序列化后的请求队列,其中,所述多个访问请求包括用于指示对所述软件模块进行更新的更新请求和获取软件模块的功能的获取请求,所述多个访问请求是从不同的线程接收的;
读取模块,用于由单一的线程依次从所述序列化后的请求队列中读取访问请求;
处理模块,用于当读取的访问请求是所述更新请求时,由所述单一的线程卸载所述软件模块,并重新加载更新后的所述软件模块,其中,所述更新后的软件模块,是在需要升级时,由宿主进程之外的升级模块对所述软件模块进行更新并保存在预设位置的。
7.根据权利要求6所述的装置,其特征在于,所述加载模块具体用于:从宿主进程之外的预设位置加载所述软件模块。
8.根据权利要求6所述的装置,其特征在于,所述管理模块具体用于:
将所述对已加载的软件模块的多个访问请求,依次排列放入预设的缓存位置。
9.根据权利要求6所述的装置,其特征在于,所述更新请求是指所述宿主进程内的第一线程发送的更新请求,所述第一线程发送的更新请求是所述第一线程接收到所述宿主进程之外的升级模块发送的更新请求后发送的,所述升级模块发送的更新请求是所述升级模块对所述软件模块进行更新并保存到预设位置后发送的。
10.根据权利要求9所述的装置,其特征在于,所述访问请求还包括所述宿主进程内的第二线程对所述软件模块的访问请求,所述单一的线程是第三线程,所述第一线程,所述第二线程和所述第三线程互不相同。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201510240885.7A CN104899057B (zh) | 2015-05-13 | 2015-05-13 | 软件模块的更新方法和装置 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201510240885.7A CN104899057B (zh) | 2015-05-13 | 2015-05-13 | 软件模块的更新方法和装置 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN104899057A CN104899057A (zh) | 2015-09-09 |
CN104899057B true CN104899057B (zh) | 2018-10-16 |
Family
ID=54031735
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201510240885.7A Active CN104899057B (zh) | 2015-05-13 | 2015-05-13 | 软件模块的更新方法和装置 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN104899057B (zh) |
Families Citing this family (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN106610996B (zh) * | 2015-10-23 | 2022-03-11 | 北京奇虎科技有限公司 | 热词典切换方法和装置 |
CN105389172B (zh) * | 2015-12-07 | 2018-09-14 | 深圳市金锐显数码科技有限公司 | 应用程序升级方法和装置 |
CN107807816A (zh) * | 2016-09-08 | 2018-03-16 | 阿里巴巴集团控股有限公司 | 服务端程序和数据库的升级方法、装置和设备 |
CN107357647A (zh) * | 2017-05-24 | 2017-11-17 | 华为技术有限公司 | 一种组件更新的方法以及相关装置 |
CN110647477B (zh) * | 2018-06-27 | 2022-02-11 | 阿里巴巴(中国)有限公司 | 数据缓存方法、装置、终端以及计算机可读存储介质 |
CN115361435A (zh) * | 2022-07-13 | 2022-11-18 | 阿里巴巴(中国)有限公司 | 数据处理方法 |
Citations (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102081619A (zh) * | 2009-11-26 | 2011-06-01 | 中国移动通信集团公司 | 数据更新方法、分发节点及海量存储集群系统 |
Family Cites Families (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7574706B2 (en) * | 2003-12-15 | 2009-08-11 | Microsoft Corporation | System and method for managing and communicating software updates |
CN102394867A (zh) * | 2011-10-10 | 2012-03-28 | 深圳市金槌拍卖行有限公司 | 网络并发通讯请求转串行队列技术 |
-
2015
- 2015-05-13 CN CN201510240885.7A patent/CN104899057B/zh active Active
Patent Citations (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102081619A (zh) * | 2009-11-26 | 2011-06-01 | 中国移动通信集团公司 | 数据更新方法、分发节点及海量存储集群系统 |
Also Published As
Publication number | Publication date |
---|---|
CN104899057A (zh) | 2015-09-09 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN104899057B (zh) | 软件模块的更新方法和装置 | |
US9772838B2 (en) | Firmware update discovery and distribution | |
JP5911504B2 (ja) | ストリーミング技術に基づくソフトウェア・イメージのアップグレード | |
US7890664B1 (en) | Methods and apparatus for non-disruptive upgrade by redirecting I/O operations | |
US8914785B2 (en) | Providing virtual appliance system firmware images | |
US20100049776A1 (en) | Fat directory structure for use in transaction safe file | |
US20090094450A1 (en) | Firmware image update and management | |
US7693969B2 (en) | Program distributing apparatus and program distributing system | |
US20060190939A1 (en) | Updatable mobile handset based on linux with compression and decompression techniques | |
US20140007067A1 (en) | RESOURCE DATa STRUCTURES FOR FIRMWARE UPDATES | |
TW201510866A (zh) | Uefi bios開機及更新之系統及方法、記錄媒體及電腦程式產品 | |
CN103870301B (zh) | 软件安装方法和设备 | |
JP2007206885A (ja) | コンピュータシステム及びシステム起動方法 | |
EP2765503A1 (en) | Method and electronic device of the file system prefetching and boot-up method | |
US11347494B2 (en) | Installing patches during upgrades | |
US20130258574A1 (en) | Customizable thermal control | |
US10466919B2 (en) | Information handling system with elastic configuration pools in flash dual in-line memory modules | |
CN109213504B (zh) | 一种堆叠式文件系统及其加载方法和升级方法 | |
US20030037323A1 (en) | Method for upgrading data | |
US9870396B2 (en) | Immediate join spilling scheme for a database | |
WO2020107469A1 (zh) | 程序处理方法、设备及存储介质 | |
CN110196730B (zh) | 应用程序的热补丁管理方法、装置和存储介质 | |
US20200364040A1 (en) | System and Method for Restoring a Previously Functional Firmware Image on a Non-Volatile Dual Inline Memory Module | |
US9495250B2 (en) | Providing code to a programmable device | |
TW201512989A (zh) | 韌體更新方法 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
C06 | Publication | ||
PB01 | Publication | ||
C10 | Entry into substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant | ||
GR01 | Patent grant | ||
TR01 | Transfer of patent right | ||
TR01 | Transfer of patent right |
Effective date of registration: 20181211 Address after: 519030 Room 105-53811, No. 6 Baohua Road, Hengqin New District, Zhuhai City, Guangdong Province Patentee after: Zhuhai Leopard Technology Co.,Ltd. Address before: 100085 East District, Second Floor, 33 Xiaoying West Road, Haidian District, Beijing Patentee before: BEIJING KINGSOFT INTERNET SECURITY SOFTWARE Co.,Ltd. |