CN113296795A - 应用部署方法、装置、设备、存储介质及程序产品 - Google Patents

应用部署方法、装置、设备、存储介质及程序产品 Download PDF

Info

Publication number
CN113296795A
CN113296795A CN202110686390.2A CN202110686390A CN113296795A CN 113296795 A CN113296795 A CN 113296795A CN 202110686390 A CN202110686390 A CN 202110686390A CN 113296795 A CN113296795 A CN 113296795A
Authority
CN
China
Prior art keywords
application
deployment
agent
target application
target
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
CN202110686390.2A
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.)
Agricultural Bank of China
Original Assignee
Agricultural Bank of China
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 Agricultural Bank of China filed Critical Agricultural Bank of China
Priority to CN202110686390.2A priority Critical patent/CN113296795A/zh
Publication of CN113296795A publication Critical patent/CN113296795A/zh
Pending legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/60Software deployment
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/60Software deployment
    • G06F8/61Installation
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/70Software maintenance or management
    • G06F8/71Version control; Configuration management

Landscapes

  • Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • General Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Computer Security & Cryptography (AREA)
  • Stored Programmes (AREA)

Abstract

本申请提供一种应用部署方法、装置、设备、存储介质及程序产品,基于应用自动化部署服务端和代理端的代理机制,通过在代理端设置不同运维环境对应不同代理模块,在进行自动化应用部署时,接收服务端发送的应用部署操作请求,应用部署操作请求包括目标应用的基础信息、操作命令和操作参数;根据目标应用的基础信息,确定目标应用的应用类型,并确定与目标应用的应用类型匹配的代理模块;通过与目标应用的应用类型匹配的代理模块,根据操作参数执行操作命令,得到执行结果;将执行结果反馈给服务端,能够适应于IIS、WAS、Linux/AIX等多种不同的运维环境,满足复杂运维场景的应用平台运维需求。

Description

