CN104881294A - 实现自动打包的系统及方法 - Google Patents

实现自动打包的系统及方法 Download PDF

Info

Publication number
CN104881294A
CN104881294A CN201510315569.1A CN201510315569A CN104881294A CN 104881294 A CN104881294 A CN 104881294A CN 201510315569 A CN201510315569 A CN 201510315569A CN 104881294 A CN104881294 A CN 104881294A
Authority
CN
China
Prior art keywords
packing
baling press
data
mirror image
interface
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.)
Granted
Application number
CN201510315569.1A
Other languages
English (en)
Other versions
CN104881294B (zh
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.)
Beijing Hongxiang Technical Service Co Ltd
Original Assignee
Beijing Qihoo Technology Co Ltd
Qizhi Software Beijing 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 Beijing Qihoo Technology Co Ltd, Qizhi Software Beijing Co Ltd filed Critical Beijing Qihoo Technology Co Ltd
Priority to CN201510315569.1A priority Critical patent/CN104881294B/zh
Publication of CN104881294A publication Critical patent/CN104881294A/zh
Application granted granted Critical
Publication of CN104881294B publication Critical patent/CN104881294B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Landscapes

  • Management, Administration, Business Operations System, And Electronic Commerce (AREA)
  • Auxiliary Devices For And Details Of Packaging Control (AREA)

Abstract

本发明公开了一种实现自动打包的系统及方法。其中,系统包括:中心机以及至少一个打包机;中心机内部具有提供任务下发接口的第一脚本,至少一个打包机内部具有提供打包接口的第二脚本;中心机适于:接收任务下发接口的调用请求运行第一脚本,以向至少一个打包机发送打包接口的调用请求和数据打包任务;至少一个打包机适于:在接收到打包接口的调用请求和数据打包任务后,运行第二脚本以对数据进行打包。本发明实现了数据自动打包,无需通过人工输入命令进行数据打包,节省人力资源,克服了由于人工输入错误而无法进行打包的缺陷,且该系统便于操作,提高了打包效率和准确率。

Description

