CN106325931A - 一种软件预部署的方法及装置 - Google Patents
一种软件预部署的方法及装置 Download PDFInfo
- Publication number
- CN106325931A CN106325931A CN201610711473.1A CN201610711473A CN106325931A CN 106325931 A CN106325931 A CN 106325931A CN 201610711473 A CN201610711473 A CN 201610711473A CN 106325931 A CN106325931 A CN 106325931A
- Authority
- CN
- China
- Prior art keywords
- deployment file
- client terminal
- issue client
- service end
- issuing service
- 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
Links
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F8/00—Arrangements for software engineering
- G06F8/60—Software deployment
- G06F8/65—Updates
Landscapes
- Engineering & Computer Science (AREA)
- Software Systems (AREA)
- General Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Computer Security & Cryptography (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Information Transfer Between Computers (AREA)
Abstract
本发明实施例涉及计算机软件领域,尤其是涉及一种软件预部署的方法及装置,用于给发布客户端预先部署软件。本发明实施例中发布服务端监控各部署文件的状态信息,当第一部署文件的状态信息发生变更,确定使用第一部署文件的第一发布客户端,发布服务端向第一发布客户端发送部署文件更新消息,第一发布客户端接收到发布服务端发送的第一部署文件更新消息,第一发布客户端向发布服务端发送第一部署文件的下载请求,第一发布客户端接收发布服务端发送的更新后的第一部署文件,并在更新完第一部署文件后向发布服务端发送更新完成通知;避免了需要创建应用实例时需要下载部署文件,而网络下载速度又较慢的问题,提高了工作效率。
Description
技术领域
本发明涉及计算机软件领域,尤其是涉及一种软件预部署的方法及装置。
背景技术
计算机软件在现代社会经济生活中占有极其重要的地位,在各个领域中发挥着越来越重要的作用。随着技术的发展,通常用户编写软件时都使用发布客户端(包括但不限于docker、rocket等)。用户需要编写软件时,需要先在发布客户端创建应用实例,而创建应用实例的第一个步骤是下载对应的部署文件。
在现有技术中,通常在需要创建应用实例时,用户才通过发布客户端向发布服务端发起下载对应部署文件的请求,下载最新版本的部署文件到本地的文件系统。但是当网络下载速度较慢时,下载部署文件需要的时间非常长,而用户只能等待部署文件下载完成后才能进行下一步的工作,使得用户工作效率降低。
发明内容
本发明提供一种软件预部署的方法及装置,用以解决现有技术中存在的当网络下载速度较慢时,下载部署文件需要的时间过长,使得用户工作效率降低的问题。
本发明方法包括:
发布服务端监控各部署文件的状态信息;
当第一部署文件的状态信息发生变更,确定使用第一部署文件的第一发布客户端,第一部署文件为各部署文件中的任一个,第一部署文件的状态信息是在第一部署文件的内容发生更新时变更的;
发布服务端向第一发布客户端发送部署文件更新消息,以使第一发布客户端更新本地存储的第一部署文件。
可选地,发布服务端向第一发布客户端发送部署文件更新消息之后,还包括:
发布服务端接收第一发布客户端的第一部署文件的下载请求;
发布服务端将更新后的第一部署文件发送给第一发布客户端。
可选地,确定使用第一部署文件的第一发布客户端,包括:
根据发布服务端存储的发布客户端与下载部署文件的对照关系,确定使用第一部署文件的第一发布客户端;
发布服务端将更新后的第一部署文件发送给第一发布客户端之后,还包括:
接收第一发布客户端发送的更新完成通知;
发布服务端将第一发布客户端与更新后的第一部署文件加入发布客户端与下载部署文件的对照关系中。
可选地,发布客户端与下载部署文件的对照关系包括部署文件的名称、部署文件的版本号、部署文件对应的发布客户端编号或部署文件对应的发布客户端的标识。
本发明实施例提供一种软件预部署的方法,包括:
第一发布客户端接收发布服务端发送的第一部署文件更新消息;第一部署文件更新消息是发布服务端的第一部署文件的状态信息发生变更后发送的,第一发布客户端中包含第一部署文件;
第一发布客户端向发布服务端发送第一部署文件的下载请求;
第一发布客户端接收发布服务端发送的更新后的第一部署文件,并在更新完第一部署文件后向发布服务端发送更新完成通知。
本发明实施例提供一种用于软件预部署的发布服务端,包括:
监控模块,用于监控各部署文件的状态信息;
确定模块,用于当第一部署文件的状态信息发生变更,确定使用第一部署文件的第一发布客户端,第一部署文件为各部署文件中的任一个,第一部署文件的状态信息是在第一部署文件的内容发生更新时变更的;
发布模块,用于向第一发布客户端发送部署文件更新消息,以使第一发布客户端更新本地存储的第一部署文件。
可选地,发布服务端还包括下载模块:
下载模块,用于接收第一发布客户端的第一部署文件的下载请求;将更新后的第一部署文件发送给第一发布客户端。
可选地,发布服务端还包括接收模块,
确定模块,具体用于根据发布服务端存储的发布客户端与下载部署文件的对照关系,确定使用第一部署文件的第一发布客户端;
接收模块,用于接收第一发布客户端发送的更新完成通知;
确定模块,还用于在接收到第一发布客户端发送的更新完成通知后,将第一发布客户端与更新后的第一部署文件加入发布客户端与下载部署文件的对照关系中。
可选地,发布客户端与下载部署文件的对照关系包括部署文件的名称、部署文件的版本号、部署文件对应的发布客户端编号或部署文件对应的发布客户端的标识。
本发明实施例提供一种用于软件预部署的发布客户端,包括:
接收模块,用于接收发布服务端发送的第一部署文件更新消息;第一部署文件更新消息是发布服务端的第一部署文件的状态信息发生变更后发送的,发布客户端中包含第一部署文件;
发送模块,用于向发布服务端发送第一部署文件的下载请求;
接收模块,还用于接收发布服务端发送的更新后的第一部署文件;发送模块,还用于在更新完第一部署文件后向发布服务端发送更新完成通知。
本发明实施例中发布服务端监控各部署文件的状态信息;当第一部署文件的状态信息发生变更,确定使用所述第一部署文件的第一发布客户端,所述第一部署文件为所述各部署文件中的任一个,所述第一部署文件的状态信息是在所述第一部署文件的内容发生更新时变更的;所述发布服务端向所述第一发布客户端发送部署文件更新消息,以使所述第一发布客户端更新本地存储的所述第一部署文件;与现有技术相比,发布服务端实时监控部署文件的更新情况,如第一部署文件目前版本为V1,在第一部署文件更新时(变为版本V2),确定已下载第一部署文件的发布客户端;通知已下载第一部署文件的发布客户端部署文件更新消息,以使发布客户端预先下载第一部署文件的更新版本,避免了当用户需要创建应用实例时需要下载部署文件,而网络下载速度又较慢的问题,提高了用户的工作效率。
附图说明
为了更清楚地说明本发明实施例中的技术方案,下面将对实施例描述中所需要使用的附图作简要介绍,显而易见地,下面描述中的附图仅仅是本发明的一些实施例,对于本领域的普通技术人员来讲,在不付出创造性劳动性的前提下,还可以根据这些附图获得其他的附图。
图1为本发明实施例提供了一种系统架构示意图;
图2为本发明实施例提供的一种实现软件预部署发布服务端的方法流程示意图;
图3为本发明实施例提供的一种实现软件预部署发布客户端的方法流程示意图;
图4为本发明实施例提供的一种实现软件预部署的方法流程示意图;
图5为本发明实施例提供的一种实现软件预部署的发布服务端的结构示意图;
图6为本发明实施例提供的一种实现软件预部署的发布客户端的结构示意图。
具体实施方式
为了使本发明的目的、技术方案及有益效果更加清楚明白,以下结合附图及实施例,对本发明进行进一步详细说明。应当理解,此处所描述的具体实施例仅仅用以解释本发明,并不用于限定本发明。
图1示例性示出了本发明实施例适用的一种系统架构示意图,如图1所示,本发明实施例适用的系统架构包括发布服务端101,以及发布客户端A102、发布客户端B103、发布客户端C104和发布客户端D105。
发布服务端101是安装于为终端提供计算或存储服务的服务器上的代理服务端,所述为终端提供计算或存储服务的设备包括但不限于文件服务器、Docker hub等。
发布客户端A102、发布客户端B103、发布客户端C104和发布客户端D105是包含于用户设备上的编写应用程序的软件的代理客户端,所述软件包括但不限于docker、rocket、脚本等;用户设备可以包括应用服务器,电脑,笔记本电脑,平板电脑或者其他移动式智能硬件,通过无线或有线网络与服务器连接。
图2为本发明实施例提供的一种实现软件预部署发布服务端的实施方法流程示意图。如图2所示,包括以下步骤:
步骤201:发布服务端监控各部署文件的状态信息;
步骤202:发布服务端监控到第一部署文件的状态信息发生变更,确定使用所述第一部署文件的第一发布客户端;所述第一部署文件为所述各部署文件中的任一个,所述第一部署文件的状态信息是在所述第一部署文件的内容发生更新时变更的;
步骤203:所述发布服务端向所述第一发布客户端发送部署文件更新消息,以使所述第一发布客户端更新本地存储的所述第一部署文件。
步骤201中,发布服务端可以周期性监控各部署文件的状态信息,或者是设定进程监控各部署文件,通常,当部署文件发生更新时,部署文件对应的日志会记录其更新信息,该进程可通过读取日志获知部署文件的状态信息发生变更。
步骤202中,发布服务端在第一部署文件的状态信息发生变更之后,确定使用所述第一部署文件的第一发布客户端,其中使用第一部署文件的第一发布客户端是指曾经在发布服务端上下载过第一部署文件的发布客户端,具体的,发布服务端根据存储的发布客户端与下载部署文件的对照关系,确定使用所述第一部署文件的第一发布客户端,根据对照关系可以快速准确地确定出要更新第一部署文件的第一发布客户端,及时向第一发布客户端发送更新消息。
步骤203中,通过发布服务端向发布客户端发送部署文件更新消息,以触发发布客户端下载更新后的部署文件;此处,发布服务端并不直接下发布客户端发送更新的部署文件,以防发布客户端不在线。
通过上述实施例中,发布服务端中在监控到第一部署文件的状态信息发生变更之后,发布服务端发送更新消息给发布客户端,从而使得发布客户端预先下载第一部署文件,避免了当用户需要创建应用实例时需要下载部署文件,而网络下载速度又较慢的问题,提高了用户的工作效率。
可选的,在步骤203之后,所述发布服务端接收所述第一发布客户端的所述第一部署文件的下载请求;所述发布服务端将更新后的第一部署文件发送给所述第一发布客户端;发布服务端接收到请求之后再发送更新后的第一部署文件可以保证成功发送更新后的第一部署文件。
可选的,接收所述第一发布客户端发送的更新完成通知后,所述发布服务端将所述第一发布客户端与所述更新后的第一部署文件加入所述发布客户端与下载部署文件的对照关系中,从而确保对各发布客户端中使用的部署文件的准确性;
可选的,所述发布客户端与下载部署文件的对照关系包括部署文件的名称、部署文件的版本号、部署文件对应的发布客户端编号或部署文件对应的发布客户端的标识;所述对照关系可以让发布服务端快速准确地确定第一发布客户端及其地址。其中,客户端的标识可以是IP(Internet Protocol,网络之间互连的协议)地址,也可以是域名等网络身份标识。
图3为本发明实施例提供的一种实现软件预部署发布客户端的实施方法流程示意图;
步骤301:第一发布客户端接收发布服务端发送的第一部署文件更新消息;所述第一部署文件更新消息是所述发布服务端的第一部署文件的状态信息发生变更后发送的,所述第一发布客户端中包含所述第一部署文件;
步骤302:所述第一发布客户端向所述发布服务端发送所述第一部署文件的下载请求;
步骤303:所述第一发布客户端接收所述发布服务端发送的更新后的第一部署文件,并在更新完所述第一部署文件后向所述发布服务端发送更新完成通知。
图4为本发明实施例提供的另一种实现软件预部署的方法的流程示意图。如图4所示,包括以下步骤:
步骤401中:发布服务端监控各部署文件的状态信息;发布服务端中存储有各部署文件对应的发布客户端与下载部署文件的对照关系,即若第一发布客户端下载部署文件a,则发布客户端与下载部署文件的对照关系中会记录第一发布客户端与部署文件2的信息,同时包括了发布客户端的编号或IP地址,便于发布服务端向发布客服端发送部署文件更新消息;
步骤402中:发布服务端监控到第一部署文件的状态信息发生变更,确定使用所述第一部署文件的第一发布客户端;所述第一部署文件为所述各部署文件中的任一个,所述第一部署文件的状态信息是在所述第一部署文件的内容发生更新时变更的;
步骤403中:所述发布服务端向所述第一发布客户端发送部署文件更新消息;
步骤404中:第一发布客户端接收发布服务端发送的第一部署文件更新消息;
步骤405中:第一发布客户端向所述发布服务端发送所述第一部署文件的下载请求;所述第一部署文件更新消息是所述发布服务端的第一部署文件的状态信息发生变更后发送的,所述第一发布客户端中包含所述第一部署文件;
步骤406中:发布服务端接收所述第一发布客户端的所述第一部署文件的下载请求;
步骤407中:发布服务端将更新后的第一部署文件发送给所述第一发布客户端;
步骤408中:所述第一发布客户端接收所述发布服务端发送的更新后的第一部署文件
步骤409中:更新完所述第一部署文件后向所述发布服务端发送更新完成通知;
步骤410中:根据更新后的第一部署文件和第一发布客户端,更新发布客户端与下载部署文件的对照关系。
本发明实施例中发布服务端是根据发布客户端与下载部署文件的对照关系来确定使用所述第一部署文件的第一发布客户端,发布客户端与下载部署文件的对照关系包括部署文件的名称、部署文件的版本号、部署文件对应的发布客户端编号或部署文件对应的发布客户端的标识。
本发明实施例中,发布服务端中第一部署文件发生变更之后,发布服务端发送更新消息给发布客户端,从而发布客户端预先下载第一部署文件,避免了当用户需要创建应用实例时需要下载部署文件,而网络下载速度又较慢的问题,提高了用户的工作效率。
本发明实施例提供一种软件预部署的示例,例如,发布服务端中储存有多个部署文件,比如,部署文件1、部署文件2、部署文件3,发布客户端A、B、C、D与发布服务端相连,发布客户端A、B、C、D分别使用部署文件1、部署文件2、部署文件3、部署文件3,各部署文件此时的版本号此时均为V1,发布服务端中记录有发布客户端以及与下载部署文件的对照关系,如表1所示。
表1 更新前发布客户端与下载部署文件的对照关系
当发布服务端存储的部署文件3发生更新,部署文件3的版本号由V1改成V2,发布服务端监控到部署文件3的更新,发布服务端更新部署文件3的状态信息以及发布服务端存储的发布客户端与下载部署文件的对照关系,如表2所示;发布服务端根据获取的发布服务端存储的下载部署文件3与发布客户端的对照关系确定发布客户端C和发布客户端D为需要更新的发布客户端,发布服务端向发布客户端C和发布客户端D发送部署文件3的更新消息,通知发布客户端C和发布客户端D更新原有的部署文件3。
针对发布客户端C和发布客户端D,设定下载状态监控表,如表2所示,从而确保对各发布客户端已下载部署文件信息的准确性。可选的,本发明实施例中可在发布客户端与下载部署文件的对照关系中增加一栏来实现下载状态监控,如下表3所示
表2 下载状态监控表
IP地址 | 版本号 | 部署文件 | 是否完成 | |
发布客户端C | xxx.xxx.xxx.3 | V2 | 3 | 否 |
发布客户端D | xxx.xxx.xxx.4 | V2 | 3 | 否 |
表3 含下载状态监控信息的发布客户端与下载部署文件的对照关系
当发布客户端C和发布客户端D都在线时,发布客户端C和发布客户端D接收到发布服务端发送的更新消息之后,自动向发布服务端发送更新部署文件3的更新请求;发布服务端接收到发布客户端C和发布客户端D的更新请求之后,发布服务端分别与发布客户端C和发布客户端D建立链接,然后分别向发布客户端C和发布客户端D发送更新之后的部署文件3;发布客户端C和发布客户端D开始接收发布服务端发送的更新后的部署文件3,接收时间的长短会由于网络传输速度的快慢而不同;当发布客户端C接收完更新后的部署文件3之后,发布客户端C向发布客户端发送更新完成的状态通知,发布服务端接收到发布客户端C发送的更新完成状态通知,发布服务端将发布客户端C与更新后的部署文件3加入发布客户端C与部署文件的对照关系中,如表4所示;当发布客户端D接收完更新后的部署文件3之后,发布客户端D向发布客户端发送更新完成的状态通知,发布服务端接收到发布客户端D发送的更新完成状态通知,发布服务端将发布客户端D与更新后的部署文件3加入发布客户端D与部署文件的对照关系中,如表5所示;
表4 发布客户端C更新完成后发布客户端与下载部署文件的对照关系
IP地址 | 版本号 | 部署文件 | 是否完成 | |
发布客户端A | xxx.xxx.xxx.1 | V1 | 1 | 是 |
发布客户端B | xxx.xxx.xxx.2 | V1 | 2 | 是 |
发布客户端C | xxx.xxx.xxx.3 | V1 | 3 | 是 |
发布客户端D | xxx.xxx.xxx.4 | V1 | 3 | 是 |
发布客户端C | xxx.xxx.xxx.3 | V2 | 3 | 是 |
发布客户端D | xxx.xxx.xxx.4 | V2 | 3 | 否 |
表5 发布客户端D更新完成后发布客户端与下载部署文件的对照关系
IP地址 | 版本号 | 部署文件 | 是否完成 | |
发布客户端A | xxx.xxx.xxx.1 | V1 | 1 | 是 |
发布客户端B | xxx.xxx.xxx.2 | V1 | 2 | 是 |
发布客户端C | xxx.xxx.xxx.3 | V1 | 3 | 是 |
发布客户端D | xxx.xxx.xxx.4 | V1 | 3 | 是 |
发布客户端C | xxx.xxx.xxx.3 | V2 | 3 | 是 |
发布客户端D | xxx.xxx.xxx.4 | V2 | 3 | 是 |
当发布客户端C在线,而发布客户端D不在线时,发布客户端C接收到发布服务端发送的更新消息之后,自动向发布服务端发送更新部署文件3的更新请求;发布服务端接收到发布客户端C的更新请求之后,发布服务端与发布客户端C建立链接,然后向发布客户端C发送更新之后的部署文件3;发布客户端C开始接收发布服务端发送的更新后的部署文件3,接收时间的长短会由于网络传输速度的快慢而不同;当发布客户端C接收完更新后的部署文件3之后,发布客户端C向发布客户端发送更新完成的状态通知,发布服务端接收到发布客户端C发送的更新完成状态通知,发布服务端将发布客户端C与更新后的部署文件3加入发布客户端C与部署文件的对照关系中,如表6所示;
表6 发布客户端C更新完成后发布客户端与下载部署文件的对照关系
发布服务端在第一预设时间段内未接收到发布客户端D发送的更新部署文件3的更新请求,则以固定的周期向发布客户端D发送更新消息,直到收到发布客户端D发送的更新部署文件3的更新请求,所述固定周期可以人为设定。可选的,若发布服务端在超过第一预设时间段仍未收到发布客户端D的更新部署文件3的更新请求时,可以不再向发布客户端D发送部署文件更新消息,从而减少对网络的无效使用。发布服务端接收到发布客户端D的更新请求之后,发布服务端与发布客户端D建立链接,然后向发布客户端D发送更新之后的部署文件3;发布客户端D开始接收发布服务端发送的更新后的部署文件D,接收时间的长短会由于网络传输速度的快慢而不同;当发布客户端D接收完更新后的部署文件3之后,发布客户端D向发布客户端发送更新完成的状态通知,发布服务端接收到发布客户端D发送的更新完成状态通知,发布服务端将发布客户端D与更新后的部署文件3加入发布客户端D与部署文件的对照关系中,如表7所示;
表7 发布客户端D更新完成后发布客户端与下载部署文件的对照关系
IP地址 | 版本号 | 部署文件 | 是否完成 | |
发布客户端A | xxx.xxx.xxx.1 | V1 | 1 | 是 |
发布客户端B | xxx.xxx.xxx.2 | V1 | 2 | 是 |
发布客户端C | xxx.xxx.xxx.3 | V1 | 3 | 是 |
发布客户端D | xxx.xxx.xxx.4 | V1 | 3 | 是 |
发布客户端C | xxx.xxx.xxx.3 | V2 | 3 | 是 |
发布客户端D | xxx.xxx.xxx.4 | V2 | 3 | 是 |
本发明实施例提供另一种软件预部署的示例,例如,发布服务端中储存有多个部署文件,比如,部署文件1、部署文件2、部署文件3,发布客户端A、B、C、D与发布服务端相连,发布客户端A、B、C、D分别使用部署文件1、部署文件2、部署文件3、部署文件3,各部署文件此时的版本号此时均为V1,发布服务端中记录有发布客户端以及与下载部署文件的对照关系,如表8所示。
表8 更新前发布客户端与下载部署文件的对照关系
IP地址 | 版本号 | 部署文件 | 是否完成 | |
发布客户端A | xxx.xxx.xxx.1 | V1 | 1 | 是 |
发布客户端B | xxx.xxx.xxx.2 | V1 | 2 | 是 |
发布客户端C | xxx.xxx.xxx.3 | V1 | 3 | 是 |
发布客户端D | xxx.xxx.xxx.4 | V1 | 3 | 是 |
发布客户端启动时告知发布服务端在线状态,发布服务端记录所述发布客户端在线状态。当发布服务端存储的部署文件3发生更新,部署文件3的版本号由V1改成V2,发布服务端监控到部署文件3的更新,发布服务端更新部署文件3的状态信息以及发布服务端存储的发布客户端与下载部署文件的对照关系,如表10所示;发布服务端根据获取的发布服务端存储的下载部署文件3与发布客户端的对照关系确定发布客户端C和发布客户端D为需要更新的发布客户端,发布服务端根据记录的发布客户端C和发布客户端D在线状态判断是否向发布客户端C或发布客户端D发送部署文件3的更新消息。
如果所述发布服务端记录所述发布客户端在线状态显示,发布客户端C和发布客户端D均在线,发布服务端向发布客户端C和发布客户端D发送部署文件3的更新消息,通知发布客户端C和发布客户端D更新原有的部署文件3。
针对发布客户端C和发布客户端D,设定下载状态监控表,如表9所示,从而确保对各发布客户端已下载部署文件信息的准确性。可选的,本发明实施例中可在发布客户端与下载部署文件的对照关系中增加一栏来实现下载状态监控,如下表10所示
表9 下载状态监控表
IP地址 | 版本号 | 部署文件 | 是否完成 | |
发布客户端C | xxx.xxx.xxx.3 | V2 | 3 | 否 |
发布客户端D | xxx.xxx.xxx.4 | V2 | 3 | 否 |
表10 含下载状态监控信息的发布客户端与下载部署文件的对照关系
IP地址 | 版本号 | 部署文件 | 是否完成 | |
发布客户端A | xxx.xxx.xxx.1 | V1 | 1 | 是 |
发布客户端B | xxx.xxx.xxx.2 | V1 | 2 | 是 |
发布客户端C | xxx.xxx.xxx.3 | V1 | 3 | 是 |
发布客户端D | xxx.xxx.xxx.4 | V1 | 3 | 是 |
发布客户端C | xxx.xxx.xxx.3 | V2 | 3 | 否 |
发布客户端D | xxx.xxx.xxx.4 | V2 | 3 | 否 |
当发布客户端C和发布客户端D都在线时,发布客户端C和发布客户端D接收到发布服务端发送的更新消息之后,自动向发布服务端发送更新部署文件3的更新请求;发布服务端接收到发布客户端C和发布客户端D的更新请求之后,发布服务端分别与发布客户端C和发布客户端D建立链接,然后分别向发布客户端C和发布客户端D发送更新之后的部署文件3;发布客户端C和发布客户端D开始接收发布服务端发送的更新后的部署文件3,接收时间的长短会由于网络传输速度的快慢而不同;当发布客户端C接收完更新后的部署文件3之后,发布客户端C向发布客户端发送更新完成的状态通知,发布服务端接收到发布客户端C发送的更新完成状态通知,发布服务端将发布客户端C与更新后的部署文件3加入发布客户端C与部署文件的对照关系中,如表11所示;当发布客户端D接收完更新后的部署文件3之后,发布客户端D向发布客户端发送更新完成的状态通知,发布服务端接收到发布客户端D发送的更新完成状态通知,发布服务端将发布客户端D与更新后的部署文件3加入发布客户端D与部署文件的对照关系中,如表12所示;
表11 发布客户端C更新完成后发布客户端与下载部署文件的对照关系
IP地址 | 版本号 | 部署文件 | 是否完成 | |
发布客户端A | xxx.xxx.xxx.1 | V1 | 1 | 是 |
发布客户端B | xxx.xxx.xxx.2 | V1 | 2 | 是 |
发布客户端C | xxx.xxx.xxx.3 | V1 | 3 | 是 |
发布客户端D | xxx.xxx.xxx.4 | V1 | 3 | 是 |
发布客户端C | xxx.xxx.xxx.3 | V2 | 3 | 是 |
发布客户端D | xxx.xxx.xxx.4 | V2 | 3 | 否 |
表12 发布客户端D更新完成后发布客户端与下载部署文件的对照关系
IP地址 | 版本号 | 部署文件 | 是否完成 | |
发布客户端A | xxx.xxx.xxx.1 | V1 | 1 | 是 |
发布客户端B | xxx.xxx.xxx.2 | V1 | 2 | 是 |
发布客户端C | xxx.xxx.xxx.3 | V1 | 3 | 是 |
发布客户端D | xxx.xxx.xxx.4 | V1 | 3 | 是 |
发布客户端C | xxx.xxx.xxx.3 | V2 | 3 | 是 |
发布客户端D | xxx.xxx.xxx.4 | V2 | 3 | 是 |
如果所述发布服务端记录所述发布客户端在线状态显示,发布客户端C在线,而发布客户端D不在线时,发布客户端C接收到发布服务端发送的更新消息之后,自动向发布服务端发送更新部署文件3的更新请求;发布服务端接收到发布客户端C的更新请求之后,发布服务端与发布客户端C建立链接,然后向发布客户端C发送更新之后的部署文件3;发布客户端C开始接收发布服务端发送的更新后的部署文件3,接收时间的长短会由于网络传输速度的快慢而不同;当发布客户端C接收完更新后的部署文件3之后,发布客户端C向发布客户端发送更新完成的状态通知,发布服务端接收到发布客户端C发送的更新完成状态通知,发布服务端将发布客户端C与更新后的部署文件3加入发布客户端C与部署文件的对照关系中,如表13所示;
表13 发布客户端C更新完成后发布客户端与下载部署文件的对照关系
IP地址 | 版本号 | 部署文件 | 是否完成 | |
发布客户端A | xxx.xxx.xxx.1 | V1 | 1 | 是 |
发布客户端B | xxx.xxx.xxx.2 | V1 | 2 | 是 |
发布客户端C | xxx.xxx.xxx.3 | V1 | 3 | 是 |
发布客户端D | xxx.xxx.xxx.4 | V1 | 3 | 是 |
发布客户端C | xxx.xxx.xxx.3 | V2 | 3 | 是 |
发布客户端D | xxx.xxx.xxx.4 | V2 | 3 | 否 |
当发布客户端D上线时,发布服务端更新布客户端D的在线状态,此时发布服务端向发布客户端D发送更新消息,发布客户端D接收到发布服务端发送的更新消息之后,自动向发布服务端发送更新部署文件3的更新请求,发布服务端接收到发布客户端D的更新请求之后,发布服务端与发布客户端D建立链接,然后向发布客户端D发送更新之后的部署文件3;发布客户端D开始接收发布服务端发送的更新后的部署文件D,接收时间的长短会由于网络传输速度的快慢而不同;当发布客户端D接收完更新后的部署文件3之后,发布客户端D向发布客户端发送更新完成的状态通知,发布服务端接收到发布客户端D发送的更新完成状态通知,发布服务端将发布客户端D与更新后的部署文件3加入发布客户端D与部署文件的对照关系中,如表14所示;
表14 发布客户端D更新完成后发布客户端与下载部署文件的对照关系
本发明上述实施例中,发布服务端监控各部署文件的状态信息;当第一部署文件的状态信息发生变更,确定使用所述第一部署文件的第一发布客户端;所述发布服务端向所述第一发布客户端发送部署文件更新消息,第一发布客户端接收发布服务端发送的第一部署文件更新消息;第一发布客户端向发布服务端发送下载请求;发布服务端向第一发布客户端发送更新后的第一部署文件,第一发布客户端接收发布服务端发送的更新后的第一部署文件;
本发明实施例中,当第一部署文件的状态信息发生变更,发布服务端向第一发布客户端发送部署文件更新消息,第一发布客户端向发布服务端发送下载请求,开始下载更新后的第一部署文件,发布客户端预先下载第一部署文件,避免了当用户需要创建应用实例时需要下载部署文件,而网络下载速度又较慢的问题,提高了用户的工作效率。
针对上述方法流程,本发明实施例还提供一种软件预部署装置,该软件预部署装置的具体内容可以参照上述方法实施。
基于相同构思,图5为本发明实施例提供的一种软件预部署装置的发布服务端结构示意图。如图5所示,该软件预部署装置包括:
监控模块501,用于监控各部署文件的状态信息;
确定模块502,用于当第一部署文件的状态信息发生变更,确定使用所述第一部署文件的第一发布客户端,所述第一部署文件为所述各部署文件中的任一个,所述第一部署文件的状态信息是在所述第一部署文件的内容发生更新时变更的;
发布模块503,用于向所述第一发布客户端发送部署文件更新消息,以使所述第一发布客户端更新本地存储的所述第一部署文件。
下载模块504:用于接收所述第一发布客户端的所述第一部署文件的下载请求;将更新后的第一部署文件发送给所述第一发布客户端。
接收模块505,用于接收所述第一发布客户端发送的更新完成通知。
较佳地,所述确定模块,具体用于根据所述发布服务端存储的发布客户端与下载部署文件的对照关系,确定使用所述第一部署文件的第一发布客户端;在接收到所述第一发布客户端发送的更新完成通知后,将所述第一发布客户端与所述更新后的第一部署文件加入所述发布客户端与下载部署文件的对照关系中。
较佳地,所述发布客户端与下载部署文件的对照关系包括部署文件的名称、部署文件的版本号、部署文件对应的发布客户端编号或部署文件对应的发布客户端的标识。
基于相同构思,图6为本发明实施例提供的一种软件预部署装置的发布客户端结构示意图。如图6所示,该软件预部署装置的发布客户端包括:
接收模块601,用于接收发布服务端发送的第一部署文件更新消息;所述第一部署文件更新消息是所述发布服务端的第一部署文件的状态信息发生变更后发送的,所述发布客户端中包含所述第一部署文件;接收所述发布服务端发送的更新后的第一部署文件;
发送模块602,用于向所述发布服务端发送所述第一部署文件的下载请求;在更新完所述第一部署文件后向所述发布服务端发送更新完成通知。
本领域内的技术人员应明白,本发明的实施例可提供为方法、或计算机程序产品。因此,本发明可采用完全硬件实施例、完全软件实施例、或结合软件和硬件方面的实施例的形式。而且,本发明可采用在一个或多个其中包含有计算机可用程序代码的计算机可用存储介质(包括但不限于磁盘存储器、CD-ROM、光学存储器等)上实施的计算机程序产品的形式。
本发明是参照根据本发明实施例的方法、设备(系统)、和计算机程序产品的流程图和/或方框图来描述的。应理解可由计算机程序指令实现流程图和/或方框图中的每一流程和/或方框、以及流程图和/或方框图中的流程和/或方框的结合。可提供这些计算机程序指令到通用计算机、专用计算机、嵌入式处理机或其他可编程数据处理设备的处理器以产生一个机器,使得通过计算机或其他可编程数据处理设备的处理器执行的指令产生用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的装置。
这些计算机程序指令也可存储在能引导计算机或其他可编程数据处理设备以特定方式工作的计算机可读存储器中,使得存储在该计算机可读存储器中的指令产生包括指令装置的制造品,该指令装置实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能。
这些计算机程序指令也可装载到计算机或其他可编程数据处理设备上,使得在计算机或其他可编程设备上执行一系列操作步骤以产生计算机实现的处理,从而在计算机或其他可编程设备上执行的指令提供用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的步骤。
尽管已描述了本发明的优选实施例,但本领域内的技术人员一旦得知了基本创造性概念,则可对这些实施例作出另外的变更和修改。所以,所附权利要求意欲解释为包括优选实施例以及落入本发明范围的所有变更和修改。
显然,本领域的技术人员可以对本发明进行各种改动和变型而不脱离本发明的精神和范围。这样,倘若本发明的这些修改和变型属于本发明权利要求及其等同技术的范围之内,则本发明也意图包含这些改动和变型在内。
Claims (10)
1.一种软件预部署的方法,其特征在于,
发布服务端监控各部署文件的状态信息;
当第一部署文件的状态信息发生变更,确定使用所述第一部署文件的第一发布客户端,所述第一部署文件为所述各部署文件中的任一个,所述第一部署文件的状态信息是在所述第一部署文件的内容发生更新时变更的;
所述发布服务端向所述第一发布客户端发送部署文件更新消息,以使所述第一发布客户端更新本地存储的所述第一部署文件。
2.如权利要求1所述的方法,其特征在于,所述发布服务端向所述第一发布客户端发送部署文件更新消息之后,还包括:
所述发布服务端接收所述第一发布客户端的所述第一部署文件的下载请求;
所述发布服务端将更新后的第一部署文件发送给所述第一发布客户端。
3.如权利要求2所述的方法,其特征在于,
所述确定使用所述第一部署文件的第一发布客户端,包括:
根据所述发布服务端存储的发布客户端与下载部署文件的对照关系,确定使用所述第一部署文件的第一发布客户端;
所述发布服务端将更新后的第一部署文件发送给所述第一发布客户端之后,还包括:
接收所述第一发布客户端发送的更新完成通知;
所述发布服务端将所述第一发布客户端与所述更新后的第一部署文件加入所述发布客户端与下载部署文件的对照关系中。
4.如权利要求3所述的方法,其特征在于,所述发布客户端与下载部署文件的对照关系包括部署文件的名称、部署文件的版本号、部署文件对应的发布客户端编号或部署文件对应的发布客户端的标识。
5.一种软件预部署的方法,其特征在于,包括:
第一发布客户端接收发布服务端发送的第一部署文件更新消息;所述第一部署文件更新消息是所述发布服务端的第一部署文件的状态信息发生变更后发送的,所述第一发布客户端中包含所述第一部署文件;
所述第一发布客户端向所述发布服务端发送所述第一部署文件的下载请求;
所述第一发布客户端接收所述发布服务端发送的更新后的第一部署文件,并在更新完所述第一部署文件后向所述发布服务端发送更新完成通知。
6.一种用于软件预部署的发布服务端,其特征在于,包括:
监控模块,用于监控各部署文件的状态信息;
确定模块,用于当第一部署文件的状态信息发生变更,确定使用所述第一部署文件的第一发布客户端,所述第一部署文件为所述各部署文件中的任一个,所述第一部署文件的状态信息是在所述第一部署文件的内容发生更新时变更的;
发布模块,用于向所述第一发布客户端发送部署文件更新消息,以使所述第一发布客户端更新本地存储的所述第一部署文件。
7.如权利要求6所述的发布服务端,其特征在于,还包括下载模块:
所述下载模块,用于接收所述第一发布客户端的所述第一部署文件的下载请求;将更新后的第一部署文件发送给所述第一发布客户端。
8.如权利要求7所述的发布服务端,其特征在于,还包括接收模块,
所述确定模块,具体用于根据所述发布服务端存储的发布客户端与下载部署文件的对照关系,确定使用所述第一部署文件的第一发布客户端;
所述接收模块,用于接收所述第一发布客户端发送的更新完成通知;
所述确定模块,还用于在接收到所述第一发布客户端发送的更新完成通知后,将所述第一发布客户端与所述更新后的第一部署文件加入所述发布客户端与下载部署文件的对照关系中。
9.如权利要求8所述的发布服务端,其特征在于,所述发布客户端与下载部署文件的对照关系包括部署文件的名称、部署文件的版本号、部署文件对应的发布客户端编号或部署文件对应的发布客户端的标识。
10.一种用于软件预部署的发布客户端,其特征在于,包括:
接收模块,用于接收发布服务端发送的第一部署文件更新消息;所述第一部署文件更新消息是所述发布服务端的第一部署文件的状态信息发生变更后发送的,所述发布客户端中包含所述第一部署文件;
发送模块,用于向所述发布服务端发送所述第一部署文件的下载请求;
所述接收模块,还用于接收所述发布服务端发送的更新后的第一部署文件;所述发送模块,还用于在更新完所述第一部署文件后向所述发布服务端发送更新完成通知。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201610711473.1A CN106325931A (zh) | 2016-08-23 | 2016-08-23 | 一种软件预部署的方法及装置 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201610711473.1A CN106325931A (zh) | 2016-08-23 | 2016-08-23 | 一种软件预部署的方法及装置 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN106325931A true CN106325931A (zh) | 2017-01-11 |
Family
ID=57742487
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201610711473.1A Pending CN106325931A (zh) | 2016-08-23 | 2016-08-23 | 一种软件预部署的方法及装置 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN106325931A (zh) |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN111722945A (zh) * | 2020-06-22 | 2020-09-29 | 重庆忽米网络科技有限公司 | 一种基于中间件实现的工业互联网应用系统及实现方法 |
CN111931103A (zh) * | 2020-07-09 | 2020-11-13 | 北京皮尔布莱尼软件有限公司 | 一种网站部署方法 |
Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2010134702A (ja) * | 2008-12-04 | 2010-06-17 | Nec Corp | 情報処理システム、サービス提供方法、装置及びプログラム |
CN102315954A (zh) * | 2010-07-02 | 2012-01-11 | 无锡华润上华半导体有限公司 | 客户端软件更新管理系统 |
CN103034690A (zh) * | 2012-11-28 | 2013-04-10 | 华南理工大学 | 一种基于web服务的移动客户端应用程序自定制方法 |
CN104615466A (zh) * | 2015-02-05 | 2015-05-13 | 广州亦云信息技术有限公司 | 一种云平台部署方法和系统 |
CN105208081A (zh) * | 2015-08-14 | 2015-12-30 | 深圳联友科技有限公司 | 一种通过订阅方式实现网络通信的方法和系统 |
CN105491161A (zh) * | 2016-01-19 | 2016-04-13 | 深圳市沃特玛电池有限公司 | 一种电池管理系统软件的远程升级系统及其远程升级方法 |
-
2016
- 2016-08-23 CN CN201610711473.1A patent/CN106325931A/zh active Pending
Patent Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2010134702A (ja) * | 2008-12-04 | 2010-06-17 | Nec Corp | 情報処理システム、サービス提供方法、装置及びプログラム |
CN102315954A (zh) * | 2010-07-02 | 2012-01-11 | 无锡华润上华半导体有限公司 | 客户端软件更新管理系统 |
CN103034690A (zh) * | 2012-11-28 | 2013-04-10 | 华南理工大学 | 一种基于web服务的移动客户端应用程序自定制方法 |
CN104615466A (zh) * | 2015-02-05 | 2015-05-13 | 广州亦云信息技术有限公司 | 一种云平台部署方法和系统 |
CN105208081A (zh) * | 2015-08-14 | 2015-12-30 | 深圳联友科技有限公司 | 一种通过订阅方式实现网络通信的方法和系统 |
CN105491161A (zh) * | 2016-01-19 | 2016-04-13 | 深圳市沃特玛电池有限公司 | 一种电池管理系统软件的远程升级系统及其远程升级方法 |
Non-Patent Citations (1)
Title |
---|
刘犇等: "基于服务器推送技术的Web数据实时更新", 《电脑开发与应用》 * |
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN111722945A (zh) * | 2020-06-22 | 2020-09-29 | 重庆忽米网络科技有限公司 | 一种基于中间件实现的工业互联网应用系统及实现方法 |
CN111722945B (zh) * | 2020-06-22 | 2024-05-28 | 重庆忽米网络科技有限公司 | 一种基于中间件实现的工业互联网应用系统及实现方法 |
CN111931103A (zh) * | 2020-07-09 | 2020-11-13 | 北京皮尔布莱尼软件有限公司 | 一种网站部署方法 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN107979493B (zh) | 平台即服务paas容器平台的构建方法、服务器及存储介质 | |
CN105373396B (zh) | 插件平台中的插件更新加载方法和装置 | |
CN103475682B (zh) | 文件迁移方法及设备 | |
CN107580083A (zh) | 一种容器ip地址分配的方法和系统 | |
CN113489772B (zh) | 网络请求处理方法及装置、电子设备 | |
CN103559056B (zh) | 文件下载方法和装置 | |
CN110855772B (zh) | 跨设备数据存储方法、系统、装置、设备、服务器及介质 | |
CN107087038A (zh) | 一种数据同步的方法、同步设备、装置及存储介质 | |
CN102447688A (zh) | 网页游戏资源加速器及加速方法 | |
CN109725952B (zh) | 一种应用程序插件化的方法、系统以及相关装置 | |
CN105721941A (zh) | 云电视的空中下载升级控制方法和装置 | |
US20080163227A1 (en) | Server and client, and update supporting and performing methods thereof | |
CN106797670A (zh) | 使用表征状态转移业务的物理交换机初始化 | |
CN109618003B (zh) | 一种服务器规划方法、服务器及存储介质 | |
CN107015972A (zh) | 一种机房业务迁移方法、装置和系统 | |
CN106293847A (zh) | 一种虚拟化平台服务支撑的方法 | |
CN107071043A (zh) | 一种网络信息的配置方法和装置 | |
CN105847231A (zh) | 服务发布方法、装置及系统 | |
CN110716734A (zh) | 一种软件升级的方法、装置、电子设备及介质 | |
CN113127023B (zh) | 业务升级的方法、装置和系统 | |
CN106325931A (zh) | 一种软件预部署的方法及装置 | |
CN108958933B (zh) | 任务执行器的配置参数更新方法、装置及设备 | |
CN113179324B (zh) | 一种区块链节点及其执行的业务处理方法 | |
CN104823410B (zh) | 参数设定系统、程序管理装置以及信息处理装置 | |
CN110134805A (zh) | 图片类评论数据的网络存储方法、装置、电子设备及介质 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
C10 | Entry into 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: 20170111 |