应用部署方法、装置、设备、存储介质及程序产品
技术领域
本申请涉及计算机技术,尤其涉及一种应用部署方法、装置、设备、存储介质及程序产品。
背景技术
随着业务规模的逐渐增大,IT运维的环境变得庞大而复杂,传统的运维手段已无法满足我们的要求,而自动化运维能把周期性、重复性、规律性的工作交给平台去处理,通过标准化、自动化、过程优化来降低运维成本,从而提高运维效率。
当前应用(Application)的部署主要有以下三种方式:1、纯手工部署:根据开发组提供的部署流程文档,投入大量人力进行应用部署,纯手工部署方式对每台机器每个操作重复进行,繁琐且效率低下,同时人工的干预增加了操作失误的风险。2、脚本操作部署:通过编写脚本,以人工交互运行脚本方式让部署部分操作自动方便执行,脚本部署方式能释放出部分人力,但仍然需要人工的干涉,没有实现整个部署流程的自动化。3、自动化部署:规范整个部署流程的操作,实现应用批量配置、批量部署、批量运行命令等功能,将人工干预降到最低,实现一键式部署。
目前,应用自动化部署是应用运维场景的趋势,现有的主流自动化部署工具大多适用于单一运维环境(如Linux或Windows环境),对于银行应用平台等包含多种运维环境的应用、设备,存在很多复杂运维场景的应用平台,无法满足运维中自动化部署的需求。
发明内容
本申请提供一种应用部署方法、装置、设备、存储介质及程序产品。
第一方面,本申请提供一种应用部署方法,包括:
接收服务端发送的应用部署操作请求,所述应用部署操作请求包括目标应用的基础信息、操作命令和操作参数;
根据所述目标应用的基础信息,确定所述目标应用的应用类型,并确定与所述目标应用的应用类型匹配的代理模块;
通过所述与所述目标应用的应用类型匹配的代理模块,根据所述操作参数执行所述操作命令,得到执行结果;
将所述执行结果反馈给所述服务端。
第二方面,本申请提供一种应用部署方法,包括:
根据应用配置操作,配置应用的基础信息;
响应于对应用的部署操作,向代理端发送应用部署操作请求,所述应用部署操作请求包括目标应用的基础信息、操作命令和操作参数;
其中,所述应用部署操作请求用于指示所述代理端根据所述目标应用的基础信息,确定所述目标应用的应用类型,并确定与所述目标应用的应用类型匹配的代理模块,通过所述与所述目标应用的应用类型匹配的代理模块,根据所述操作参数执行所述操作命令,得到执行结果,并将所述执行结果反馈给所述服务端。
第三方面,本申请提供一种应用部署装置,包括:
通信模块,用于接收服务端发送的应用部署操作请求,所述应用部署操作请求包括目标应用的基础信息、操作命令和操作参数;
识别模块,用于根据所述目标应用的基础信息,确定所述目标应用的应用类型,并确定与所述目标应用的应用类型匹配的代理模块;
代理执行模块,用于通过所述与所述目标应用的应用类型匹配的代理模块,根据所述操作参数执行所述操作命令,得到执行结果;
所述通信模块还用于:将所述执行结果反馈给所述服务端。
第四方面,本申请提供一种应用部署装置,包括:
配置模块,用于根据应用配置操作,配置应用的基础信息;
通信模块,用于响应于对应用的部署操作,向代理端发送应用部署操作请求,所述应用部署操作请求包括目标应用的基础信息、操作命令和操作参数;
其中,所述应用部署操作请求用于指示所述代理端根据所述目标应用的基础信息,确定所述目标应用的应用类型,并确定与所述目标应用的应用类型匹配的代理模块,通过所述与所述目标应用的应用类型匹配的代理模块,根据所述操作参数执行所述操作命令,得到执行结果,并将所述执行结果反馈给所述服务端。
第五方面,本申请提供一种电子设备,包括:
处理器,存储器,以及存储在所述存储器上并可在所述处理器上运行的计算机程序;
其中,所述处理器运行所述计算机程序时实现上述任一方面所述的方法。
第六方面,本申请提供一种计算机可读存储介质,所述计算机可读存储介质中存储有计算机执行指令,所述计算机执行指令被处理器执行时用于实现上述任一方面所述的方法。
第七方面,本申请提供一种计算机程序产品,包括计算机程序,该计算机程序被处理器执行时实现上述任一方面所述的方法。
本申请提供的应用部署方法、装置、设备、存储介质及程序产品,基于应用自动化部署服务端和代理端的代理机制,通过在代理端设置不同运维环境对应不同代理模块(包括IIS代理、WAS代理、Linux/AIX代理),在进行自动化应用部署时,接收服务端发送的应用部署操作请求,所述应用部署操作请求包括目标应用的基础信息、操作命令和操作参数;根据所述目标应用的基础信息,确定所述目标应用的应用类型,并确定与所述目标应用的应用类型匹配的代理模块;通过所述与所述目标应用的应用类型匹配的代理模块,根据所述操作参数执行所述操作命令,得到执行结果;将所述执行结果反馈给所述服务端,能够适应于IIS、WAS、Linux/AIX等多种不同的运维环境,能够应用于银行应用平台等包含多种运维环境的应用、设备,存在很多复杂运维场景的应用平台,满足运维需求。
附图说明
此处的附图被并入说明书中并构成本说明书的一部分,示出了符合本申请的实施例,并与说明书一起用于解释本申请的原理。
图1为本申请实施例提供的应用部署的架构示意图;
图2为本申请实施例一提供的应用部署方法流程图;
图3为本申请实施例二提供的应用部署方法流程图;
图4为本申请实施例二提供的代理机制实现原理示意图;
图5为本申请实施例三提供的应用部署装置的结构示意图;
图6为本申请实施例四提供的应用部署装置的结构示意图;
图7为本申请实施例五提供的电子设备的结构示意图。
通过上述附图,已示出本申请明确的实施例,后文中将有更详细的描述。这些附图和文字描述并不是为了通过任何方式限制本申请构思的范围,而是通过参考特定实施例为本领域技术人员说明本申请的概念。
具体实施方式
这里将详细地对示例性实施例进行说明,其示例表示在附图中。下面的描述涉及附图时,除非另有表示,不同附图中的相同数字表示相同或相似的要素。以下示例性实施例中所描述的实施方式并不代表与本申请相一致的所有实施方式。相反,它们仅是与如所附权利要求书中所详述的、本申请的一些方面相一致的装置和方法的例子。
首先对本申请所涉及的名词进行解释:
代理:在分布式系统中持续自主发挥作用,具有自主性、交互性、反应性和主动性的活着的计算实体。本申请中也将代理称为“代理模块”。
应用:具有独立部署特点的一套目标码,部署在Windows、AIX和Linux等上的程序。
开放平台:基于PC Server或小型机的基础资源平台。
部署:在应用程序变更流程中,由应用支持人员进行的、针对生产环境应用程序的具体操作。
策略文件:策略文件以.stg后缀命名,是指一套代理程序能够识别和执行的脚本文件,分为部署策略文件和回退策略文件,供程序部署或回退时使用。
目前,应用自动化部署是应用运维场景的趋势,现有的主流自动化部署工具有ansible和saltstack等。Ansible是由具有不同功能的模块组成的一种自动化部署框架,其本身没有批量部署的能力,真正具有批量部署的是ansible运行的模块。Python语言实现,基于SSH协议传输数据,不需要在其服务器端安装客户端,使用时直接运行命令即可,可实现多级指挥。SaltStack是一个服务器基础架构集中化管理平台,具有配置管理、远程执行、监控等功能。Python语言实现,基于轻量级消息队列ZeroMQ实现快速通信,支持大部分UNIX/Linux及Windows环境,通过Salt-ssh在客户端部署。
其中,ansible的缺点是:效率不高,容易挂起,不太适合中大规模环境的应用场景;难以进行大批量、复杂的耗时业务操作。对于银行的应用平台等应用多、设备多、存在很多复杂运维场景,ansible无法满足运维需求。SaltStack要求以root权限安装master和monitor,风险很大,且master和monitor之间的通信采用zeroMQ,zeroMQ本身数据传输是不加密的,存在一定的安全风险;对于银行等安全要求严格的开放系统不提供root管理员权限,且安全等级要求高,SaltStack无法满足运维需求。
本实施例提供一种应用部署方法,可以采用如图1所示的架构,主要涉及两方面:应用自动化部署服务端和代理端的代理机制,策略文件的解析执行。首先,在应用自动化部署服务端配置应用的基础信息,然后由应用支持人员发送操作命令给代理端,代理端根据应用类型匹配相应代理执行操作命令,返回执行结果,其中不同应用类型对应的代理不同,例如,WAS应用、Linux/AIX应用、IIS应用分别对应的代理为:WAS代理、Linux/AIX代理、IIS代理。同时,针对应用部署和应用回退的各类操作,分解成原子操作,组合形成对应的策略文件,由代理端解析执行策略文件,实现各类操作原子操作,例如,WAS应用启停、卸载、文件备份、调用脚本,IIS清理、IIS启动等等。其中,代理是自动化部署工具的执行者,部署在具体应用的服务器上。
本实施例提供的方法,基于应用自动化部署服务端和代理端的代理机制,在进行自动化应用部署时,接收服务端发送的应用部署操作请求,应用部署操作请求包括目标应用的基础信息、操作命令和操作参数;根据目标应用的基础信息,确定目标应用的应用类型,并确定与目标应用的应用类型匹配的代理模块;通过与目标应用的应用类型匹配的代理模块,根据操作参数执行操作命令,得到执行结果;将执行结果反馈给服务端,能够适应于多种不同的运维环境,能够应用于银行应用平台等包含多种运维环境的应用、设备,存在很多复杂运维场景的应用平台,满足运维需求。
下面以具体地实施例对本申请的技术方案以及本申请的技术方案如何解决上述技术问题进行详细说明。下面这几个具体的实施例可以相互结合,对于相同或相似的概念或过程可能在某些实施例中不再赘述。下面将结合附图,对本申请的实施例进行描述。
实施例一
图2为本申请实施例一提供的应用部署方法流程图。本实施例中的方法应用于应用平台,应用平台包括自动化部署的服务端的设备和代理端设备。例如,银行应用平台的集群等,在其他实施例中,该方法还可应用于其他电子设备,本实施例以应用平台为例进行示意性说明。如图2所示,该方法具体步骤如下:
步骤S101、服务端根据应用配置操作,配置应用的基础信息。
本实施例中,运维人员可以在服务端配置应用的基础信息。
其中,应用基础信息包括应用名称、应用设备信息(包括IP地址、操作系统类型等)、程序类型(比如IIS下的Web应用、Windows服务、WAS站点应用、AIX\LINUX应用等)、备份文件路径、发布文件路径、配置源应用部署包位置等。
步骤S102、响应于对应用的部署操作,服务端向代理端发送应用部署操作请求,应用部署操作请求包括目标应用的基础信息、操作命令和操作参数。
本实施例中,运维人员可以通过服务端向代理端发送操作命令及操作参数。
其中,操作命令包括但不限于:应用程序包上传(upload)、应用部署(deploy)、应用部署完成验证(check)、应用回退(rollback)、查看日志(getcurrentlog)、获取应用最新版本(getversion)、代理自检查操作(isalive)等。
应用配置的基础信息将作为操作命令的操作参数,结合具体的操作命令,以xml规范的形式生成应用部署操作请求,并传输给代理端。
步骤S103、代理端接收服务端发送的应用部署操作请求。
步骤S104、代理端根据目标应用的基础信息,确定目标应用的应用类型,并确定与目标应用的应用类型匹配的代理模块。
在接收到服务端的应用部署操作请求之后,代理端通过解析应用部署操作请求,能够得到目标应用的基础信息、操作命令和操作参数。
其中,目标应用的应用类型为以下任意一种:IIS应用、WAS应用、Linux/AIX应用。
与IIS应用匹配的代理模块为IIS代理,与WAS应用匹配的代理模块为WAS代理,与Linux/AIX应用匹配的代理模块为Linux/AIX代理。
本实施例中,可以预先配置应用的操作系统类型与应用类型之间的映射关系。该步骤中,可以从目标应用的基础信息确定目标应用的操作系统类型,根据应用的操作系统类型与应用类型之间的映射关系,可以确定目标应用的操作系统类型对应的应用类型,得到目标应用的应用类型;进一步确定目标应用的应用类型匹配的代理模块。
可选地,可以预先配置各应用类型与各类型的代理模块之间的映射关系并存储。
步骤S105、代理端通过与目标应用的应用类型匹配的代理模块,根据操作参数执行操作命令,得到执行结果。
在确定与目标应用的应用类型匹配的代理模块之后,通过代理端通过与目标应用的应用类型匹配的代理模块,根据操作参数执行操作命令,得到执行结果。
步骤S106、代理端将执行结果反馈给服务端。
其中,执行结果用来展示代理执行成败和失败原因,可以包含结果编码(用code节点表示)、结果标题(用title节点表示)和详细内容(用detail节点表示),同样以xml规范返回给服务端。
例如,以服务端部署资源包上传upload请求的返回结果为例,执行结果如下所示:
<?xml version="1.0"encoding="utf-8"?>
<return>
<code>0000</code>//结果编码
<title>文件上传成功</title>//结果标题
<detail>文件filename接受成功,共13211322字节</detail>//详细内容
</return>
本申请实施例基于应用自动化部署服务端和代理端的代理机制,通过在代理端设置不同运维环境对应不同代理模块(包括IIS代理、WAS代理、Linux/AIX代理),在进行自动化应用部署时,接收服务端发送的应用部署操作请求,应用部署操作请求包括目标应用的基础信息、操作命令和操作参数;根据目标应用的基础信息,确定目标应用的应用类型,并确定与目标应用的应用类型匹配的代理模块;通过与目标应用的应用类型匹配的代理模块,根据操作参数执行操作命令,得到执行结果;将执行结果反馈给服务端,能够适应于IIS、WAS、Linux/AIX等多种不同的运维环境,能够应用于银行应用平台等包含多种运维环境的应用、设备,存在很多复杂运维场景的应用平台,满足运维需求。
实施例二
图3为本申请实施例二提供的应用部署方法流程图,图4为本申请实施例二提供的代理机制实现原理示意图。在上述实施例一的基础上,本实施例中,代理是自动化部署工具的执行者,部署在具体应用的服务器上,以守护进程的形式存在,提供Socket协议的服务。代理机制实现原理如图4所示,服务端向代理端下发socket报文(应用部署请求),代理端会监听来自服务端的socket报文,以多线程的方式处理多个请求任务,当收到服务端的socket报文时,会启用一个新的线程进行相应的报文识别、功能处理和结果返回等处理。这样,代理端能够批量分发程序、批量部署、批量回退、批量执行命令等,实现了应用自动化批量部署,减少人工干预导致的部署失败风险,提高应用部署的效率。
应用手工部署流程涉及到的操作至少包括:应用程序包上传(upload)、应用部署(deploy)、应用部署完成验证(check)、应用回退(rollback)、查看日志(getcurrentlog)、获取应用最新版本(getversion)等,其中每个操作又包括更多更小的操作,且在生产环境出现失误的风险很大。
本实施例中,将以上操作和代理自检查操作(isalive)交由代理程序实现,在自动实现操作的同时也确保了操作的正确性和安全性。主要思想是:将操作细节隐藏,服务端将操作命令和参数以xml规范,通过socket协议发送给代理,代理接收到socket报文进行安全确认后,解析xml,根据参数执行完操作命令对应操作细节,并将结果返回给前端。
本实施例中,将应用部署和应用回退的操作分解为多个原子操作,如应用备份、停止、启动、卸载、调用脚本等,并将原子操作以关键字的形式形成操作规范,组合成部署策略文件和回退策略文件,供代理端自动执行实现应用部署和应用回退。其中,策略文件可以是扩展名为.STG的文件。
如图3所示,该方法具体步骤如下:
步骤S201、响应于任一应用的任一操作命令的策略文件生成指令,服务端获取输入的有序排列的多个原子操作。
在银行等应用平台中,基于Linux、Windows、WAS系统的开放平台的应用部署和应用回退操作方式不一致,如Linux一般采用shell脚本、linux标准命令等进行应用部署和应用回退,Windows通常采用启用IIS服务、调用bat脚本、调用Windows底层命令等方式进行应用部署和应用回退,WAS系统调用was标准命令进行应用部署和应用回退。但IIS、WAS、CICS三类标准中间件在应用部署和回退时具有共同操作,通过对各类应用系统的需求调研,将应用部署和应用回退的操作分解为原子操作(如应用备份、停止、启动、卸载、调用脚本等),并以关键字的形式形成操作规范。将多个原子操作的关键字组合成部署策略文件和回退策略文件,可以由代理端自动执行对应的策略文件实现应用部署和回退。另外,除了应用部署和应用回退的操作之外,其他复杂操作也可以分解成多个原子操作,通过原子操作组合成对应的策略文件,由代理端自动执行对应的策略文件实现对应的操作功能。
用户可以在服务端使用已有的原子操作,编排生成任一应用的任一操作命令对应的策略文件。策略文件中包括有序排列的多个原子操作。
可选地,响应于任一类型的代理模块的原子操作查询请求,服务端可以显示该类型的代理模块的原子操作及原子操作的描述信息,以供用户参考和选择所需的原子操作。
其中,原子操作的描述信息用于描述原子操作所能实现的功能,可以是原子操作的功能简介。
示例性地,Linux/AIX代理的策略文件中可以使用的原子操作的关键字及其描述信息可以如下表1所示:
表1
关键字 功能简介
untar 解压app下.tar或.tar.Z结尾的程序包
unzip 解压app下.zip结尾的程序包
backup4ebb 根据目标码备份
backup4mbap 从生产站点根目录全量备份
stopapp 执行配置中的停止脚本
startapp 执行配置中的启动脚本
deletebin 删除站点的bin目录
deploy4ebb 使用mv方式将目标码移动至相应生产目录
deploy4mbap 将所有文件夹拷贝至生产目录,并授权777
rollback4ebb 根据指定的目标码进行回退
rollback4mbap 整个站点进行回退
exec 执行app、deploy、rollback下的指定脚本
示例性地,IIS代理的策略文件中可以使用的原子操作的关键字及其描述信息可以如下表2所示:
表2
关键字 功能简介
IISStop 停止IIS服务
RetrieveAppPool 回收应用程序池
UnZipAppFile 解压指定应用名的应用部署包到部署准备目录
DeleteWebSiteFolder 删除生产代码下所有文件(发全量包)
DeleteBinFolder 删除生产代码下的bin目录
UpdateAimPaths 执行本次变更,更新原生产代码(含备份步骤)
RollbackAimPaths 执行本次变更回退,删除生产目录后,使用备份目录覆盖
AppWinServStop 停止应用程序对应的windows服务
AppWinServReStart 重启应用程序对应的windows服务
AppWinServStart 启动应用程序对应的windows服务
AppSiteStart 启动iis的site站点
AppSiteStop 停止iis的site站点
AppPoolStart 启动应用程序池
AppPoolStop 停止应用程序池
Exec 执行deploy目录下的脚本文件
IISStart 启动IIS服务
Delay 按照设定时间(单位秒)进行线程延时
示例性地,WAS代理的策略文件中可以使用的原子操作的关键字及其描述信息可以如下表3所示:
表3
策略文件关键字 功能简介
startCluster 启动集群
stopCluster 停集群
install 安装应用程序
uninstall 卸载应用程序
startApplication 启动应用程序
stopApplication 停止应用程序
export 导出应用程序以进行备份
exec 执行指定的脚本文件
update 通过zip进行部分更新
setClassLoaderParentLast 设置父类最后加载
setParentLastForApplication 设置父类最后加载(应用程序)
setParentLastForModle 设置父类最后加载(web模块)
rollback 通过export导出的ear进行回退
setSharedLibrary 设置共享库
setVirtualHost 设置虚拟主机
installWithLib 绑定共享库安装
installWithHost 绑定虚拟主机安装
checkAppRun 检查应用程序是否处于运行状态
checkAppStop 检查应用程序是否处于停止状态
immediateStopCluster 立即停止集群
installWithPreCompile 预编译安装
步骤S202、服务端生成包含有序排列的多个原子操作的策略文件;生成任一应用的部署资源包,部署资源包至少包括任一应用的策略文件和程序包。
本实施例中,根据有序排列的多个原子操作,生成对应的策略文件。
在策略文件编写规范里,可以以“$”加关键字来表示对应的原子操作(如$startCluster代表启停集群),在应用部署一开始,运维人员可以自由选择组合原子操作形成部署策略文件和回退策略文件(可以分别用deploy.stg和rollback.stg表示),原子操作的组合规则一定要符合策略规则库,例如backup原子操作一定要在install原子操作之前,由此形成的部署策,略文件和回退策略文件在顺序和逻辑上满足部署要求,减少了人工校验的麻烦。
其中,策略规则库可以根据实际应用场景的需要进行设置和调整,本实施例此处不做具体限定。
示例性地,Linux/AIX代理的部署策略文件可以包括如下所示关键字:
$untar
$backup4ebb
$deploy4ebb
其中,各个关键字对应原子操作的功能简介如表1中所示。
在生成应用的操作命令对应的策略文件之后,服务端可以将应用的策略文件和程序包打包生成应用的部署资源包,并将应用的部署资源包发送给代理端。
步骤S203、服务端将任一应用的部署资源包发送给代理端。
步骤S204、代理端接收服务端发送的应用的部署资源包。
代理端接收到应用的部署资源包之后,将应用的标识信息与应用的部署资源包对应存储。代理端根据应用的标识信息(如应用名称等)可以根据应用名匹配应用的部署资源包中的策略文件,可以对策略文件提取出关键字,为执行策略文件做准备。
步骤S205、服务端根据应用配置操作,配置应用的基础信息。
本实施例中,服务端还可以配置应用的基础信息。
其中,应用基础信息包括应用名称、应用设备信息(包括IP地址、操作系统类型等)、程序类型(比如IIS下的Web应用、Windows服务、WAS站点应用、AIX\LINUX应用等)、备份文件路径、发布文件路径、配置源应用部署包位置等。
步骤S206、响应于对应用的部署操作,服务端生成应用部署操作请求报文,应用部署操作请求报文为socket报文,应用部署操作请求报文包括目标应用的基础信息、操作命令和操作参数。
本实施例中,运维人员可以通过服务端向代理端发送操作命令及操作参数。
其中,操作命令包括但不限于:应用程序包上传(upload)、应用部署(deploy)、应用部署完成验证(check)、应用回退(rollback)、查看日志(getcurrentlog)、获取应用最新版本(getversion)、代理自检查操作(isalive)等。
应用配置的基础信息将作为操作命令的操作参数,结合具体的操作命令,以xml规范的形式生成应用部署操作请求报文(socket报文)进行传输。
示例性地,socket报文由命令节点(command节点)和参数节点(parameters节点)两部分组成,以应用程序包上传(upload)的socket报文为例,包括如下内容:
Figure BDA0003124735710000121
其中,应用程序包上传(upload)的上传路径可以在配置文件中获取。
步骤S207、服务端向代理端发送应用部署操作请求报文。
在生成操作命令对应的应用部署操作请求报文之后,服务端向代理端发送应用部署操作请求报文。
步骤S208、代理端监听服务端发送的应用部署操作请求报文。
其中,应用部署操作请求报文为socket报文。
本实施例中,代理端通过指定端口监听服务端发送的应用部署操作请求报文。
例如,代理端的7777端口会监听来自服务端的应用部署操作请求报文。
步骤S209、代理端解析应用部署操作请求报文,得到目标应用的基础信息、操作命令和操作参数。
在监听、接收到服务端的应用部署操作请求报文之后,代理端通过解析应用部署操作请求报文,能够得到目标应用的基础信息、操作命令和操作参数。
步骤S210、根据目标应用的基础信息,确定目标应用的应用类型,并确定与目标应用的应用类型匹配的代理模块。
其中,目标应用的应用类型为以下任意一种:IIS应用、WAS应用、Linux/AIX应用。
与IIS应用匹配的代理模块为IIS代理,与WAS应用匹配的代理模块为WAS代理,与Linux/AIX应用匹配的代理模块为Linux/AIX代理。
本实施例中,可以预先配置应用的操作系统类型与应用类型之间的映射关系。该步骤中,可以从目标应用的基础信息确定目标应用的操作系统类型,根据应用的操作系统类型与应用类型之间的映射关系,可以确定目标应用的操作系统类型对应的应用类型,得到目标应用的应用类型;进一步确定目标应用的应用类型匹配的代理模块。
可选地,可以预先配置各应用类型与各类型的代理模块之间的映射关系并存储。
步骤S211、通过与目标应用的应用类型匹配的代理模块对应的进程,创建线程;通过线程,根据操作参数执行操作命令,得到执行结果。
本实施例中,代理端通过与目标应用的应用类型匹配的代理模块对应的进程,创建线程;通过线程,根据操作参数执行操作命令,得到执行结果。这样,当收到服务端的socket报文时,会启用一个新的线程进行相应的报文识别、功能处理和结果返回等处理。这样,代理端能够以多线程的方式批量处理多个请求任务,能够实现批量分发程序、批量部署、批量回退、批量执行命令等,实现了应用自动化批量部署,减少人工干预导致的部署失败风险,提高应用部署的效率。
具体地,该步骤中,获取目标应用的配置文件;根据目标应用的配置文件,根据操作参数执行操作命令,得到执行结果。
进一步地,若操作命令为应用部署或者应用回退,则根据目标应用的配置文件,获取目标应用的与操作命令对应的策略文件;解析策略文件,得到有序排列的多个原子操作;根据操作参数,依次执行多个原子操作,得到执行结果。
示例性地,执行策略文件包含的任一原子操作时,可以根据原子操作的关键字去调用相应应用程序编程接口(Application Programming Interface,简称API)、调用shell脚本\bat脚本、或调用标准命令(如linux命令,was控制台命令等)等,实现对应原子操作的逻辑功能。
步骤S212、代理端将执行结果反馈给服务端。
其中,执行结果用来展示代理执行成败和失败原因,可以包含结果编码(用code节点表示)、结果标题(用title节点表示)和详细内容(用detail节点表示),同样以xml规范返回给服务端。
例如,以服务端部署资源包上传upload请求的返回结果为例,执行结果如下所示:
<?xml version="1.0"encoding="utf-8"?>
<return>
<code>0000</code>//结果编码
<title>文件上传成功</title>//结果标题
<detail>文件filename接受成功,共13211322字节</detail>//详细内容
</return>
本实施例中,为了实现socket传输,还需要建立socket连接,并在返回执行结果后,关闭socket连接。
示例性地,如图4所示,针对服务端的每一请求,代理端可以启动一个新的线程,该线程执行如下流程,实现操作命令对应的功能处理:
(1)建立socket连接;
(2)报文识别:根据socket报文中的command字段识别操作命令的类型;
(3)功能处理:根据操作命令的类型和操作参数执行对应的操作命令,实现对应的功能逻辑;
(4)结果返回:返回执行结果;
(5)关闭socket连接。
本实施例提供一套标准的交互规范组织代理,实现了在不同的场景下完成特色的运维能力,兼顾规范化和本地化,解决庞大而复杂环境下的运维问题,同时着眼于未来,从设计上考虑对更多运维场景的支持,提高产品交付效率,有效保障生产运行安全。
本申请实施例利用代理机制能代替应用支持人员进行相关部署操作,整个部署流程由代理实现,减少人工操作的失误,提高应用部署的可靠性;通过灵活地配置,代理端能够实现批量分发程序、批量部署、批量回退、批量执行命令等,实现了应用自动化批量部署,减少人工干预导致的部署失败风险,提高应用部署的效率。进一步地,将应用部署和应用回退等操作分解成多个原子操作,通过灵活地组合原子操作生成策略文件,能够更加灵活地自动执行应用部署和回退操作,提高了灵活性。
实施例三
图5为本申请实施例三提供的应用部署装置的结构示意图。本申请实施例提供的应用部署装置可以执行应用部署方法实施例提供的处理流程。如图5所示,该应用部署装置30包括:通信模块301,识别模块302和代理执行模块303。
具体地,通信模块301,用于接收服务端发送的应用部署操作请求,应用部署操作请求包括目标应用的基础信息、操作命令和操作参数。
识别模块302,用于根据目标应用的基础信息,确定目标应用的应用类型,并确定与目标应用的应用类型匹配的代理模块。
代理执行模块303,用于通过与目标应用的应用类型匹配的代理模块,根据操作参数执行操作命令,得到执行结果。
通信模块301还用于:将执行结果反馈给服务端。
一种可选的实施方式中,目标应用的应用类型为以下任意一种:IIS应用、WAS应用、Linux/AIX应用;与IIS应用匹配的代理模块为IIS代理,与WAS应用匹配的代理模块为WAS代理,与Linux/AIX应用匹配的代理模块为Linux/AIX代理。
一种可选的实施方式中,通信模块301还用于:
监听服务端发送的应用部署操作请求报文,应用部署操作请求报文为socket报文。
识别模块302还用于:解析应用部署操作请求报文,得到目标应用的基础信息、操作命令和操作参数。
一种可选的实施方式中,代理执行模块303还用于:
通过与目标应用的应用类型匹配的代理模块对应的进程,创建线程;通过线程,根据操作参数执行操作命令,得到执行结果。
一种可选的实施方式中,代理执行模块303还用于:
获取目标应用的配置文件;根据目标应用的配置文件,根据操作参数执行操作命令,得到执行结果。
一种可选的实施方式中,代理执行模块303还用于:
若操作命令为应用部署或者应用回退,则根据目标应用的配置文件,获取目标应用的与操作命令对应的策略文件;解析策略文件,得到有序排列的多个原子操作;根据操作参数,依次执行多个原子操作,得到执行结果。
一种可选的实施方式中,通信模块301还用于:
接收服务端发送的目标应用的部署资源包,部署资源包至少包括目标应用的策略文件和程序包。
本申请实施例提供的装置可以具体用于执行上述任一方法实施例中代理端所执行的方法流程,具体功能此处不再赘述。
本申请实施例利用代理机制能代替应用支持人员进行相关部署操作,整个部署流程由代理实现,减少人工操作的失误,提高应用部署的可靠性;通过灵活地配置,代理端能够实现批量分发程序、批量部署、批量回退、批量执行命令等,实现了应用自动化批量部署,减少人工干预导致的部署失败风险,提高应用部署的效率。进一步地,将应用部署和应用回退等操作分解成多个原子操作,通过灵活地组合原子操作生成策略文件,能够更加灵活地自动执行应用部署和回退操作,提高了灵活性。
实施例四
图6为本申请实施例四提供的应用部署装置的结构示意图。本申请实施例提供的应用部署装置可以执行应用部署方法实施例提供的处理流程。如图6所示,该应用部署装置40包括:配置模块401和请求发送模块402。
具体地,配置模块401,用于根据应用配置操作,配置应用的基础信息。
请求发送模块402,用于响应于对应用的部署操作,向代理端发送应用部署操作请求,应用部署操作请求包括目标应用的基础信息、操作命令和操作参数。
其中,应用部署操作请求用于指示代理端根据目标应用的基础信息,确定目标应用的应用类型,并确定与目标应用的应用类型匹配的代理模块,通过与目标应用的应用类型匹配的代理模块,根据操作参数执行操作命令,得到执行结果,并将执行结果反馈给服务端。
一种可选的实施方式中,请求发送模块402还用于:
响应于对应用的部署操作,生成应用部署操作请求报文,应用部署操作请求报文为socket报文,应用部署操作请求报文包括目标应用的基础信息、操作命令和操作参数;向代理端发送应用部署操作请求报文。
一种可选的实施方式中,配置模块401还用于:
响应于任一应用的任一操作命令的策略文件生成指令,获取输入的有序排列的多个原子操作;生成包含有序排列的多个原子操作的策略文件;生成任一应用的部署资源包,并将任一应用的部署资源包发送给代理端,其中,部署资源包至少包括任一应用的策略文件和程序包。
本申请实施例提供的装置可以具体用于执行上述任一方法实施例中服务端所执行的方法流程,具体功能此处不再赘述。
本申请实施例利用代理机制能代替应用支持人员进行相关部署操作,整个部署流程由代理实现,减少人工操作的失误,提高应用部署的可靠性;通过灵活地配置,代理端能够实现批量分发程序、批量部署、批量回退、批量执行命令等,实现了应用自动化批量部署,减少人工干预导致的部署失败风险,提高应用部署的效率。进一步地,将应用部署和应用回退等操作分解成多个原子操作,通过灵活地组合原子操作生成策略文件,能够更加灵活地自动执行应用部署和回退操作,提高了灵活性。
实施例五
图7为本申请实施例五提供的电子设备的结构示意图。如图7所示,该电子设备70包括:处理器701,存储器702,以及存储在存储器702上并可在处理器701上运行的计算机程序。
其中,处理器701运行计算机程序时实现上述任一方法实施例中代理端或者服务端所执行的方法流程。
本申请实施例利用代理机制能代替应用支持人员进行相关部署操作,整个部署流程由代理实现,减少人工操作的失误,提高应用部署的可靠性;通过灵活地配置,代理端能够实现批量分发程序、批量部署、批量回退、批量执行命令等,实现了应用自动化批量部署,减少人工干预导致的部署失败风险,提高应用部署的效率。进一步地,将应用部署和应用回退等操作分解成多个原子操作,通过灵活地组合原子操作生成策略文件,能够更加灵活地自动执行应用部署和回退操作,提高了灵活性。
本申请实施例还提供一种计算机可读存储介质,计算机可读存储介质中存储有计算机程序,计算机程序被处理器执行时实现上述任一方法实施例中代理端或者服务端所执行的方法流程。
本申请实施例还提供了一种计算机程序产品,程序产品包括:计算机程序,计算机程序存储在可读存储介质中,电子设备的至少一个处理器可以从可读存储介质读取计算机程序,至少一个处理器执行计算机程序使得,电子设备执行上述任一方法实施例中代理端或者服务端所执行的方法流程。
在本申请所提供的几个实施例中,应该理解到,所揭露的装置和方法,可以通过其它的方式实现。例如,以上所描述的装置实施例仅仅是示意性的,例如,单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,例如多个单元或组件可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通信连接可以是通过一些接口,装置或单元的间接耦合或通信连接,可以是电性,机械或其它的形式。
作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部单元来实现本实施例方案的目的。
另外,在本申请各个实施例中的各功能单元可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中。上述集成的单元既可以采用硬件的形式实现,也可以采用硬件加软件功能单元的形式实现。
上述以软件功能单元的形式实现的集成的单元,可以存储在一个计算机可读取存储介质中。上述软件功能单元存储在一个存储介质中,包括若干指令用以使得一台计算机设备(可以是个人计算机,服务器,或者网络设备等)或处理器(processor)执行本申请各个实施例方法的部分步骤。而前述的存储介质包括:U盘、移动硬盘、只读存储器(Read-OnlyMemory,ROM)、随机存取存储器(Random Access Memory,RAM)、磁碟或者光盘等各种可以存储程序代码的介质。
本领域技术人员可以清楚地了解到,为描述的方便和简洁,仅以上述各功能模块的划分进行举例说明,实际应用中,可以根据需要而将上述功能分配由不同的功能模块完成,即将装置的内部结构划分成不同的功能模块,以完成以上描述的全部或者部分功能。上述描述的装置的具体工作过程,可以参考前述方法实施例中的对应过程,在此不再赘述。
本领域技术人员在考虑说明书及实践这里公开的发明后,将容易想到本申请的其它实施方案。本申请旨在涵盖本申请的任何变型、用途或者适应性变化,这些变型、用途或者适应性变化遵循本申请的一般性原理并包括本申请未公开的本技术领域中的公知常识或惯用技术手段。说明书和实施例仅被视为示例性的,本申请的真正范围和精神由下面的权利要求书指出。
应当理解的是,本申请并不局限于上面已经描述并在附图中示出的精确结构,并且可以在不脱离其范围进行各种修改和改变。本申请的范围仅由所附的权利要求书来限制。