实现自动打包的系统及方法
技术领域
本发明涉及互联网技术领域,具体涉及一种实现自动打包的系统及方法。
背景技术
LXC(Linux Container)容器是一种内核虚拟化技术,可以提供轻量级的虚拟化,以便隔离进程和资源,而且不需要提供指令解释机制以及全虚拟化的其他复杂性。相当于C++中的命名空间(NameSpace)。容器有效地将由单个操作系统管理的资源划分到孤立的组中,以更好地在孤立的组之间平衡有冲突的资源使用需求。
Docker是PaaS提供商dotCloud开源的一个基于LXC的高级容器引擎,源代码托管在Github上,基于go语言并遵从Apache2.0协议开源。简单得来说,Docker是一个由GO语言写的程序运行的“容器”(Linux containers,LXCs);目前云服务的基石是操作系统级别的隔离,在同一台宿主机上虚拟出多个主机。Docker则实现了一种应用程序级别的隔离,它改变我们基本的开发、操作单元,由直接操作虚拟主机(VM)转换到操作程序运行的“容器”上来。
现有技术一般采用人工方式手动输入打包命令docker build来对数据进行打包,这种方式效率低,占用人力资源,并会由于输入命令的错误而无法实现打包,准确率低。
发明内容
鉴于上述问题,提出了本发明以便提供一种克服上述问题或者至少部分地解决上述问题的实现自动打包的系统和相应的实现自动打包的方法。
根据本发明的一个方面,提供了一种实现自动打包的系统,包括:中心机以及至少一个打包机;中心机内部具有提供任务下发接口的第一脚本,至少一个打包机内部具有提供打包接口的第二脚本;
中心机适于:接收任务下发接口的调用请求运行第一脚本,以向至少一个打包机发送打包接口的调用请求和数据打包任务;
至少一个打包机适于:在接收到打包接口的调用请求和数据打包任务后,运行第二脚本以对数据进行打包。
根据本发明的另一方面,提供了一种实现自动打包的方法,应用于包括中心机以及至少一个打包机的系统;中心机内部具有提供任务下发接口的第一脚本,至少一个打包机内部具有提供打包接口的第二脚本;方法包括:
通过中心机接收任务下发接口的调用请求运行第一脚本,以向至少一个打包机发送打包接口的调用请求和数据打包任务;以及
至少一个打包机在接收到打包接口的调用请求和数据打包任务后,运行第二脚本以对数据进行打包。
根据本发明提供的方案,中心机在接收任务下发接口的调用请求运行第一脚本,向至少一个打包机发送打包接口的调用请求和数据打包任务;至少一个打包机在接收到打包接口的调用请求和数据打包任务后,运行第二脚本以对数据进行打包,实现了数据自动打包,无需通过人工输入命令进行数据打包,节省人力资源,克服了由于人工输入错误而无法进行打包的缺陷,且该系统便于操作,提高了打包效率和准确率。
上述说明仅是本发明技术方案的概述,为了能够更清楚了解本发明的技术手段,而可依照说明书的内容予以实施,并且为了让本发明的上述和其它目的、特征和优点能够更明显易懂,以下特举本发明的具体实施方式。
附图说明
通过阅读下文优选实施方式的详细描述,各种其他的优点和益处对于本领域普通技术人员将变得清楚明了。附图仅用于示出优选实施方式的目的,而并不认为是对本发明的限制。而且在整个附图中,用相同的参考符号表示相同的部件。在附图中:
图1示出了根据本发明一个实施例的实现自动打包的系统的功能框图;
图2示出了根据本发明一个实施例的实现自动打包的方法的流程图;
图3示出了根据本发明另一个实施例的实现自动打包的方法的流程图。
具体实施方式
下面将参照附图更详细地描述本公开的示例性实施例。虽然附图中显示了本公开的示例性实施例,然而应当理解,可以以各种形式实现本公开而不应被这里阐述的实施例所限制。相反,提供这些实施例是为了能够更透彻地理解本公开,并且能够将本公开的范围完整的传达给本领域的技术人员。
现有的数据打包一般是通过人工输入打包命令来实现,在整个打包过程中需要一一输入对应的命令来完成上述打包任务。本申请提供了一种实现自动打包的系统和方法,其提供了至少一个打包机,并通过检测打包机的状态,将打包任务首先发送给空闲状态的打包机,分布式处理数据打包任务。
图1示出了根据本发明一个实施例的实现自动打包的系统的功能框图。如图1所示,该系统,包括:中心机100以及至少一个打包机110;中心机100内部具有提供任务下发接口的第一脚本,至少一个打包机110内部具有提供打包接口的第二脚本。中心机100与至少一个打包机配合使用对数据进行打包。
可选地,该系统还包括:镜像源120以及至少一个宿主机130。其中,镜像源120,适于存储至少一个打包机上传的镜像数据。至少一个宿主机130,适于在接收到拉取镜像数据的消息后,到镜像源拉取镜像数据。
可选地,第一脚本用于实现向至少一个打包机发送打包接口的调用请求和数据打包任务。第二脚本用于对数据进行打包。
中心机100适于:接收任务下发接口的调用请求运行第一脚本,以向至少一个打包机发送打包接口的调用请求和数据打包任务;及,接收至少一个打包机发送的上传结果信息,根据上传结果信息向至少一个宿主机发送拉取镜像数据的消息。
可选地,任务下发接口的调用请求中包含以下调用信息的一种或多种:镜像标签、系统文件的相对路径和第一配置信息;其中,第一配置信息包括:系统文件的基础路径、打包机列表信息和超时时间,更具体地,镜像标签定义了在打包结束后,上传至镜像源中镜像数据的名称;系统文件(dockerfile)的相对路径定义了dockerfile存储路径中的用于确定dockerfile所在的底层目录的部分路径,dockerfile由一条一条的指令组成,其包含创建镜像所需要的全部指令,基于在dockerfile中的指令来创建镜像;超时时间定义了打包机接收数据打包任务到将镜像数据自动上传到镜像源的时间,超过该时间,则说明上传失败。
打包接口的调用请求中包含以下调用信息的一种或多种:镜像标签、系统文件的相对路径和第二配置信息;其中,第二配置信息包括:系统文件的基础路径、镜像源地址、镜像数据存储地址,更具体地,系统文件的基础路径定义了dockerfile存储路径中的用于确定dockerfile所在的初始目录的部分路径;镜像源地址定义了镜像源的地址,该地址用于指示打包机在数据打包结束后,镜像数据上传的地址;镜像数据存储地址定义了打包机在数据打包结束后,镜像数据存储在本地的地址。
中心机100通过任务下发接口接收调用请求,并根据该调用请求中的调用信息运行第一脚本,并在第一脚本运行过程中向至少一个打包机发送打包接口的调用请求和数据打包任务,其中,数据打包任务存储于中心机100的消息队列中,中心机100从消息队列中选择数据打包任务发送给打包机列表信息中记录的打包机。本实施例中,中心机通过任务下发接口接收调用请求具体代码实现如下:
octopus-ctl -t test-image/centos -p build/test-image/centos/Dockerflie -cconfig.yml
具体的参数含义:
-t镜像标签
-p系统文件的相对路径
-c第一配置信息:系统文件的基础路径、打包机列表信息和超时时间
可选地,中心机100进一步适于:检测至少一个打包机的状态,将打包接口的调用请求和数据打包任务发送至处于空闲状态的打包机。打包机的状态包括忙碌状态和空闲状态,忙碌状态说明已为打包机分配了数据打包任务,打包机正在进行数据打包,空闲状态说明未给打包机分配数据打包任务。具体地,在检测到至少一个打包机处于空闲状态,则中心机100将打包接口的调用请求和从消息队列中选择数据打包任务发送给该处于空闲状态的打包机。通过检测至少一个打包机的状态,可以有针对性地向处于空闲状态的打包机发送数据打包任务,克服了为部分打包机分配有多个数据打包任务,而却未给另一部分打包机分配打包任务的缺陷,保证最高效的利用打包机,提高了打包效率。
可选地,中心机100进一步适于:检测至少一个打包机是否创建有打包进程;若中心机检测到打包机未创建有打包进程,则将打包接口的调用请求和数据打包任务发送至该打包机。其中,进程是一个具有一定独立功能的程序关于某个数据集合的一次运行活动,中心机通过检测至少一个打包机是否创建有打包进程,来判断是否给打包机分配了数据打包任务,若检测到打包机创建有打包进程则说明已给打包机分配任务;若检测到打包机未创建有打包进程,则说明未给打包机分配任务,中心机可以将打包接口的调用请求和从消息队列中选择数据打包任务发送至该打包机。
中心机100进一步适于:通过检测至少一个打包机创建的进程名称是否包含关键字来确定至少一个打包机是否创建有打包进程;若进程名称不包含关键字,则打包机未创建有打包进程,将打包接口的调用请求和数据打包任务发送至该打包机。更具体地,至少一个打包机创建进程后,会为该进程设置对应的进程名称,通过检测进程名称中是否包含关键字,例如,“打包”等来确定至少一个打包机是否创建有打包进程;若进程中包含关键字“打包”,则打包机已创建有打包进程;若进程中不包含关键字“打包”,则打包机未创建有打包进程,将打包接口的调用请求和数据打包任务发送至该打包机。
中心机100在接收至少一个打包机发送的上传结果信息后,根据上传结果信息向至少一个宿主机发送拉取镜像数据的消息。具体地,若中心机100接收到至少一个打包机发送的上传成功信息,则中心机100向至少一个宿主机发送拉取镜像数据的消息,若中心机100接收到至少一个打包机发送的上传失败的信息,则中心机100不向至少一个宿主机发送拉取镜像数据的消息。更具体地,拉取镜像数据的消息中包含镜像标签,以供至少一个宿主机依据镜像标签拉取镜像数据。
至少一个打包机110适于:在接收到打包接口的调用请求和数据打包任务后,运行第二脚本以对数据进行打包。
可选地,至少一个打包机110进一步适于:在打包完毕后,将打包数据作为镜像数据自动上传至镜像源,并通过回调打包接口向中心机发送上传结果信息。本实施例中,中心机调用至少一个打包机的打包接口具体代码实现如下:
def run_cmd(self,*args,**kwargs):
results=ansible.runner.Runner(host_list=kwargs["host_list"],#调用的打包机
             module_args=kwargs["cmd"],脚本代码内部的打包接口的调用请求的调用信息
             forks=10,
             remote_user=kwargs["username"],
             remote_pass=kwargs["password"],
             become=True,
             become_pass=kwargs["password"]
             ).run()
其中,脚本代码内部的打包接口的调用请求的调用信息,具体代码实现如下:
octopus-build -t test-image/centos -p build/test-image/centos/Dockerflie -cconfig.yml
参数含义:
-t镜像标签
-p系统文件的相对路径
-c第二配置信息:系统文件的基础路径、镜像源地址、镜像数据存储地址
至少一个打包机110在接收到中心机内部的第一脚本调用打包接口的调用请求和数据打包任务后,运行第二脚本,该第二脚本根据打包接口调用请求中的调用信息:系统文件的基础路径和系统文件的相对路径查找到dockerfile,对数据进行打包;并在打包完毕后,根据打包接口调用请求中的调用信息:镜像数据存储地址,将镜像数据存储于本地,根据打包接口调用请求中的调用信息:镜像标签、镜像源地址将镜像数据自动上传至镜像源,并通过回调打包接口向中心机发送上传结果信息。
上传结果信息包括:镜像数据上传成功信息和镜像数据上传失败信息,其中镜像数据上传成功信息说明数据打包成功,镜像数据上传失败信息又分为:数据打包成功但打包机上传镜像数据失败和数据打包失败。本实施例中,至少一个打包机回调打包接口向中心机发送上传结果信息,具体代码实现如下:
{"build-host":"docker-build01v.add.bjdt.qihoo.net",
"tag":"test-image/centos"
"build":数据打包成功返回True;数据打包失败返回False
"upload":镜像数据上传成功返回True;镜像数据上传失败返回False
   }