Claims (15)

1.一种应用部署方法,其特征在于,包括:
接收服务端发送的应用部署操作请求,所述应用部署操作请求包括目标应用的基础信息、操作命令和操作参数;
根据所述目标应用的基础信息,确定所述目标应用的应用类型,并确定与所述目标应用的应用类型匹配的代理模块;
通过所述与所述目标应用的应用类型匹配的代理模块,根据所述操作参数执行所述操作命令,得到执行结果;
将所述执行结果反馈给所述服务端。
2.根据权利要求1所述的方法,其特征在于,
所述目标应用的应用类型为以下任意一种:IIS应用、WAS应用、Linux/AIX应用;
与IIS应用匹配的代理模块为IIS代理,与WAS应用匹配的代理模块为WAS代理,与Linux/AIX应用匹配的代理模块为Linux/AIX代理。
3.根据权利要求1所述的方法,其特征在于,所述接收服务端发送的应用部署操作请求,所述应用部署操作请求包括目标应用的基础信息、操作命令和操作参数,包括:
监听所述服务端发送的应用部署操作请求报文,所述应用部署操作请求报文为socket报文;
解析所述应用部署操作请求报文,得到目标应用的基础信息、操作命令和操作参数。
4.根据权利要求1所述的方法,其特征在于,所述通过所述与所述目标应用的应用类型匹配的代理模块,根据所述操作参数执行所述操作命令,得到执行结果,包括:
通过所述与所述目标应用的应用类型匹配的代理模块对应的进程,创建线程;
通过所述线程,根据所述操作参数执行所述操作命令,得到执行结果。
5.根据权利要求1-4中任一项所述的方法,其特征在于,所述根据所述操作参数执行所述操作命令,得到执行结果,包括:
获取所述目标应用的配置文件;
根据所述目标应用的配置文件,根据所述操作参数执行所述操作命令,得到执行结果。
6.根据权利要求5所述的方法,其特征在于,所述根据所述目标应用的配置文件,根据所述操作参数执行所述操作命令,得到执行结果,包括:
若所述操作命令为应用部署或者应用回退,则根据所述目标应用的配置文件,获取所述目标应用的与所述操作命令对应的策略文件;
解析所述策略文件,得到有序排列的多个原子操作;
根据所述操作参数,依次执行所述多个原子操作,得到所述执行结果。
7.根据权利要求6所述的方法,其特征在于,所述若所述操作命令为应用部署或者应用回退,则根据所述目标应用的配置文件,获取所述目标应用的与所述操作命令对应的策略文件之前,还包括:
接收服务端发送的所述目标应用的部署资源包,所述部署资源包至少包括所述目标应用的策略文件和程序包。
8.一种应用部署方法,其特征在于,包括:
根据应用配置操作,配置应用的基础信息;
响应于对应用的部署操作,向代理端发送应用部署操作请求,所述应用部署操作请求包括目标应用的基础信息、操作命令和操作参数;
其中,所述应用部署操作请求用于指示所述代理端根据所述目标应用的基础信息,确定所述目标应用的应用类型,并确定与所述目标应用的应用类型匹配的代理模块,通过所述与所述目标应用的应用类型匹配的代理模块,根据所述操作参数执行所述操作命令,得到执行结果,并将所述执行结果反馈给所述服务端。
9.根据权利要求8所述的方法,其特征在于,所述响应于对应用的部署操作,向代理端发送应用部署操作请求,所述应用部署操作请求包括目标应用的基础信息、操作命令和操作参数,包括:
响应于对应用的部署操作,生成应用部署操作请求报文,所述应用部署操作请求报文为socket报文,所述应用部署操作请求报文包括目标应用的基础信息、操作命令和操作参数;
向所述代理端发送所述应用部署操作请求报文。
10.根据权利要求8所述的方法,其特征在于,所述响应于对应用的部署操作,向代理端发送应用部署操作请求之前,还包括:
响应于任一应用的任一操作命令的策略文件生成指令,获取输入的有序排列的多个原子操作;
生成包含所述有序排列的多个原子操作的策略文件;
生成所述任一应用的部署资源包,并将所述任一应用的部署资源包发送给代理端,其中,所述部署资源包至少包括所述任一应用的策略文件和程序包。
11.一种应用部署装置,其特征在于,包括:
通信模块,用于接收服务端发送的应用部署操作请求,所述应用部署操作请求包括目标应用的基础信息、操作命令和操作参数;
识别模块,用于根据所述目标应用的基础信息,确定所述目标应用的应用类型,并确定与所述目标应用的应用类型匹配的代理模块;
代理执行模块,用于通过所述与所述目标应用的应用类型匹配的代理模块,根据所述操作参数执行所述操作命令,得到执行结果;
所述通信模块还用于:将所述执行结果反馈给所述服务端。
12.一种应用部署装置,其特征在于,包括:
配置模块,用于根据应用配置操作,配置应用的基础信息;
请求发送模块,用于响应于对应用的部署操作,向代理端发送应用部署操作请求,所述应用部署操作请求包括目标应用的基础信息、操作命令和操作参数;
其中,所述应用部署操作请求用于指示所述代理端根据所述目标应用的基础信息,确定所述目标应用的应用类型,并确定与所述目标应用的应用类型匹配的代理模块,通过所述与所述目标应用的应用类型匹配的代理模块,根据所述操作参数执行所述操作命令,得到执行结果,并将所述执行结果反馈给所述服务端。
13.一种电子设备,其特征在于,包括:
处理器,存储器,以及存储在所述存储器上并可在所述处理器上运行的计算机程序;
其中,所述处理器运行所述计算机程序时实现如权利要求1-10中任一项所述的方法。
14.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质中存储有计算机执行指令,所述计算机执行指令被处理器执行时用于实现如权利要求1-10中任一项所述的方法。
15.一种计算机程序产品,其特征在于,包括计算机程序,该计算机程序被处理器执行时实现权利要求1-10中任一项所述的方法。
CN202110686390.2A 2021-06-21 2021-06-21 应用部署方法、装置、设备、存储介质及程序产品 Pending CN113296795A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202110686390.2A CN113296795A (zh) 2021-06-21 2021-06-21 应用部署方法、装置、设备、存储介质及程序产品

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202110686390.2A CN113296795A (zh) 2021-06-21 2021-06-21 应用部署方法、装置、设备、存储介质及程序产品