当上传结果信息为数据打包失败信息时,中心机进一步适于:根据上传结果信息向至少一个打包机发送重新进行数据打包的消息。至少一个打包机在接收到中心机发送的重新对数据进行打包的消息后,对打包失败的数据再次进行打包。
当上传结果信息为数据打包成功但镜像数据上传失败信息时,中心机进一步适于:根据上传结果信息向至少一个打包机发送重新进行镜像数据上传的消息。至少一个打包机在接收到中心机发送的重新上传镜像数据的消息后,对上传失败的镜像数据再次进行上传。
至少一个宿主机130,适于在接收到拉取镜像数据的消息后,根据拉取镜像数据的消息中所包含的镜像标签到镜像源拉取镜像数据。镜像标签体现了在镜像源中镜像数据存储的名称,至少一个宿主机可以根据镜像标签具体选择要拉取的镜像数据。
根据本发明上述实施例提供的系统,中心机在接收任务下发接口的调用请求运行第一脚本,向至少一个打包机发送打包接口的调用请求和数据打包任务;至少一个打包机在接收到打包接口的调用请求和数据打包任务后,运行第二脚本以对数据进行打包,并在打包完毕后,将打包数据作为镜像数据自动上传至镜像源,并通过回调打包接口向中心机发送上传结果信息,实现了数据自动打包和自动上传,无需通过人工输入命令进行数据打包和上传,节省人力资源,克服了由于人工输入错误而无法进行打包和上传的缺陷,且该系统便于操作,提高了打包效率、上传效率和准确率。
图2示出了根据本发明一个实施例的实现自动打包的方法的流程图。如图2所示,该方法包括以下步骤:
步骤S200,通过中心机接收任务下发接口的调用请求运行第一脚本,以向至少一个打包机发送打包接口的调用请求和数据打包任务。
其中,数据打包任务存储于中心机的消息队列中,中心机从消息队列中选择数据打包任务发送给打包机列表信息中记录的打包机。中心机内部具有提供任务下发接口的第一脚本,用于实现向至少一个打包机发送打包接口的调用请求和数据打包任务。
步骤S210,至少一个打包机在接收到打包接口的调用请求和数据打包任务后,运行第二脚本以对数据进行打包。
可选地,至少一个打包机内部具有提供打包接口的第二脚本,用于对数据进行打包。
根据本发明上述实施例提供的方法,通过中心机接收任务下发接口的调用请求运行第一脚本,向至少一个打包机发送打包接口的调用请求和数据打包任务;至少一个打包机在接收到打包接口的调用请求和数据打包任务后,运行第二脚本以对数据进行打包,实现了数据自动打包,无需通过人工输入命令进行数据打包,节省人力资源,克服了由于人工输入错误而无法进行打包的缺陷,且该系统便于操作,提高了打包效率和准确率。
图3示出了根据本发明另一个实施例的实现自动打包的方法的流程图。
步骤S300,通过中心机接收任务下发接口的调用请求运行第一脚本,以向至少一个打包机发送打包接口的调用请求。
任务下发接口的调用请求中包含以下调用信息的一种或多种:镜像标签、系统文件的相对路径和第一配置信息;其中,第一配置信息包括:系统文件的基础路径、打包机列表信息和超时时间,更具体地,镜像标签定义了在打包结束后,上传至镜像源中镜像数据的名称;系统文件(dockerfile)的相对路径定义了dockerfile存储路径中的用于确定dockerfile所在的底层目录的部分路径,dockerfile由一条一条的指令组成,其包含创建镜像所需要的全部指令,基于在dockerfile中的指令来创建镜像。
打包接口的调用请求中包含以下调用信息的一种或多种:镜像标签、系统文件的相对路径和第二配置信息;其中,第二配置信息包括:系统文件的基础路径、镜像源地址、镜像数据存储地址,更具体地,系统文件的基础路径定义了dockerfile存储路径中的用于确定dockerfile所在的初始目录的部分路径;镜像源地址定义了镜像源的地址,该地址用于指示打包机在数据打包结束后,镜像数据上传的地址;镜像数据存储地址定义了打包机在数据打包结束后,镜像数据存储在本地的地址。
本实施例中,中心机通过任务下发接口接收调用请求具体代码实现如下:octopus-ctl -t test-image/centos -p build/test-image/centos/Dockerflie -cconfig.yml
具体的参数含义:
-t镜像标签
-p系统文件的相对路径
-c第一配置信息:系统文件的基础路径、打包机列表信息和超时时间
步骤S310,中心机检测至少一个打包机的状态,将打包接口的调用请求和数据打包任务发送至处于空闲状态的打包机。
打包机的状态包括忙碌状态和空闲状态,忙碌状态说明已为打包机分配了数据打包任务,打包机正在进行数据打包,空闲状态说明未给打包机分配数据打包任务。具体地,在检测到至少一个打包机处于空闲状态,则中心机将打包接口的调用请求和从消息队列中选择数据打包任务发送给该处于空闲状态的打包机。通过检测至少一个打包机的状态,可以有针对性地向处于空闲状态的打包机发送数据打包任务,克服了为部分打包机分配有多个数据打包任务,而却未给另一部分打包机分配打包任务的缺陷,保证最高效的利用打包机,提高了打包效率。
可选地,中心机检测至少一个打包机是否创建有打包进程;若中心机检测到打包机未创建打包进程,则将打包接口的调用请求和数据打包任务发送至该打包机。其中,进程是一个具有一定独立功能的程序关于某个数据集合的一次运行活动,中心机通过检测至少一个打包机是否创建有打包进程,来判断是否给打包机分配了数据打包任务,若检测到打包机创建有打包进程则说明已给打包机分配任务;若检测到打包机未创建打包进程,则说明未给打包机分配任务,中心机可以将打包接口的调用请求和从消息队列中选择数据打包任务发送至该打包机。
可选地,中心机通过检测至少一个打包机创建的进程名称是否包含关键字来确定至少一个打包机是否创建有打包进程;若进程名称不包含关键字,则打包机未创建有打包进程,将打包接口的调用请求和数据打包任务发送至该打包机。更具体地,至少一个打包机创建进程后,会为该进程设置对应的进程名称,通过检测进程名称中是否包含关键字,例如,“打包”等来确定至少一个打包机是否创建有打包进程;若进程中包含关键字“打包”,则打包机已创建了打包进程;若进程中不包含关键字“打包”,则打包机未创建有打包进程,将打包接口的调用请求和数据打包任务发送至该打包机。
步骤S320,至少一个打包机在接收到打包接口的调用请求和数据打包任务后,运行第二脚本以对数据进行打包。
本实施例中,中心机调用至少一个打包机的打包接口具体代码实现如下:
def run_cmd(self,*args,**kwargs):
results=ansible.runner.Runner(host_list=kwargs["host_list"],#调用的打包机
             module_args=kwargs["cmd"],脚本代码内部的打包接口的调用请求的调用信息
             forks=10,
             remote_user=kwargs["username"],
             remote_pass=kwargs["password"],
             become=True,
             become_pass=kwargs["password"]
             ).run()
其中,脚本代码内部的打包接口的调用请求的调用信息,具体代码实现如下:
octopus-build -t test-image/centos -p build/test-image/centos/Dockerflie -cconfig.yml
参数含义:
-t镜像标签
-p系统文件的相对路径
-c第二配置信息:系统文件的基础路径、镜像源地址、镜像数据存储地址
步骤S330,至少一个打包机在打包完毕后,将打包数据作为镜像数据自动上传至镜像源,并通过回调打包接口向中心机发送上传结果信息。
至少一个打包机根据打包接口调用请求中的调用信息:镜像数据存储地址,将镜像数据存储于本地,根据打包接口调用请求中的调用信息:镜像标签、镜像源地址将镜像数据自动上传至镜像源,并通过回调打包接口向中心机发送上传结果信息。
上传结果信息包括:镜像数据上传成功信息和镜像数据上传失败信息,其中镜像数据上传成功信息说明数据打包成功,镜像数据上传失败信息又分为:数据打包失败以及数据打包成功,但打包机上传镜像数据失败。本实施例中,至少一个打包机回调打包接口向中心机发送上传结果信息,具体代码实现如下:
{"build-host":"docker-build01v.add.bjdt.qihoo.net",
"tag":"test-image/centos"
"build":数据打包成功返回True;数据打包失败返回False
"upload":镜像数据上传成功返回True;镜像数据上传失败返回False
}
步骤S340,中心机接收至少一个打包机发送的上传结果信息,根据上传结果信息向至少一个宿主机发送拉取镜像数据的消息。
具体地,若中心机100接收到至少一个打包机发送的上传成功信息,则中心机100向至少一个宿主机发送拉取镜像数据的消息,若中心机100接收到至少一个打包机发送的上传失败的信息,则中心机100不向至少一个宿主机发送拉取镜像数据的消息。其中,拉取镜像数据的消息中包含镜像标签,以供至少一个宿主机依据镜像标签拉取镜像数据。
当上传结果信息为数据打包失败信息时,本实施例还包括:中心机根据上传结果信息向至少一个打包机发送重新进行数据打包的消息。至少一个打包机在接收到中心机发送的重新对数据进行打包的消息后,对打包失败的数据再次进行打包。
当上传结果信息为数据打包成功但镜像数据上传失败信息时,本实施例还包括:中心机根据上传结果信息向至少一个打包机发送重新进行镜像数据上传的消息。至少一个打包机在接收到中心机发送的重新上传镜像数据的消息后,对上传失败的镜像数据再次进行上传。
步骤S350,至少一个宿主机在接收到拉取镜像数据的消息后,到镜像源拉取镜像数据。
具体地,至少一个宿主机在接收到中心机发送的拉取镜像数据的消息后,根据镜像标签拉取镜像数据。镜像标签体现了在镜像源中镜像数据存储的名称,至少一个宿主机可以根据镜像标签具体选择要拉取的镜像数据。
根据本发明上述实施例提供的方法,通过中心机接收任务下发接口的调用请求运行第一脚本,向至少一个打包机发送打包接口的调用请求;检测至少一个打包机的状态,将数据打包任务发送至处于空闲状态的打包机,可以有针对性地向处于空闲状态的打包机发送数据打包任务,克服了为部分打包机分配有多个数据打包任务,而却未给另一部分打包机分配打包任务的缺陷,保证最高效的利用打包机,提高了打包效率;至少一个打包机在接收到打包接口的调用请求和数据打包任务后,运行第二脚本以对数据进行打包,并在打包完毕后,将打包数据作为镜像数据自动上传至镜像源,并通过回调打包接口向中心机发送上传结果信息,实现了数据自动打包和自动上传,无需通过人工输入命令进行数据打包和上传,节省人力资源,克服了由于人工输入错误而无法进行打包和上传的缺陷,且该系统便于操作,提高了上传效率和准确率。
在此提供的算法和显示不与任何特定计算机、虚拟系统或者其它设备固有相关。各种通用系统也可以与基于在此的示教一起使用。根据上面的描述,构造这类系统所要求的结构是显而易见的。此外,本发明也不针对任何特定编程语言。应当明白,可以利用各种编程语言实现在此描述的本发明的内容,并且上面对特定语言所做的描述是为了披露本发明的最佳实施方式。
在此处所提供的说明书中,说明了大量具体细节。然而,能够理解,本发明的实施例可以在没有这些具体细节的情况下实践。在一些实例中,并未详细示出公知的方法、结构和技术,以便不模糊对本说明书的理解。
类似地,应当理解,为了精简本公开并帮助理解各个发明方面中的一个或多个,在上面对本发明的示例性实施例的描述中,本发明的各个特征有时被一起分组到单个实施例、图、或者对其的描述中。然而,并不应将该公开的方法解释成反映如下意图:即所要求保护的本发明要求比在每个权利要求中所明确记载的特征更多的特征。更确切地说,如下面的权利要求书所反映的那样,发明方面在于少于前面公开的单个实施例的所有特征。因此,遵循具体实施方式的权利要求书由此明确地并入该具体实施方式,其中每个权利要求本身都作为本发明的单独实施例。
本领域那些技术人员可以理解,可以对实施例中的设备中的模块进行自适应性地改变并且把它们设置在与该实施例不同的一个或多个设备中。可以把实施例中的模块或单元或组件组合成一个模块或单元或组件,以及此外可以把它们分成多个子模块或子单元或子组件。除了这样的特征和/或过程或者单元中的至少一些是相互排斥之外,可以采用任何组合对本说明书(包括伴随的权利要求、摘要和附图)中公开的所有特征以及如此公开的任何方法或者设备的所有过程或单元进行组合。除非另外明确陈述,本说明书(包括伴随的权利要求、摘要和附图)中公开的每个特征可以由提供相同、等同或相似目的的替代特征来代替。
此外,本领域的技术人员能够理解,尽管在此所述的一些实施例包括其它实施例中所包括的某些特征而不是其它特征,但是不同实施例的特征的组合意味着处于本发明的范围之内并且形成不同的实施例。例如,在下面的权利要求书中,所要求保护的实施例的任意之一都可以以任意的组合方式来使用。
本发明的各个部件实施例可以以硬件实现,或者以在一个或者多个处理器上运行的软件模块实现,或者以它们的组合实现。本领域的技术人员应当理解,可以在实践中使用微处理器或者数字信号处理器(DSP)来实现根据本发明实施例的实现自动打包的设备中的一些或者全部部件的一些或者全部功能。本发明还可以实现为用于执行这里所描述的方法的一部分或者全部的设备或者装置程序(例如,计算机程序和计算机程序产品)。这样的实现本发明的程序可以存储在计算机可读介质上,或者可以具有一个或者多个信号的形式。这样的信号可以从因特网网站上下载得到,或者在载体信号上提供,或者以任何其他形式提供。
应该注意的是上述实施例对本发明进行说明而不是对本发明进行限制,并且本领域技术人员在不脱离所附权利要求的范围的情况下可设计出替换实施例。在权利要求中,不应将位于括号之间的任何参考符号构造成对权利要求的限制。单词“包含”不排除存在未列在权利要求中的元件或步骤。位于元件之前的单词“一”或“一个”不排除存在多个这样的元件。本发明可以借助于包括有若干不同元件的硬件以及借助于适当编程的计算机来实现。在列举了若干装置的单元权利要求中,这些装置中的若干个可以是通过同一个硬件项来具体体现。单词第一、第二、以及第三等的使用不表示任何顺序。可将这些单词解释为名称。
本发明公开了:A1、一种实现自动打包的系统,包括:中心机以及至少一个打包机;所述中心机内部具有提供任务下发接口的第一脚本,所述至少一个打包机内部具有提供打包接口的第二脚本;
所述中心机适于:接收所述任务下发接口的调用请求运行所述第一脚本,以向所述至少一个打包机发送所述打包接口的调用请求和数据打包任务;
所述至少一个打包机适于:在接收到所述打包接口的调用请求和数据打包任务后,运行第二脚本以对数据进行打包。
A2、根据A1所述的系统,所述至少一个打包机进一步适于:在打包完毕后,将打包数据作为镜像数据自动上传至镜像源,并通过回调所述打包接口向中心机发送上传结果信息。
A3、根据A2所述的系统,所述中心机进一步适于:接收所述至少一个打包机发送的上传结果信息,根据所述上传结果信息向至少一个宿主机发送拉取镜像数据的消息。
A4、根据A3所述的系统,所述拉取镜像数据的消息中包含镜像标签,以供所述至少一个宿主机依据所述镜像标签拉取镜像数据。
A5、根据A3或A4所述的系统,所述上传结果信息包括:镜像数据上传成功信息和镜像数据上传失败信息,其中,镜像数据上传失败信息分为:数据打包失败信息以及数据打包成功但镜像数据上传失败信息;
当所述上传结果信息为数据打包失败信息时,所述中心机进一步适于:根据所述上传结果信息向所述至少一个打包机发送重新进行数据打包的消息;
当所述上传结果信息为数据打包成功但镜像数据上传失败信息时,所述中心机进一步适于:根据所述上传结果信息向所述至少一个打包机发送重新进行镜像数据上传的消息。
A6、根据A1-A5任一项所述的系统,所述任务下发接口的调用请求中包含以下调用信息的一种或多种:
镜像标签、系统文件的相对路径和第一配置信息;
其中,所述第一配置信息包括:系统文件的基础路径、打包机列表信息和超时时间。
A7、根据A1-A6任一项所述的系统,所述打包接口的调用请求中包含以下调用信息的一种或多种:
镜像标签、系统文件的相对路径和第二配置信息;
其中,所述第二配置信息包括:系统文件的基础路径、镜像源地址、镜像数据存储地址。
A8、根据A1-A7任一项所述的系统,所述中心机进一步适于:检测所述至少一个打包机的状态,将所述打包接口的调用请求和数据打包任务发送至处于空闲状态的打包机。
A9、根据A8所述的系统,所述中心机进一步适于:检测所述至少一个打包机是否创建有打包进程;
若所述中心机检测到所述打包机未创建有打包进程,则将所述打包接口的调用请求和数据打包任务发送至该打包机。
A10、根据A9所述的系统,所述中心机进一步适于:通过检测所述至少一个打包机创建的进程名称是否包含关键字来确定所述至少一个打包机是否创建有打包进程;
若所述进程名称不包含所述关键字,则所述打包机未创建有打包进程,将所述打包接口的调用请求和数据打包任务发送至该打包机。
本发明还公开了:B11、一种实现自动打包的方法,应用于包括中心机以及至少一个打包机的系统;所述中心机内部具有提供任务下发接口的第一脚本,所述至少一个打包机内部具有提供打包接口的第二脚本;所述方法包括:
通过中心机接收所述任务下发接口的调用请求运行所述第一脚本,以向所述至少一个打包机发送所述打包接口的调用请求和数据打包任务;以及
所述至少一个打包机在接收到所述打包接口的调用请求和数据打包任务后,运行第二脚本以对数据进行打包。
B12、根据B11所述的方法,所述方法进一步包括:
在打包完毕后,所述至少一个打包机将打包数据作为镜像数据自动上传至镜像源,并通过回调所述打包接口向中心机发送上传结果信息。
B13、根据B12所述的方法,所述方法进一步包括:
中心机接收所述至少一个打包机发送的上传结果信息,根据所述上传结果信息向至少一个宿主机发送拉取镜像数据的消息。
B14、根据B13所述的方法,所述拉取镜像数据的消息中包含镜像标签,以供所述至少一个宿主机依据所述镜像标签拉取镜像数据。
B15、根据B13或B14所述的方法,所述上传结果信息包括:镜像数据上传成功信息和镜像数据上传失败信息,其中,镜像数据上传失败信息分为:数据打包失败信息以及数据打包成功但镜像数据上传失败信息;
当所述上传结果信息为数据打包失败信息时,所述方法还包括:所述中心机根据所述上传结果信息向所述至少一个打包机发送重新进行数据打包的消息;
当所述上传结果信息为数据打包成功但镜像数据上传失败信息时,所述方法还包括:所述中心机根据所述上传结果信息向所述至少一个打包机发送重新进行镜像数据上传的消息。
B16、根据B11-B15任一项所述的方法,所述任务下发接口的调用请求中包含以下调用信息的一种或多种:
镜像标签、系统文件的相对路径和第一配置信息;
其中,所述第一配置信息包括:系统文件的基础路径、打包机列表信息和超时时间。
B17、根据B11-B16任一项所述的方法,所述打包接口的调用请求中包含以下调用信息的一种或多种:
镜像标签、系统文件的相对路径和第二配置信息;
其中,所述第二配置信息包括:系统文件的基础路径、镜像源地址、镜像数据存储地址。
B18、根据B11-B17任一项所述的方法,中心机向所述至少一个打包机发送数据打包任务进一步包括:
中心机检测所述至少一个打包机的状态,将所述打包接口的调用请求和数据打包任务发送至处于空闲状态的打包机。
B19、根据B18所述的方法,所述中心机检测所述至少一个打包机的状态,将数据打包任务发送至处于空闲状态的打包机进一步包括:
中心机检测所述至少一个打包机是否创建有打包进程;
若所述中心机检测到所述打包机未创建有打包进程,则将所述打包接口的调用请求和数据打包任务发送至该打包机。
B20、根据B19所述的方法,所述中心机检测所述至少一个打包机是否创建有打包进程进一步包括:
中心机通过检测所述至少一个打包机创建的进程名称是否包含关键字来确定所述至少一个打包机是否创建有打包进程;
若所述进程名称不包含所述关键字,则所述打包机未创建有打包进程,将所述打包接口的调用请求和数据打包任务发送至该打包机。