Publications (1)

Publication Number Publication Date
CN113296795A true CN113296795A (zh) 2021-08-24

Family

ID=77328983

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202110686390.2A Pending CN113296795A (zh) 2021-06-21 2021-06-21 应用部署方法、装置、设备、存储介质及程序产品

Country Status (1)

Country Link
CN (1) CN113296795A (zh)

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN114389936A (zh) * 2021-11-26 2022-04-22 上海景域智能科技有限公司 一种跨云多集群部署运维方法、系统、处理器和存储介质
CN115525362A (zh) * 2022-09-29 2022-12-27 建信金融科技有限责任公司 基于操作系统内核参数调整平台的参数变更方法和装置

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8505005B1 (en) * 2007-07-24 2013-08-06 United Services Automobile Association (Usaa) Multi-platform network-based software distribution
US20140282495A1 (en) * 2013-03-13 2014-09-18 Pablo Chico de Guzman Huerta Deploying, monitoring, and controlling multiple components of an application
CN109656569A (zh) * 2018-10-16 2019-04-19 平安普惠企业管理有限公司 多环境应用部署方法、设备、存储介质及装置
CN110463162A (zh) * 2017-09-19 2019-11-15 华为技术有限公司 应用部署方法、装置及系统

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8505005B1 (en) * 2007-07-24 2013-08-06 United Services Automobile Association (Usaa) Multi-platform network-based software distribution
US20140282495A1 (en) * 2013-03-13 2014-09-18 Pablo Chico de Guzman Huerta Deploying, monitoring, and controlling multiple components of an application
CN110463162A (zh) * 2017-09-19 2019-11-15 华为技术有限公司 应用部署方法、装置及系统
CN112732273A (zh) * 2017-09-19 2021-04-30 华为技术有限公司 应用部署方法、装置及系统
CN109656569A (zh) * 2018-10-16 2019-04-19 平安普惠企业管理有限公司 多环境应用部署方法、设备、存储介质及装置

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN114389936A (zh) * 2021-11-26 2022-04-22 上海景域智能科技有限公司 一种跨云多集群部署运维方法、系统、处理器和存储介质
CN115525362A (zh) * 2022-09-29 2022-12-27 建信金融科技有限责任公司 基于操作系统内核参数调整平台的参数变更方法和装置
CN115525362B (zh) * 2022-09-29 2023-09-15 建信金融科技有限责任公司 基于操作系统内核参数调整平台的参数变更方法和装置

Similar Documents

Publication Publication Date Title
CN110752947B (zh) 一种k8s集群部署方法及装置,一种部署平台
CN109120678B (zh) 用于分布式存储系统的服务托管的方法和装置
US8151277B2 (en) Method and system for dynamic remote injection of in-process agents into virtual machine based applications
US8464246B2 (en) Automation of mainframe software deployment
US8104043B2 (en) System and method for dynamic cooperative distributed execution of computer tasks without a centralized controller
US8166458B2 (en) Method and system for automated distributed software testing
US9575739B2 (en) Performing unattended software installation
US7694181B2 (en) Automated software testing framework
CN112463144B (zh) 分布式存储的命令行服务方法、系统、终端及存储介质
CN109298868B (zh) 测绘影像数据处理软件智能动态部署及卸载方法
US20150242200A1 (en) Re-configuration in cloud computing environments
CN106681956A (zh) 一种大规模计算机集群的操作方法及装置
US20170123777A1 (en) Deploying applications on application platforms
CN113434158B (zh) 一种大数据组件的自定义管理方法、装置、设备及介质
US9542226B2 (en) Operating programs on a computer cluster
CN111324599B (zh) 一种区块链实验系统及管理方法
CN113296795A (zh) 应用部署方法、装置、设备、存储介质及程序产品
US20150100831A1 (en) Method and system for selecting and executing test scripts
CN113778486A (zh) 一种代码流水线的容器化处理方法、装置、介质及设备
CN110890987A (zh) 自动创建集群的方法、装置、设备和系统
CN114443294B (zh) 大数据服务组件部署方法、系统、终端及存储介质
CN112565416B (zh) 基于云原生的大规模边缘安卓设备纳管系统及其纳管方法
CN110011827A (zh) 面向医联体的多用户大数据分析服务系统和方法
CN114500268B (zh) chart资源的部署方法、装置、服务器及存储介质
CN113515293B (zh) 一种管理DevOps工具链的方法和系统

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