Claims (10)

1.一种实现自动打包的系统,包括:中心机以及至少一个打包机;所述中心机内部具有提供任务下发接口的第一脚本,所述至少一个打包机内部具有提供打包接口的第二脚本;
所述中心机适于:接收所述任务下发接口的调用请求运行所述第一脚本,以向所述至少一个打包机发送所述打包接口的调用请求和数据打包任务;
所述至少一个打包机适于:在接收到所述打包接口的调用请求和数据打包任务后,运行第二脚本以对数据进行打包。
2.根据权利要求1所述的系统,所述至少一个打包机进一步适于:在打包完毕后,将打包数据作为镜像数据自动上传至镜像源,并通过回调所述打包接口向中心机发送上传结果信息。
3.根据权利要求2所述的系统,所述中心机进一步适于:接收所述至少一个打包机发送的上传结果信息,根据所述上传结果信息向至少一个宿主机发送拉取镜像数据的消息。
4.根据权利要求3所述的系统,所述拉取镜像数据的消息中包含镜像标签,以供所述至少一个宿主机依据所述镜像标签拉取镜像数据。
5.根据权利要求3或4所述的系统,所述上传结果信息包括:镜像数据上传成功信息和镜像数据上传失败信息,其中,镜像数据上传失败信息分为:数据打包失败信息以及数据打包成功但镜像数据上传失败信息;
当所述上传结果信息为数据打包失败信息时,所述中心机进一步适于:根据所述上传结果信息向所述至少一个打包机发送重新进行数据打包的消息;
当所述上传结果信息为数据打包成功但镜像数据上传失败信息时,所述中心机进一步适于:根据所述上传结果信息向所述至少一个打包机发送重新进行镜像数据上传的消息。
6.根据权利要求1-5任一项所述的系统,所述任务下发接口的调用请求中包含以下调用信息的一种或多种:
镜像标签、系统文件的相对路径和第一配置信息;
其中,所述第一配置信息包括:系统文件的基础路径、打包机列表信息和超时时间。
7.根据权利要求1-6任一项所述的系统,所述打包接口的调用请求中包含以下调用信息的一种或多种:
镜像标签、系统文件的相对路径和第二配置信息;
其中,所述第二配置信息包括:系统文件的基础路径、镜像源地址、镜像数据存储地址。
8.根据权利要求1-7任一项所述的系统,所述中心机进一步适于:检测所述至少一个打包机的状态,将所述打包接口的调用请求和数据打包任务发送至处于空闲状态的打包机。
9.根据权利要求8所述的系统,所述中心机进一步适于:检测所述至少一个打包机是否创建有打包进程;
若所述中心机检测到所述打包机未创建有打包进程,则将所述打包接口的调用请求和数据打包任务发送至该打包机。
10.一种实现自动打包的方法,应用于包括中心机以及至少一个打包机的系统;所述中心机内部具有提供任务下发接口的第一脚本,所述至少一个打包机内部具有提供打包接口的第二脚本;所述方法包括:
通过中心机接收所述任务下发接口的调用请求运行所述第一脚本,以向所述至少一个打包机发送所述打包接口的调用请求和数据打包任务;以及
所述至少一个打包机在接收到所述打包接口的调用请求和数据打包任务后,运行第二脚本以对数据进行打包。
CN201510315569.1A 2015-06-10 2015-06-10 实现自动打包的系统及方法 Active CN104881294B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201510315569.1A CN104881294B (zh) 2015-06-10 2015-06-10 实现自动打包的系统及方法

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201510315569.1A CN104881294B (zh) 2015-06-10 2015-06-10 实现自动打包的系统及方法

Publications (2)

Publication Number Publication Date
CN104881294A true CN104881294A (zh) 2015-09-02
CN104881294B CN104881294B (zh) 2019-03-01

Family

ID=53948801

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201510315569.1A Active CN104881294B (zh) 2015-06-10 2015-06-10 实现自动打包的系统及方法

Country Status (1)

Country Link
CN (1) CN104881294B (zh)

Cited By (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN107229476A (zh) * 2017-06-06 2017-10-03 田进 一种基于数据量的应用程序打包方法及装置
CN107391155A (zh) * 2017-07-31 2017-11-24 北京北信源软件股份有限公司 一种打包方法及装置
CN107908404A (zh) * 2017-11-17 2018-04-13 深圳市泉眼网络科技有限公司 程序打包方法、系统及终端设备
CN111301789A (zh) * 2018-12-11 2020-06-19 顺丰科技有限公司 应用软件打包方法和装置

Citations (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20080320470A1 (en) * 2007-06-20 2008-12-25 Cebicon Gmbh Process for creating an automatically distributable software package
CN102521044A (zh) * 2011-12-30 2012-06-27 北京拓明科技有限公司 一种基于消息中间件的分布式任务调度方法及系统
CN103559082A (zh) * 2013-11-04 2014-02-05 北京华胜天成科技股份有限公司 一种基于队列的分布式任务调度方法、装置及系统
CN103838572A (zh) * 2013-12-20 2014-06-04 北京掌阔技术有限公司 一种安卓开发包的打包系统和方法
CN104407856A (zh) * 2014-11-10 2015-03-11 北京国双科技有限公司 软件工具开发包文件的打包方法和装置
CN104462352A (zh) * 2014-12-04 2015-03-25 北京国双科技有限公司 数据打包方法及装置
CN104484172A (zh) * 2014-12-11 2015-04-01 上海天脉聚源文化传媒有限公司 一种文件打包的方法及装置

Patent Citations (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20080320470A1 (en) * 2007-06-20 2008-12-25 Cebicon Gmbh Process for creating an automatically distributable software package
CN102521044A (zh) * 2011-12-30 2012-06-27 北京拓明科技有限公司 一种基于消息中间件的分布式任务调度方法及系统
CN103559082A (zh) * 2013-11-04 2014-02-05 北京华胜天成科技股份有限公司 一种基于队列的分布式任务调度方法、装置及系统
CN103838572A (zh) * 2013-12-20 2014-06-04 北京掌阔技术有限公司 一种安卓开发包的打包系统和方法
CN104407856A (zh) * 2014-11-10 2015-03-11 北京国双科技有限公司 软件工具开发包文件的打包方法和装置
CN104462352A (zh) * 2014-12-04 2015-03-25 北京国双科技有限公司 数据打包方法及装置
CN104484172A (zh) * 2014-12-11 2015-04-01 上海天脉聚源文化传媒有限公司 一种文件打包的方法及装置

Cited By (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN107229476A (zh) * 2017-06-06 2017-10-03 田进 一种基于数据量的应用程序打包方法及装置
CN107391155A (zh) * 2017-07-31 2017-11-24 北京北信源软件股份有限公司 一种打包方法及装置
CN107908404A (zh) * 2017-11-17 2018-04-13 深圳市泉眼网络科技有限公司 程序打包方法、系统及终端设备
CN111301789A (zh) * 2018-12-11 2020-06-19 顺丰科技有限公司 应用软件打包方法和装置
CN111301789B (zh) * 2018-12-11 2022-08-12 顺丰科技有限公司 应用软件打包方法和装置

Also Published As

Publication number Publication date
CN104881294B (zh) 2019-03-01

Similar Documents

Publication Publication Date Title
US8555252B2 (en) Apparatus and method for loading and updating codes of cluster-based java application system
CN105589701B (zh) 一种客户端应用程序局部更新方法及装置
US9766927B1 (en) Data flow management in processing workflows
US9535754B1 (en) Dynamic provisioning of computing resources
CN104950757A (zh) 监控容器的方法及系统
CN102567015A (zh) 用于执行动态软件版本选择的方法和系统
US11599821B2 (en) Attached accelerator based inference service
CN104899126A (zh) 对宿主机中容器进行本地实时监控的方法、装置及系统
CN104881294A (zh) 实现自动打包的系统及方法
US10949216B2 (en) Support for third-party kernel modules on host operating systems
CN103678508A (zh) 一种网页打开方法及装置
US9367299B2 (en) Preventing application downgrade in an application store
EP3799697B1 (en) Virtual machine container for applications
CN109951553B (zh) 数据处理方法、系统、电子设备以及计算机可读存储介质
CN105955805A (zh) 一种应用容器迁移的方法及装置
CN110213309A (zh) 一种绑定关系管理的方法、设备及存储介质
US20200012545A1 (en) Event to serverless function workflow instance mapping mechanism
CN106202179A (zh) 一种页面加载方法和装置
US11422863B2 (en) Attached accelerator scaling
CN104899068A (zh) 使用容器进行多进程启动的方法及装置
CN109343862A (zh) 应用的资源数据的调度方法及装置
US9189406B2 (en) Placement of data in shards on a storage device
CN105426272A (zh) 应用程序备份方法及装置
US10152490B2 (en) Sequential replication with limited number of objects
US11467835B1 (en) Framework integration for instance-attachable accelerator

Legal Events

Date Code Title Description
C06 Publication
PB01 Publication
EXSB Decision made by sipo to initiate 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: 20220729

Address after: 300450 No. 9-3-401, No. 39, Gaoxin 6th Road, Binhai Science Park, Binhai New Area, Tianjin

Patentee after: 3600 Technology Group Co.,Ltd.

Address before: 100088 room 112, block D, 28 new street, new street, Xicheng District, Beijing (Desheng Park)

Patentee before: BEIJING QIHOO TECHNOLOGY Co.,Ltd.

Patentee before: Qizhi software (Beijing) Co.,Ltd.

TR01 Transfer of patent right
TR01 Transfer of patent right

Effective date of registration: 20230713

Address after: 1765, floor 17, floor 15, building 3, No. 10 Jiuxianqiao Road, Chaoyang District, Beijing 100015

Patentee after: Beijing Hongxiang Technical Service Co.,Ltd.

Address before: 300450 No. 9-3-401, No. 39, Gaoxin 6th Road, Binhai Science Park, Binhai New Area, Tianjin

Patentee before: 3600 Technology Group Co.,Ltd.