CN1620653A - 计算网络中服务的动态部署 - Google Patents

计算网络中服务的动态部署 Download PDF

Info

Publication number
CN1620653A
CN1620653A CNA018220134A CN01822013A CN1620653A CN 1620653 A CN1620653 A CN 1620653A CN A018220134 A CNA018220134 A CN A018220134A CN 01822013 A CN01822013 A CN 01822013A CN 1620653 A CN1620653 A CN 1620653A
Authority
CN
China
Prior art keywords
service
deployment
selection
request
accordance
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
CNA018220134A
Other languages
English (en)
Inventor
彼得·J·布里登汉姆
道格拉斯·B.·戴维斯
戴维·B.·林德奎斯特
阿扎姆·A.·韦斯利
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.)
International Business Machines Corp
Original Assignee
International Business Machines Corp
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 International Business Machines Corp filed Critical International Business Machines Corp
Publication of CN1620653A publication Critical patent/CN1620653A/zh
Pending legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F15/00Digital computers in general; Data processing equipment in general
    • G06F15/16Combinations of two or more digital computers each having at least an arithmetic unit, a program unit and a register, e.g. for a simultaneous processing of several programs
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/50Allocation of resources, e.g. of the central processing unit [CPU]
    • G06F9/5005Allocation of resources, e.g. of the central processing unit [CPU] to service a request
    • G06F9/5027Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resource being a machine, e.g. CPUs, Servers, Terminals
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/50Allocation of resources, e.g. of the central processing unit [CPU]
    • G06F9/5083Techniques for rebalancing the load in a distributed system
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/02Protocols based on web technology, e.g. hypertext transfer protocol [HTTP]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/10Protocols in which an application is distributed across nodes in the network
    • H04L67/1001Protocols in which an application is distributed across nodes in the network for accessing one among a plurality of replicated servers
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/10Protocols in which an application is distributed across nodes in the network
    • H04L67/1001Protocols in which an application is distributed across nodes in the network for accessing one among a plurality of replicated servers
    • H04L67/1004Server selection for load balancing
    • H04L67/101Server selection for load balancing based on network conditions
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/10Protocols in which an application is distributed across nodes in the network
    • H04L67/1001Protocols in which an application is distributed across nodes in the network for accessing one among a plurality of replicated servers
    • H04L67/1004Server selection for load balancing
    • H04L67/1012Server selection for load balancing based on compliance of requirements or conditions with available server resources
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/10Protocols in which an application is distributed across nodes in the network
    • H04L67/1001Protocols in which an application is distributed across nodes in the network for accessing one among a plurality of replicated servers
    • H04L67/1029Protocols in which an application is distributed across nodes in the network for accessing one among a plurality of replicated servers using data related to the state of servers by a load balancer

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Theoretical Computer Science (AREA)
  • Software Systems (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Computer Hardware Design (AREA)
  • Information Transfer Between Computers (AREA)
  • Multi Processors (AREA)
  • Computer And Data Communications (AREA)

Abstract

定义了监视输入客户请求的诸如应用量度之类条件(或者其它网络条件,例如负载均衡考虑因素)的过程,并被用于触发向网络中的位置动态部署、重新部署和/或解除部署web服务,以便改进效率。解除部署可应用于服务的分布位置,还可应用于最初从其部署服务的起始服务器。以对客户透明的方式,把服务请求动态发送给服务所驻留的目的地。在一个可选方面,通过利用相同的动态部署方法,可实现系统升级的有计划复制,能够显著降低升级以前所部署软件的复杂性。作为另一可选方面,利用公开的技术,也可自动并且有计划地解除部署以前部署的软件。

Description

计算网络中服务的动态部署
技术领域
本发明涉及计算机网络,更具体地说,涉及动态部署、重新部署和解除部署往/来于网络内的各个站点的服务(例如web服务或其它网络可达服务)的方法、系统和计算机程序产品。
背景技术
Web服务技术正在快速显现为用于分布式应用程序集成的机制。一般来说,“web服务”是描述一批网络可达操作的接口(interface)。Web服务完成特定的任务或一组任务。他们可按照可互用方式与一个或多个其它web服务一起工作,从而完成他们的那部分复杂工作流或商业交易。例如,完成复杂的定货单交易要求位于定货企业的定单发出服务(即定单发出软件)和位于其一个或多个商业伙伴的定单履行服务之间的自动相互作用。
许多行业专家认为面向服务的web服务的创始是新的因特网发展阶段。借助web服务,对软件的分布式网络访问将更广泛地适用于程序-程序操作,而不需要人类的干预。而早期的因特网主要用作分布式文件系统,其中人类用户可请求传送已产生的静态文件,近年来的趋势是向供给请求者的内容中增加越来越多的动态和个人化特征。典型地,在企业网络中已产生这种动态和个人化的内容。但是,这种方法对企业计算资源提出了极高的要求。为了减轻对后端服务器的处理负担,提出了几种技术,包括静态内容的超高速缓存(在有限程度上,在动态产生内容之后超高速缓存内容);工作负荷均衡;和内容分发。
超高速缓存试图通过保存内容,并且每当可能时,把保存的内容提供给后来的请求者,避免内容的重复产生。供给超高速缓存内容不仅减轻了后端计算资源的工作负荷,而且缩短了对用户的响应时间。工作负荷均衡通过动态调整发送给一组群集服务器中每个服务器的工作量,改进了Web站点的性能。内容分发试图抢先主动(静态地)向网络中的不同位置公布静态内容;例如,向超高速缓存服务器公布静态内容,以便增大可从超高速缓存满足请求的可能性。内容分发服务提供者(“CDSP”)通过提供对他们广泛网络基础结构的访问,以便把静态内容超高速缓存在非常接近最终用户之处,提供有价值的服务。这又使企业能够以成本低廉的方式缩放他们的操作。动态内容分布(即动态地把产生的内容移到更接近用户之处)会产生相同的可缩放性好处。对于一些应用(例如在其表示逻辑电路内提供话路管理,只以批量方式访问后端商务逻辑电路的那些应用)来说,能够(静态地)把表示逻辑电路部署在边缘。这些情况下,内容分发过程一般也会导致响应时间降低。
网络结构中“边缘服务器”的应用通过把静态应用组件(例如图像、表格等)超高速缓存在网络边缘附近,在网络边缘附近,所述静态应用组件可被快速返回给请求者(或者由表示逻辑电路快速取回,供装配将被传送给请求者的响应之用),提高网络效率和可用性。边缘服务器是物理位于网络边缘或者网络边缘附近的服务器。边缘服务器可实现工作负荷均衡,有时被称为分布式web超高速缓存器、代替者和/或代理人。(例如,IBM WebSphere边缘服务器执行工作负荷均衡,还用作反向代理和/或超高速缓存服务器)。图1提供了网络内典型服务器站点100(即供应与指定的完全合格域名相关的web内容的一批服务器节点)的视图,所述服务器站点100(举例来说)可为诸如 www.ibm.com之类域名供应内容。例证的服务器站点100包括应用程序服务器140(例如IBM WebSphere应用程序服务器)的群集150;数个后端企业数据服务器160(例如运行来自于IBM的DB/2、CICS、和/或MQI产品的IBM OS/390);数个Web服务器130(例如Apache、Netscape、或者Microsoft服务器;注意应用程序服务器和Web服务器通常共同驻留在单一硬件箱中);数个防火墙110;和数个边缘服务器或反向代理/超高速缓存/负载均衡器120。(“WebSphere”、“OS/390”和“CICS”是IBM的注册商标)。
下一代边缘服务器技术将为网络的边缘带来应用程序的一些动态特征。这可通过把web应用程序寄留在网络边缘,并且静态把表示逻辑(例如servlets,JSPTM、PHP等)部署在这些边缘服务器上来实现。JSP或JavaServer PagesTM是通过利用脚本命令动态地把内容嵌入Web文件中表现的表示逻辑。(“JSP”和“JavaServerPages”是Sun Microsystems,Inc.的商标)。PHP(“个人主页”)是可用于动态地把内容嵌入Web文件中的另一脚本语言。
借助基于Web的开放标准,例如HTTP(“超文本传送协议”)、SOAP(“简单对象访问协议”)和/或XML(“可扩充置标语言”)协议、WSDL(“Web服务描述语言”)和UDDI(“通用描述、发现和集成”),Web服务将简化“准时(just-in-time)”应用程序集成。HTTP通常用于通过诸如因特网之类TCP/IP(“传输控制协议/网间协议”)交换消息。SOAP是用于在分布式环境中调用方式的基于XML的协议。XML协议是万维网联盟关于应用层传送协议的衍生规范,所述应用层传送协议能够实现应用程序-应用程序消息接发。XML协议可与SOAP汇合。WSDL是一种描述分布式网络服务的XML格式。UDDI是一种基于XML的注册技术,借助该技术,企业可列举他们的服务,并且借助该技术,服务请求者可找到提供特定服务的企业。通过经UDDI注册机发出UDDI请求,查找分布式服务的地点,并且利用服务信息动态地把请求者和定位服务捆绑在一起,可实现准时应用程序集成,通过利用SOAP/XML协议和HTTP消息,以中性平台WSDL格式传送服务信息。(下面对SOAP的引用应解释为等同涉及XML协议的在语义方面类似的特征)。通过利用这些组件,web服务将向请求者提供对可能驻留在一个或多个远程位置的程序组件的透明存取,即使这些组件可能运行于不同的操作系统上,并且用不同于请求者的编程语言编写。(有关SOAP的更多信息,参阅http://www.w3.org/TR/2000/NOTE-SOAP-20000508,题目为“SimpleObject Access Protocol(SOAP)1.1,W3C Note 08 May 2000”。有关XML协议的更多信息,参见http://www.w3.org/2000/xp。可在http://www.w3.org/TR/2001/NOTE-wsdl-20010315,题目为“Web Services Description Language(WSDL)1.1,W3C Note15 March 2001”找到关于WSDL的更多信息。有关UDDI的更多信息,参见“http://www.uddi.org/specification.html”。在来自因特网工程任务组的请求评议(“RFC”)2616,题目为“HypertextTransfer Protocol-HTTP/1.1”(1999年6月)中描述了HTTP)。
虽然静态地把表示逻辑部署在网络的边缘会减轻后端计算资源的负担,并将缩短对不需要执行后端商业逻辑的那些内容请求的响应时间,但是仍然存在必须被送入企业,以便产生内容的许多请求。当商业逻辑保持在企业的中心内时,不能实现网络效率,企业继续是商业增长方面的处理瓶颈和限制因素。此外,只有当应用模式保持恒定并且可预测时,在网络边缘静态部署表示逻辑才有效:如果应用模式变化,那么静态部署的逻辑非常有效。另外,按照这种方式的软件静态部署可能会增大管理复杂性,具体地说是关于软件升级的管理复杂性,因为必须提供一种用于记录在哪些系统已部署哪些级别的软件,以及当需要时修改部署的软件的装置。这种升级过程通常是手动的,要求沉闷、易于出错的工作。并且,当web服务使分布式软件资源更广泛地适用时,对于大量的远程服务请求者来说,一些服务的物理位置可能会导致响应时间不太理想。
因此,需要一种避免现有技术的这些缺陷和局限性的技术。
发明内容
本发明的第一目的是提供一种在分布式网络中动态部署网络可访问服务(包括,但不限于web服务)的技术。
本发明的第二目的是提供一种在分布式网络中动态重新部署网络可访问服务(包括,但不限于web服务)的技术。
本发明的第三目的是提供一种在分布式网络中动态解除部署网络可访问服务(包括,但不限于web服务)的技术。
本发明的另一目的是提供一种根据应用量度动态部署网络可访问服务的技术。
本发明的又一目的是提供一种根据应用量度动态解除部署网络可访问服务的技术。
本发明的又一目的是提供一种根据负载均衡考虑因素,动态部署网络可访问服务的技术。
本发明的又一目的是提供一种根据负载均衡考虑因素,动态解除部署网络可访问服务的技术。
本发明的部分其它目的和优点将在下面的说明和附图中陈述,部分根据所述说明是显而易见的或者可通过实践本发明而了解。
为了实现前述目的,并根据这里概括说明的本发明的目的,本发明提供在计算网络中动态部署服务的方法、系统和计算机程序产品。在优选实施例中,该技术包括:接收关于选择服务的客户请求;当选择的服务还未被动态部署时,从第一服务器服务接收的请求;当触发动态部署时,通过有计划地(programmatically)把选择的服务从第一服务器转移到一个或多个其它服务器,实现动态部署;在实现步骤导致选择的服务被动态部署之后,从一个或多个其它服务器服务接收的请求。
本发明还提供在计算网络中动态重新部署服务的方法、系统和计算机程序产品。在优选实施例中,该技术包括:接收关于选择服务的重新部署触发;确定客户请求选择服务的一个或多个网络位置;当已从选择服务在起始服务器上的最初位置部署选择服务时,从第一服务器服务接收的请求;有计划地除去还未动态部署的服务;通过有计划地从网络位置和起始服务器移动选择的服务,实现动态部署;和有计划地替换所述网络位置和起始服务器的选择服务。
本发明还提供在计算网络中动态解除部署服务的方法、系统和计算机程序产品。在优选实施例中,该技术包括:接收关于选择服务的解除部署触发;确定选择的服务所部署的一个或多个网络位置;并且通过有计划地从网络位置中的一个或多个选择网络位置除去选择的服务,实现动态解除部署。
本发明还可有利地用在进行交易的方法中,例如通过1)提供会导致更有效的web寄留站点的动态部署服务(所述web寄留站点又向其用户提供降低端对端费用和/或改进用户站点的效率的优点);2)提供会导致更有效的web寄留站点的动态重新部署服务(所述web寄留站点提供和目前所需相比,更快速、工作量更小地更新部署的服务);3)提供会导致更有效的web寄留站点的动态解除部署服务(其中可有计划地除去在网络边缘不再需要的服务)。
下面参考附图说明本发明,其中相同的附图标记代表相同的部件。
附图说明
图1是根据现有技术的,其中边缘服务器发送输入的内容请求的服务器站点的视图;
图2图解说明本发明的组件以及在网络结构内,本发明的组件的布置和互连;
图3图解说明可用于累积供本发明之用的应用量度的数据结构;
图4根据本发明的优选实施例,图解说明借助其可实现动态服务部署的12阶段过程;
图5根据本发明的优选实施例,图解说明可发出的例证部署请求的内容;
图6根据本发明的优选实施例,图解说明响应接收图5中的消息,可发出的SOAP请求的内容;
图7根据本发明的优选实施例,图解说明可作为对图6的部署请求的响应返回的例证SOAP包络的内容;
图8和10根据本发明的优选实施例,图解说明可用于动态解除部署服务的两种方法;
图9图解说明可用于记录已部署服务的部署位置的数据结构;
图11根据本发明的优选实施例,图解说明可用于动态更新或重新部署服务的过程。
具体实施方式
本发明定义通过动态部署网络可达服务,改进网络操作的技术,借此解决现有技术的缺点。另外,通过基于相同的动态部署机制的可选增加,借助系统升级的自动的有计划复制,降低了对先前部署的软件升级的复杂性。在另一种可选增强中,通过利用本发明的技术,也可自动地、有计划地解除部署先前部署的软件。(注意,虽然这里本发明的优选实施例被描述为在网络的边缘工作,不过对本领域的技术人员来说,这些技术显然也适合用在服务器场地(farm)的前端。此外,虽然这里把优选实施例描述为适合于与Web服务一起应用,不过这只是出于举例说明的目的,而不是对本发明的限制。公开的技术也可和其它类型的网络可达服务一起应用)。
按照优选实施例,根据到来的关于特定web服务的客户请求,动态计算应用量度(usage metrics)。通过随着用户需求的变化动态部署服务,即使在应用模式快速变动的情况下,也可从边缘获取合适的软件。
一般来说,如同本领域已知那样,web服务可内嵌任意形式的程序设计逻辑,包括脚本程序,JavaTM类程,COM类程,EJB(“Enterprise JavaBeans”TM),存储过程,IMS或其它数据库事务等。(“Java”和“Enterprise JavaBeans”是SunMicrosystems,Inc.的商标)。由于web服务是操作系统、组件模型和程序设计语言,当使用本发明时,消除了现有技术的只在边缘部署表示逻辑的限制(假定在部署地点存在必要的运行期,如下更详细所述那样)。从而,现在可对于本质上确实动态的内容,实现现有技术中由静态内容的超高速缓存获得的网络效率。
这里,术语“应用量度”被用于表示收集的和特定web服务被请求的次数相关的信息,并可用于确定何时某一服务被多次请求,以致足以通过把所述服务部署在边缘服务器来实现效率。在本发明的一些实现中,最好对所有web服务使用单一阈值;在其它实现中,最好提供多个阈值(包括为每个单独的web服务提供一个不同的阈值)。一般,当配置网络参数时,由系统管理员设置阈值。(另一方面,一些阈值可使用默认值,和/或可有计划地设置一些阈值)。
本发明的动态部署技术可在诸如图1中所示的实例网络内工作,这里边缘服务器120被修改,以便实现这里所述的动态部署。图2表示了本发明可在其中工作的网络结构的抽象表现,图解说明了实现动态部署过程的组件的布置以及他们的网络互连。下面说明这些组件。
如图2中所示,部署系统的组件包括存在点(“POP”)部署服务商(facilitator)230(这里也称为“部署服务商”或“DF”),CDSP部署节点260(这里也称为“部署节点”或“DN”),和部署提供商280(“DP”)。可选地,可提供部署运行期贮存器(container)(“DRTC”)245。(DRTC用于本发明的可选增强,它提供解除部署和重新部署,如下所述。如果需要,DRTC也可用在动态部署系统中)。另外,表示了服务请求者210(例如客户应用程序)、公共UDDI注册机(registry)220、边缘服务器或POP 240、基于域名系统(“DNS”)的主解析系统250、专用UDDI注册机270和起始服务器290。一般来说,部件210、220、240、250、270和290本领域已知(除了这里要说明的动态部署、解除部署和重新部署功能之外),这里不对这些现有部件进行详细说明。
部署服务商组件230驻留在边缘服务器240上,协调从一个或多个起始服务器290到与DF 230位于相同位置的CDSP接入点的web服务的部署,如同下面参考图4详细说明的那样。
在优选实施例中,部署节点260保存该CDSP的应用量度,并当它监视到输入的服务请求时,更新这些量度。当达到应用阈值时,部署节点负责启动向特定的POP(例如向特定的边缘服务器)部署相应的服务。部署节点还包括专用UDDI注册机270,专用UDDI注册机270管理该特定CDSP的服务部署的当前状态。这里使用的专用UDDI节点最好是寄留在CDSP的防火墙内,只允许核实的伙伴公布他们的服务,以便包含在其UDDI注册机中的伙伴目录UDDI节点。另外,只允许该组织内(即防火墙后)的请求者向该专用UDDI节点要求信息。通过用公共UDDI注册机220替代专用UDDI注册机270的内容,组织之外的请求者能够请求位于组织之内的服务。
注意另一方面,UDDI注册机220可以是寄留在CDSP的非军事(demilitarized)区(“DMZ”)中的入口UDDI节点(即另一种专用节点)。入口UDDI节点允许任意请求者查找服务,但是只允许CDSP公布服务。
现有技术的CDSP一般提供内部服务,所述内部服务包括动态查找提供被请求内容的服务器的DNS 250,确定请求者的地理位置的ping三角测量装置,和在已知公共请求URL(“统一资源定位符”)的情况下,用于透明地把客户请求重定向到恰当的POP(即重定向到距离请求者相对较近的POP)的IP地址图。根据本发明,DN 260将与这种系统交互作用,从而将向客户透明反映动态服务部署。(即,客户会请求特定的服务,DNS系统会确定该服务当前部署在何处,并自动把客户的请求发送给所述当前位置)。下面参考图4更详细论述这种透明重定向。
部署提供商280存在于企业网络内,最好存在于超始服务器290上,并且响应部署请求,以便自动并且有计划地把服务部署到请求边缘服务器240。假定服务应用程序的“可边缘性”方面(即能够部署到网络边缘的那些方面)将被恰当打包并保存在部署提供商的内容内(即以企业档案(“EAR”)的形式,以Web档案(“WAR”)的形式,以Java档案(“JAR”)的形式等)。
图3中图解说明了本发明的优选实施例可使用的数据结构。在优选实施例中,DN 260使用该数据结构存储位于单个POP的特定服务的应用计数。(在一些实施例中,最好根据反映全系统活动的应用量度,跟踪部署的服务)。如图3中所示,最好依据其UDDI绑定密钥识别服务。(另一方面,可依据其服务名称或者其它类似的标识符,服务提供商,最终端点识别服务)。为了举例说明起见,这里把数据结构称为“表格”,保存于其中的服务信息被表示成具有由CDSP管理的各个POP的不同行。
在优选实施例中,这里利用12个阶段描述的过程被用于动态部署web服务。在该部署过程中,基于标准的web服务平台最好被leveraged,该平台包括SOAP、WSDL、UDDI和HTTP消息流。W3C发布的题为“SOAP Messages with Attachments,W3C Note11 December 2000”的规范(参见http://www.w3.org/TR/2000/NOTE-SOAP-attachments-20001211)描述一种利用多部分MIME(“多用途因特网邮件扩展”)结构传送附件,使SOAP消息与呈其本来格式的一个或多个附件联系的标准方式。由于SOAP是调用web服务的标准消息接发格式,在本发明的优选实施例中,SOAP附件标准被用作动态部署web服务的机制。如前所述,在不偏离本发明的范围的情况下,可用语义相似的组件代替这里描述的那些组件。例如,在一些实施例中,可用SMTP(“简单邮件传送协议”)流代替HTTP流,如前所述,可用XML协议代替SOAP。
图4关于图2中描绘的那些组件,使用带圆圈的数字表示优选实施例的12阶段过程中的每个阶段。下面参考图4说明这12个阶段中的每个阶段。
在阶段1中,web服务495被部署在起始服务器290上。该阶段使用不构成本发明一部分的现有部署技术。随后向部署节点260公布web服务495(阶段2)。在优选实施例中,该公布操作使用UDDI程序员API(“应用程序接口”)把WSDL文件从起始服务器290传送给部署节点260,以便保存在专用UDDI注册机270中。(可在http://www.uddi.org/pubs/ProgrammersAPI-V1-1.pdf中找到UDDI程序员API,其标题为“UDDI Programmer′s API1.0,UDDI Open Draft Specification 2000年9月30日”)。传送的WSDL文件利用在WSDL规范中规定的格式,描述部署的服务。除了把WSDL文件保存在注册机270中之外,部署节点260最好还保存与该文件相关的提供者元数据(例如发送文件的起始服务器290的网络位置)。
在阶段3中,部署节点260最好利用“公布”API的UDDI命令(例如“save_service”),用公共UDDI注册TH 220代替其专用UDDI注册机270。例如,下述HTTP请求可被用于向名为“testregistry”的测试级IBM注册机发布信息:
http://www-3.ibm.com/services/uddi/testregistry/protect/publishapi
此时,部署节点260最好还更新储存库452中的DNS项,从而DNS 250将自动使关于该web服务495的后续客户请求被发送给部署节点260。(部署节点随后会利用保存在图3中在300所示数据结构中的信息,把这些后续请求转发给web服务495的恰当位置。下面参考阶段5,更详细地说明输入的客户请求的DN处理)。DN最好还在其表格300中产生初始条目,包括发布的该服务的UDDI绑定密钥并且应用计数的值为0。
可选地,在专用UDDI注册机270(即伙伴目录)和位于220的公共UDDI操作员节点之间可建立hosting重定向关系。该关系使关于公共节点的任何“查找”请求能够参考专用节点中的条目。这种情况下,当路由请求时,不需要在阶段5中描述的三角测量过程。
在阶段4中,客户(即,服务请求者)210从“查询”API发出诸如“find_service”之类的UDDI命令,向公共UDDI注册机220询问特定服务的位置。例如,利用名为“testregistry”的注册机,下述HTTP请求可用于查问服务的位置:
http://www-3.ibm.com/services/uddi/testregistry/inquiryapi
根据本发明的优选实施例,解析的服务目的地会包含引用部署节点260的URL的终点信息(从而使客户210把其后续请求发送给DN)。另一方面,如果使用hosting重定向器方法,则UDDI绑定模板将提供引用由部署节点管理的第二绑定模板“B”的绑定密钥“A”。绑定模板“B”将为寄留在部署节点的重定向服务提供“入口点”部件。在已知恰当的绑定密钥“A”和为所需服务提供入口点的绑定模板的情况下,该重定向服务将响应get_bindingDetail消息。
客户随后发出服务请求(阶段5),图4中描述成与服务“绑定”在一起。通过利用在阶段4中从UDDI注册机220获得的终点信息,服务请求被发送给部署节点260。CDSP的DNS功能250截取该请求,并从其DNS存储库452获得被请求服务的当前位置。如果服务已部署在客户的POP 240(这可通过利用诸如ping三角测量之类的技术确定客户位于何处,使用IP地图查找客户的POP,或者借助hosting重定向器关系来确定),那么该请求被发送给该POP,以便处理(如图4中所示)。如果服务还未部署在客户的POP,则如阶段6中那样进行处理。
在阶段6,部署节点接收客户的服务请求,并将其转发给起始服务器290,所请求的web服务495目前部署在起始服务器290上。在起始服务器处理该服务,服务结果被返回给客户(图4中未示出)。
在部署节点接收每个服务请求之后,在优选实施例的阶段7中,部署节点更新服务的应用量度,以便反映客户请求。(参见图3中的表格,DN部署节点最好保持关于客户请求的信息)。如果服务先前已被访问,那么递增应用计数器。如果这是关于该服务发出的第一次请求,那么应用计数器被设置为1。图3中的例子表示具有UDDI绑定密钥“xxx”的服务已从基于旧金山的POP访问100次,但是从基于纽约市的POP只访问了33次。
在更新应用量度之后,在阶段8中,DN 260检查应用计数器是否等于或大于管理员配置的(或者以其它方式设置的)阈值。如果是,那么这表示服务应部署在客户的POP上。即,该POP的客户正在足够频繁地请求该服务,以致在本地POP部署该服务的副本是有用和高效的(例如,减小网络往返时间,从而提高对客户的响应时间,以及减轻后端系统内传输和处理负担)。于是,部署节点将向位于恰当POP 240的部署服务商发出部署请求(图4中表示为流8)。部署请求最好提供服务描述,所述服务描述可被用于从部署提供商280启动部署。图5表示了包含利用WSDL编码的服务描述的例证部署请求。
对熟悉WSDL编码的人来说,图5A和5B中的例证部署请求显然规定了接口定义。本例中,接口定义是本发明的部署服务的接口定义。如在510所示,例证的接口被命名为“Deployment-interface”并利用“getDeployedService”方法540调用(参见图5B)。定义了两个消息“DeploymentRequest”520和“DeploymentResponse”530。DeploymentRequest消息包括“runtimeEnvironment”部分,从而当为在该POP部署而准备特定服务时,部署服务商可规定将由部署提供商使用的POP专用信息(如同下面参考阶段9更详细论述的那样)。如图所示在550定义向SOAP提供WSDL操作和消息之间的映射的绑定。调用Deploy方法的结果或者是档案索引,或者是服务档案(参见组件560)。图5C规定了同样在阶段8中发送的部署服务的实现定义。
在阶段9中,位于客户的POP的部署服务商230利用在阶段8中从部署节点260获得的信息,向部署提供商280发出SOAP请求,该SOAP请求要求动态部署所涉及的服务。图6中表示了可在阶段9中传送的SOAP请求的一个例子。注意,要部署的服务的名称或者其它标识符被规定为诸如“ServiceName”610之类标记的内容。本例中,规定了唯一的服务标识符“urn.www.acme.com:stockquoteservice”,指示客户210请求的,位于 www.acme.com的“stockquoteservice”服务将被动态部署。
在POP上的运行期环境已知,并且对于将部署特定服务的每个POP来说,所述运行期环境一致的环境中,在阶段9中发送的部署请求只需要识别所请求的服务。例如,如果用Java编写所请求的服务,并且每个POP具有Java运行期,如果每个POP运行相同的操作系统,如果每个POP支持相同版本的SOAP,从而理解相同的部署消息语法,那么这种简单方法是恰当的。但是,在许多连网环境中,在不同的POP之中,可能存在这些类型信息的差异。例如,不同的SOAP服务器可以在相同的POP上运行,这些服务器具有不同的服务部署方式。或者,可以用不可移植的语言编写所请求的web服务。于是,在起始服务器上(或者在起始服务器可访问的存储库中)可保存要部署的每种服务的多个版本。随后根据在特定POP上可获得的支持,可向所述特定POP发送所述服务的一种不同版本。例如,可相对于特定服务的一个请求者,部署Windows操作系统的COM应用程序,而相同的服务可以C程序的形式部署到运行LinuxTM操作系统的POP上。(“Linux”是Linus Torvalds的商标)。于是,本发明的优选实施例支持在图5A的520中定义的“runtimeEnvironment”组件,以便当请求部署服务时,允许POP向部署提供商提供其配置信息。在图6中,在620图解说明了该技术的例子,这里部署服务商已提供了数种运行期信息。本例中,该信息包括在POP运行的操作系统(Windows 2000),SOAP服务器的名称(Apache SOAP V2.1),和运行期环境(Java)。通过利用该信息,部署提供商随后能够选择web服务的正确实现,以便部署在该特定POP上。部署运行期环境串的内容可根据整个环境的需要而简单或复杂(即,如果在整个环境内使用相同的SOAP服务器,并且用Java编写所有web服务,那么参数值可为空;否则,可提供不同的或者其它类型的信息。作为提供额外信息的一个例子,如果可从部署提供商获得多个版本的web服务,则部署服务商可规定供部署提供商使用的版本号)。
再次参考图4,在阶段9中发送部署请求之后,部署提供商280随后(在阶段10)向部署服务商230返回SOAP包络,SOAP包络包括档案索引或者服务档案(如上参考图5的组件560说明的那样)。如在图7中例证的SOAP包络中的730所示,根据已说明的Attachments规范,企业档案(EAR)以MIME附件的形式包含在传送该SOPA包络的HTTP响应中。(另一方面,WAR或JAR可以附件的形式包含于SOAP包络中,或者可根据SOAP包络查阅WAR或JAR)。如本例中在710所示,具有诸如“ArchiveRef”之类名称的标记的“href”属性指定和二进制附件中的内容ID 720匹配的地址。(另一方面,href属性可被省略,假定SOAP服务器适合于处理ArchiveRef标记,随后利用ArchiveRef标记的内容,对照附件的内容ID组件,发出搜索)。
在阶段11,在接收SOAP包络和附件之后,部署服务商230随后访问本地SOAP服务器API,把服务部署在客户的POP 240上。(SOAP服务器API本领域已知,不构成本发明的一部分)。
最后,在阶段12,部署服务商230最好向部署节点260返回成功返回代码,部署节点260随后更新储存库452中的DNS条目,指示该web服务现在部署在边缘服务器240(如图4中在448所示)。通过按照这种方式更新DNS,来自使用该边缘服务器240作为POP的那些客户的关于该服务的后续请求现在将被自动发送给部署在448的服务,而不是发送给部署在起始服务器290的服务495。
如上证明的那样,本发明的部署系统提供动态部署web服务的可扩展结构。这里说明的优选实施例使用应用量度来启动服务部署。其它实施例可使用其它触发事件,而不会偏离这里公开的发明原理。例如,DN可监视网络上的负载,可在阶段8的动态部署决定中使用该信息,代替上面论述的应用量度(或者除上面论述的应用量度之外)。由于如同已说明的那样,该部署系统的优选实施例融合(leverage)UDDI、WSDL、SOAP/XML协议和HTTP的web服务组,因此可在众多平台上无缝把这些实施例集合在一体。边缘服务器代表利用这种部署系统的一个应用平台,并且这里只是出于举例说明,而不是对本发明的限制,描述了边缘服务器。
就本发明的可选增强来说,一种实现可提供动态解除部署和/或重新部署web服务。现在说明这些增强。(注意虽然参考上面说明的部署过程描述这些可选增强的优选实施例,但是这是为了举例说明,而不是对本发明的限制。下面描述的解除部署和重新部署也可和以其它方式部署的服务一起使用)。
第一可选增强
正象动态部署web服务一样,本发明的可选增强使得能够动态解除部署web服务。在一个方面,该解除部署可以是有条件的或者选择性的;在另一方面,解除部署是无条件的。下面依次说明每个方面。
为了能够实现有条件的解除部署,可使用web服务的应用量度确定何时应解除服务的部署。一般来说,应用量度是在一段时间内接收的应用请求的平均数。根据该应用量度,可设置指示利用率的阈值,在所述利用率下,应解除服务的部署。阈值最好被保存在部署节点260,并且如果需要的话,可任意改变所述阈值(例如,由部署提供商280,由系统管理员等改变)。例如,如果应用量度是一月内每天的平均请求数,阈值被设置成每天100次请求,那么如果月末利用率低于每天100次请求,就应解除部署该web服务。(在除应用请求之外的其它标准确定服务的动态部署的实现中,解除部署最好反映所述其它标准)。
最好,应用量度保留在边缘服务器240上。利用上述例子,通过把应用计数器保持一个月,计算应用量度。在该例中,为了计算利用率,边缘服务器还保存开始计数的日期,在每月的月末,重置应用计数器。或者,可使用可调整的一月间隔。(注意,并不严格要求每个边缘服务器保留在该服务器上部署的特定服务的应用量度。在一些实现中,在选择的边缘服务器上累积代表性应用量度就足够了)。
虽然应用量度保持在边缘服务器上,但是,根据该可选增强的优选实施例,部署节点260负责发出解除部署请求。于是,部署节点监视将用于确定何时应解除部署边缘服务器上的web服务的利用率。部署节点可定期查询每个边缘服务器,以便获得应用量度。如果应用量度小于阈值,则解除该web服务的部署。
在根据本发明动态部署web服务之后,在优选实施例中使用下述过程,有条件地动态解除web服务的部署。现在参考图8,带圆圈的数字图解说明可用于执行该过程的流程和操作。
1.当起动部署节点260时,部署节点260最好被配置成每隔规定的时间间隔,检查部署的服务的状态。应根据部署的web服务的应用模式,设置所述时间间隔。所使用的特定时间间隔并不重要,例如可用分钟、小时、天、周或月来表述使用的特定时间间隔。
2.当部署新的web服务时,最好把该服务的解除布置阈值保存在部署节点260上。随后可使用该阈值确定何时应解除部署动态部署的web服务。
3、每隔规定的时间间隔,部署节点会获得所有动态部署的web服务的清单。从专用注册机270获得该清单,因为对于每个动态部署的web服务,在该注册机中产生新的商业服务项。该清单包含已部署web服务的所有部署服务商的索引。图9中的表格900图解说明可保存该信息的格式的简单例子。如其中所示,诸如UDDI绑定密钥之类的服务标识符910识别每个部署的服务,诸如IP地址之类的信息920识别这些服务被部署在何处。(注意可根据需要合并或单独保存图3的表格300和图9的表格900中的信息)。
4.向每个部署服务商230发送应用量度请求。作为响应,部署服务商会从部署运行期贮存器(container)获得应用量度,并把获得的应用量度返回给部署节点260。(在每个POP 240中,每个部署服务商230可以接触部署运行期贮存器245,所述部署运行期贮存器为web服务提供与运行期环境的接口。部署运行期贮存器保持用于该解除部署机制的POP专用应用量度)。
5.部署节点260比较应用量度和阈值。如果应用量度小于阈值,部署节点将启动关于该web服务的解除部署过程。
6.通过向DNS服务器250发送从DSN储存库452除去该web服务的条目的请求,起动解除部署过程。在处理该请求之后,web服务不再接收任何其它请求。
7.部署节点随后向部署服务商发送解除该web服务的部署的请求。
8.当部署服务商接收解除部署请求时,关闭web服务448,并从边缘服务器240上的运行期环境除去web服务的可执行代码。在完成解除部署请求之后,最好向部署节点发送指示web服务已被成功解除部署的响应(图8中未示出)。
9.随后,部署节点会除去专用注册机中已被解除部署的web服务的条目。
就该增强的提供无条件解除部署的方面来说,当不再需要web服务时,或者当将用新的web服务替代该web服务时,解除部署web服务。对于如现有技术中那样静态部署的web服务来说,典型的解除部署过程有两个基本步骤。
1.不从服务注册机发布web服务的服务描述。在不发布服务之后,没有人能够查找服务描述。
2.从运行期环境除去web服务。这包括有序关闭运行的web服务,除去运行期环境所需的任何元信息,以及从运行期环境除去web服务的可执行代码。(部署SOAP服务所需的部署描述符是这种元信息的一个例子)。
对于根据本发明动态部署的服务来说,需要增强该解除部署过程,以便解除部署原始web服务,以及所有动态部署的web服务。现在参考图10说明在优选实施例中实现这一点的方式,图10中带圆圈的数字对应于列举的步骤。
1.部署提供商280将从起始服务器290向部署节点260发出解除部署请求。部署提供商最好是该方案中允许发出这种请求的唯一参与者。
2.部署节点通过在其专用注册机270中搜索web服务,核实该web服务部署在其节点上。
3.如果在专用注册机中找到该web服务,那么继续部署节点上的解除部署处理。部署节点负责完成来自部署提供商的解除部署请求。如果在专用注册机中没有找到该web服务,那么最好向部署提供商回送错误消息(图10中未示出)。
4.部署节点通过向公共注册机220发送不发布请求,启动解除部署过程。在处理该请求之后,服务请求者210不能够查找web服务描述,但是所有的web服务仍然继续运行。
5.在完成不发布请求之后,部署节点通知DNS 250服务器除去关于该web服务的所有条目。当这些条目被除去时,服务请求者可访问的唯一形式的web服务是在起始服务器上运行的web服务。
6.部署节点260上的专用注册机包含部署服务商和起始服务器290的引用。部署节点将除去关于起始服务器的条目,以便它不再把服务请求转发给起始服务器。
7.部署节点260将获得部署web服务的部署服务商230的清单。该清单从专用注册机270获得,因为关于每个动态部署的web服务产生新的商业服务项。
8.向在步骤7获得的清单中的每个部署服务商发送解除部署请求。
9.当部署服务商收到解除部署请求时,web服务448被关闭,从边缘服务器240上的运行期环境中除去该web服务的可执行代码。在完成解除部署请求之后,最好向部署节点发送指示web服务已被成功解除部署的响应(图10中未示出)。
10.当部署节点已完成来自部署提供商的解除部署请求时,最好向部署提供商发送指示解除部署请求已完成的响应。
11.部署提供商关闭正在起始服务器上运行的web服务495,随后除去可执行代码。
第二可选增强
在一开始已部署web服务之后,该web服务可能必须被更新(例如修改缺陷或者增加新功能)。对于根据现有技术静态部署的web服务来说,典型的web服务更新过程有四个基本步骤。
1.通过从服务注册机中除去该web服务的条目,禁止对该web服务的动态访问。在除去其条目之后,服务请求者应该不能查找关于该web服务的服务描述。
2.从运行期环境除去该web服务。这包括有序关闭正在运行的web服务,从运行期环境除去运行期环境所需的任意元信息,和除去web服务的可执行代码。在关闭web服务之前,有序关闭会核实所有未完成的请求被处理。
3.在运行期环境中部署更新后的web服务代码和元信息,随后起动该服务。
4.重新发布关于该web服务的服务描述。这使得能够动态访问该web服务。
对于根据本发明动态部署的服务,该重新部署过程需要被增强,以便更新最初部署的web服务,以及所有动态部署的web服务。最好应更新所有web服务,从而同时在所有部署系统上可实现更新。下面参考图11说明优选实施例中实现这一点的方式,图11中,带圆圈的数字对应于下面列举的步骤。
1.最好当部署提供商更新起始服务器290上的web服务时开始更新过程。这可通过关闭web服务,更新该服务的可执行代码和元信息,随后再次起动该服务来实现。
2.部署提供商280从起始服务器290向部署节点260发出更新请求。部署提供商最好是本方案中允许发布这种请求的唯一参与者。
3.部署节点通过在其专用注册机270中搜索web服务,核实该web服务已部署。专用注册机包括部署在起始服务器290上的web服务,以及所有动态部署的web服务的索引。
4.如果在专用注册机中找到该web服务,那么部署节点将处理更新请求。部署节点负责完成来自部署提供商的更新请求。如果在专用注册机中没有找到该web服务,那么最好向部署提供商回送出错消息(图11中未示出)。
5.部署节点通过向公共注册机220发送不发布请求,起动更新过程。在该请求被处理之后,服务请求者210不能够查找该web服务,但是所有的web服务仍然在运行。
6.在完成不发布请求之后,部署节点将从其注册机270获得部署web服务的部署服务商230的清单。
7.对于该清单上的每个web服务,更新DNS服务器250,以致所有请求被发送给部署节点。在处理更新的同时,部署节点最好向试图访问该服务的任何服务请求者返回出错消息。
8.在DNS服务器被更新之后,部署节点向在步骤5中获得的清单中的每个部署服务商发送更新请求。最好,按照和部署过程的阶段8(参见图4)中发送的部署请求相似的格式格式化该更新请求,并且更新请求使用和部署请求相似的语法,但是区别在于它传送的是更新请求。
9.当部署服务商收到更新请求时,它会关闭该web服务,随后向起始服务器发送部署请求,以便获得更新后的web服务。在优选实施例中,(重)部署请求使用前面参考部署过程的阶段9(参见图4)说明的相同格式和语法。
10.在部署服务商从部署提供商280收到更新后的web服务分组时,它会在运行期环境中部署该web服务和元信息,随后起动该服务。
11.当部署节点完成来自部署提供商的更新请求时,它将向DNS服务器发送请求,以便重新激活所部署web服务的初始DNS项,并向公共注册机220发布更新后的服务描述。
12.在发布服务描述之后,服务请求者可查找更新后的服务描述,并使用任意更新web服务。服务请求将由DNS服务器重新发送给部署的web服务,或者将按照前面关于部署过程的阶段5和6说明的相似方式(关于这些流程的说明参见图4,图11中未示出),被发送给部署节点,并被转发给正在起始服务器上运行的web服务。
13.当部署节点向部署提供商发送对更新请求的响应时(图11中未示出),最好结束更新过程。
从而,可看出可选增强任一或者两者的应用提供除已说明的动态部署技术之外的优点。
本领域的技术人员会认识到,可以方法、系统或计算机程序产品的形式提供本发明的实施例。因此,本发明可采取彻底硬件的实施例,彻底软件的实施例或者组合软件和硬件特征的实施例的形式。此外,本发明可采取包含在一个或多个计算机可读存储介质(包括(但不限于)磁盘存储器、CD-ROM、光学存储器等)上的计算机程序指令的形式,所述计算机可读存储介质具有包含于其中的计算机可用程序代码。
已参考根据本发明实施例的方法、设备(系统)和计算机程序产品的流程图和/或方框图说明了本发明。显然可用计算机程序指令实现流程图和/或方框图的各个流程和/或方框,以及流程图和/或方框图中流程和/或方框的组合。这些计算机程序指令可提供给通用计算机、专用计算机、嵌入处理器或其它可编程数据处理设备,以产生机器,从而借助计算机或其它可编程数据处理设备的处理器执行的指令产生实现在流程图流程和/或方框图方框中规定的功能的手段。
这些计算机程序指令也可保存在计算机可读的存储器中,所述存储器可指导计算机或其它可编程数据处理设备按照特定的方式运行,从而保存在计算机可读存储器中的指令产生包括实现在流程图流程和/或方框图方框中规定的功能的指令装置的制造产品。
计算机程序指令也可被加载到计算机或其它可编程数据处理设备上,使得在计算机或其它可编程设备上执行一系列的操作步骤,从而产生计算机实现的程序,以致在计算机或其它可编程设备上执行的指令提供用于实现在流程图流程和/或方框图方框中规定的功能的步骤。
虽然已说明了本发明的优选实施例,不过本领域的技术人员一旦了解基本发明原理,那么他们可对这些实施例做出其它变化和修改。于是,附加权利要求应被理解为既包括这些优选实施例,又包括落入本发明的精神和范围内的所有这种变化和修改。

Claims (33)

1、一种在计算网络中动态部署服务的方法,包括下述步骤:
接收关于选择的服务的客户请求;
当选择的服务还未被动态部署时,从第一服务器服务接收的请求;
当触发动态部署时,通过有计划地把选择的服务从第一服务器转移到一个或多个其它服务器,实现动态部署;和
在实现步骤导致选择的服务被动态部署之后,从一个或多个其它服务器服务接收的请求。
2、按照权利要求1所述的方法,还包括下述步骤:
监视接收的关于选择的服务的客户请求的数目;和
当监视的数目超过预定阈值时,触发动态部署。
3、按照权利要求2所述的方法,其中预定阈值应用于若干可动态部署的服务。
4、按照权利要求2所述的方法,其中预定阈值应用于选择的服务。
5、按照权利要求2所述的方法,其中监视步骤计数在所述一个或多个其它服务器的单个服务器上的接收客户请求。
6、按照权利要求2所述的方法,其中监视步骤计数在所述一个或多个其它服务器中的若干服务器上的接收客户请求。
7、按照权利要求1所述的方法,还包括下述步骤:
监视计算网络上的负载;和
当监视的负载超过预定阈值时,触发动态部署。
8、一种在计算网络中动态部署服务的系统,包括:
接收关于选择的服务的客户请求的装置;
当选择的服务还未被动态部署时,从第一服务器服务接收请求的装置;
当触发动态部署时,通过有计划地把选择的服务从第一服务器转移到一个或多个其它服务器,实现动态部署的装置;以及
在实现步骤导致选择的服务被动态部署之后,从一个或多个其它服务器服务接收请求的装置。
9、一种在计算网络中动态部署服务的计算机程序产品,所述计算机程序产品包含在一个或多个计算机可读介质上,并且包括:
接收关于选择的服务的客户请求的计算机可读程序代码装置;
当选择的服务还未被动态部署时,从第一服务器服务接收请求的计算机可读程序代码装置;
当触发动态部署时,通过有计划地把选择的服务从第一服务器转移到一个或多个其它服务器,实现动态部署的计算机可读程序代码装置;以及
在实现步骤导致选择的服务被动态部署之后,从一个或多个其它服务器服务接收请求的计算机可读程序代码装置。
10、一种在计算网络中动态解除部署服务的方法,包括下述步骤:
接收关于选择的服务的解除部署触发;
确定部署选择的服务的一个或多个网络位置;和
通过有计划地从网络位置中的一个或多个选择的网络位置除去选择的服务,实现动态解除部署。
11、按照权利要求10所述的方法,还包括下述步骤:
接收关于选择的服务的客户请求;和
继续从与有计划地从其除去选择的服务的一个或多个选择的网络位置不同的网络位置服务接收的请求。
12、按照权利要求10所述的方法,其中解除部署触发以网络位置处选择的服务的应用率为基础。
13、按照权利要求10所述的方法,其中解除部署触发以网络位置处的网络负载为基础。
14、按照权利要求10所述的方法,其中解除部署触发是最初从其部署选择的服务的起始服务器发出的解除部署请求。
15、按照权利要求12所述的方法,还包括比较选择的服务的应用率和预定阈值,当应用率低于预定阈值时,发送解除部署触发。
16、按照权利要求15所述的方法,其中预定阈值的数值应用于若干部署的服务。
17、按照权利要求15所述的方法,其中预定阈值的数值应用于网络位置的一个或多个选择的位置。
18、按照权利要求12所述的方法,其中应用率是预定时间间隔内,关于选择的服务的客户请求的平均数。
19、按照权利要求15所述的方法,还包括定期获得供比较步骤之用的应用率的步骤。
20、按照权利要求10所述的方法,还包括下述步骤:
监视计算网络上的负载;和
当监视的负载满足预定阈值时,触发动态解除部署。
21、按照权利要求10所述的方法,其中有计划地除去步骤还包括向一个或多个选择的网络位置发出关于选择的服务的解除部署请求。
22、按照权利要求21所述的方法,还包括下述步骤:
在网络位置中的一个特定网络位置接收解除部署请求,所述特定网络位置是网络位置中正在从其动态解除部署选择的服务的一个选择的网络位置;和
响应接收步骤,关闭所述特定网络位置的选择的服务,并从所述特定网络位置的运行期环境中除去实现选择的服务的执行代码。
23、一种在计算网络中动态解除部署服务的系统,包括:
接收关于选择的服务的解除部署触发的装置;
确定部署选择的服务的一个或多个网络位置的装置;和
通过有计划地从网络位置中的一个或多个选择的网络位置除去选择的服务,实现动态解除部署的装置。
24.一种在计算网络中动态解除部署服务的计算机程序产品,所述计算机程序产品包含在一个或多个计算机可读介质上,并且包括:
接收关于选择的服务的解除部署触发的计算机可读程序代码装置;
确定部署选择的服务的一个或多个网络位置的计算机可读程序代码装置;和
通过有计划地从网络位置中的一个或多个选择的网络位置除去选择的服务,实现动态解除部署的计算机可读程序代码装置。
25、一种在计算网络中动态重新部署服务的方法,包括下述步骤:
接收关于选择的服务的重新部署触发;
确定已从选择的服务在起始服务器上的最初位置向其部署选择的服务的一个或多个网络位置;
有计划地从网络位置和起始服务器除去选择的服务;和
有计划地替换网络位置和起始服务器上的选择的服务。
26、按照权利要求25所述的方法,其中重新部署触发包括来自起始服务器的重新部署请求。
27、按照权利要求25所述的方法,还包括当选择的服务要被修改时,发送重新部署触发的步骤。
28、按照权利要求25所述的方法,还包括下述步骤:
接收关于选择的服务的客户请求;
在接收重新部署触发之前,从网络位置服务接收的请求;和
在有计划除去和有计划替换步骤之后,利用替换后的服务,服务于接收的请求。
29、按照权利要求25所述的方法,还包括在接收重新部署触发之后,在完成有计划除去和有计划替换步骤之前,不发布选择的服务,以及之后重新发布选择的服务的步骤。
30、按照权利要求26所述的方法,还包括响应从起始服务器接收到重新部署请求,向每个网络位置发送后续重新部署请求的步骤。
31、按照权利要求30所述的方法,其中有计划替换步骤还包括下述步骤:
从网络位置中的一个选择的网络位置发出关于选择的服务的部署请求;
在网络位置中的所述选择的网络位置接收响应消息,响应消息包括选择的服务的替换者;并在网络位置中的所述选择的网络位置部署选择的服务的替换者。
32、一种在计算网络中动态重新部署服务的系统,包括:
接收关于选择的服务的重新部署触发的装置;
确定已从选择的服务在起始服务器上的最初位置向其部署选择的服务的一个或多个网络位置的装置;
有计划地从网络位置和起始服务器除去选择的服务的装置;和
有计划地替换网络位置和起始服务器上的选择的服务的装置。
33、一种在计算网络中动态重新部署服务的计算机程序产品,所述计算机程序产品包含在一个或多个计算机可读介质,并且包括:
接收关于选择的服务的重新部署触发的计算机可读程序代码装置;
确定已从选择的服务在起始服务器上的最初位置向其部署选择的服务的一个或多个网络位置的计算机可读程序代码装置;
有计划地从网络位置和起始服务器除去选择的服务的计算机可读程序代码装置;和
有计划地替换网络位置和起始服务器上的选择的服务的计算机可读程序代码装置。
CNA018220134A 2001-05-23 2001-10-05 计算网络中服务的动态部署 Pending CN1620653A (zh)

Applications Claiming Priority (4)

Application Number Priority Date Filing Date Title
US09/864,608 US8180871B2 (en) 2001-05-23 2001-05-23 Dynamic redeployment of services in a computing network
US09/864,663 US20020178254A1 (en) 2001-05-23 2001-05-23 Dynamic deployment of services in a computing network
US09/864,607 US7325047B2 (en) 2001-05-23 2001-05-23 Dynamic undeployment of services in a computing network
PCT/US2001/031268 WO2002095605A1 (en) 2001-05-23 2001-10-05 Dynamic deployment of services in a computing network

Publications (1)

Publication Number Publication Date
CN1620653A true CN1620653A (zh) 2005-05-25

Family

ID=27420431

Family Applications (1)

Application Number Title Priority Date Filing Date
CNA018220134A Pending CN1620653A (zh) 2001-05-23 2001-10-05 计算网络中服务的动态部署

Country Status (9)

Country Link
US (4) US8180871B2 (zh)
EP (1) EP1402385A4 (zh)
JP (1) JP2004533687A (zh)
KR (1) KR20040000441A (zh)
CN (1) CN1620653A (zh)
CA (1) CA2415314A1 (zh)
IL (1) IL152963A0 (zh)
TW (1) TW591909B (zh)
WO (1) WO2002095605A1 (zh)

Cited By (15)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101410863A (zh) * 2006-04-07 2009-04-15 国际商业机器公司 客户可配置的工作流系统
CN1881976B (zh) * 2005-06-16 2010-06-23 国际商业机器公司 基于协议的自动服务供应方法与设备
CN101951402A (zh) * 2010-09-17 2011-01-19 山东中创软件工程股份有限公司 一种Web Service可用性跟踪检测方法、装置及系统
CN101083587B (zh) * 2006-05-31 2011-04-20 Sap股份公司 在分层级的监视器服务中的设备注册
US8005879B2 (en) 2005-11-21 2011-08-23 Sap Ag Service-to-device re-mapping for smart items
US8131838B2 (en) 2006-05-31 2012-03-06 Sap Ag Modular monitor service for smart item monitoring
US8156208B2 (en) 2005-11-21 2012-04-10 Sap Ag Hierarchical, multi-tiered mapping and monitoring architecture for service-to-device re-mapping for smart items
US8181071B2 (en) 2007-06-29 2012-05-15 Microsoft Corporation Automatically managing system downtime in a computer network
US8396788B2 (en) 2006-07-31 2013-03-12 Sap Ag Cost-based deployment of components in smart item environments
US8522341B2 (en) 2006-03-31 2013-08-27 Sap Ag Active intervention in service-to-device mapping for smart items
US8527622B2 (en) 2007-10-12 2013-09-03 Sap Ag Fault tolerance framework for networks of nodes
CN101013956B (zh) * 2005-11-21 2014-05-21 Sap股份公司 智能项目的分级的多层映射和监视架构
CN108574598A (zh) * 2017-03-14 2018-09-25 安移通网络公司 网络部署
CN111343002A (zh) * 2020-02-10 2020-06-26 腾讯科技(深圳)有限公司 服务器扩容部署的方法、装置及服务器
CN113453194A (zh) * 2020-03-24 2021-09-28 大唐移动通信设备有限公司 一种移动边缘业务更新方法、装置、系统、设备及介质

Families Citing this family (177)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7657887B2 (en) * 2000-05-17 2010-02-02 Interwoven, Inc. System for transactionally deploying content across multiple machines
US7136913B2 (en) * 2000-05-31 2006-11-14 Lab 7 Networks, Inc. Object oriented communication among platform independent systems across a firewall over the internet using HTTP-SOAP
US7596784B2 (en) * 2000-09-12 2009-09-29 Symantec Operating Corporation Method system and apparatus for providing pay-per-use distributed computing resources
US8180871B2 (en) * 2001-05-23 2012-05-15 International Business Machines Corporation Dynamic redeployment of services in a computing network
US7194529B2 (en) * 2001-07-12 2007-03-20 Abb Inc. Method and apparatus for the delivery and integration of an asset management system into an existing enterprise network
US7313824B1 (en) * 2001-07-13 2007-12-25 Liquid Machines, Inc. Method for protecting digital content from unauthorized use by automatically and dynamically integrating a content-protection agent
US7111285B2 (en) * 2001-07-17 2006-09-19 Liquid Machines, Inc. Method and system for protecting software applications against static and dynamic software piracy techniques
US20030033467A1 (en) * 2001-08-08 2003-02-13 Satoshi Yoshizawa Method and apparatus for resource allocation in network router and switch
US7130898B2 (en) * 2001-08-27 2006-10-31 Sun Microsystems, Inc. Mechanism for facilitating invocation of a service
US7296061B2 (en) * 2001-11-21 2007-11-13 Blue Titan Software, Inc. Distributed web services network architecture
US7853643B1 (en) * 2001-11-21 2010-12-14 Blue Titan Software, Inc. Web services-based computing resource lifecycle management
EP1321853A3 (en) * 2001-12-10 2009-12-23 Sap Ag Dynamic component transfer based on resource negotiations between computer systems
JP2006502465A (ja) * 2002-01-11 2006-01-19 アカマイ テクノロジーズ インコーポレイテッド コンテンツ配信ネットワーク(CDN)で使用するためのJavaアプリケーションフレームワーク
CA2369797A1 (en) * 2002-01-31 2003-07-31 Bridgewater Systems Corporation System and method for web service management
AU2003211141A1 (en) * 2002-02-22 2003-09-09 Bea Systems, Inc. Web services runtime architecture
US20040015578A1 (en) * 2002-02-22 2004-01-22 Todd Karakashian Web services runtime architecture
US7769825B2 (en) * 2002-02-22 2010-08-03 Bea Systems, Inc. System and method for web services Java API-based invocation
US20060075070A1 (en) * 2002-04-02 2006-04-06 Patrick Merissert-Coffinieres Development and deployment of mobile and desktop applications within a flexible markup-based distributed architecture
US9137324B2 (en) * 2002-04-10 2015-09-15 International Business Machines Corporation Capacity on-demand in distributed computing environments
ITTO20020341A1 (it) * 2002-04-19 2003-10-20 Telecom Italia Lab Spa Procedimento per realizzare l'interlavoro fra reti del tipo content delivery network -cdn-,relativo insieme di reti e componente di interfac
US20030204612A1 (en) * 2002-04-30 2003-10-30 Mark Warren System and method for facilitating device communication, management and control in a network
US8892895B1 (en) 2002-05-07 2014-11-18 Data Recognition Corporation Integrated system for electronic tracking and control of documents
US6772081B1 (en) * 2002-05-21 2004-08-03 Data Recognition Corporation Priority system and method for processing standardized tests
US7290262B2 (en) * 2002-05-21 2007-10-30 International Business Machine Corporation Method and apparatus for dynamically determining information for deploying a web service
US7610404B2 (en) * 2002-05-22 2009-10-27 Cast Iron Systems, Inc. Application network communication method and apparatus
US8296433B2 (en) * 2002-05-22 2012-10-23 International Business Machines Corporation Virtualization method and apparatus for integrating enterprise applications
US20040010510A1 (en) * 2002-07-10 2004-01-15 Timo Hotti Method and system for database synchronization
US8073935B2 (en) * 2002-07-25 2011-12-06 Oracle America, Inc. Pluggable semantic verification and validation of configuration data
EP1401169A1 (en) * 2002-09-18 2004-03-24 Alcatel Method and system using a Meta service selector for deploying services over a plurality of networks
US7933891B2 (en) * 2002-09-26 2011-04-26 International Business Machines Corporation Web services data aggregation system and method
US8356067B2 (en) * 2002-10-24 2013-01-15 Intel Corporation Servicing device aggregates
US7991827B1 (en) * 2002-11-13 2011-08-02 Mcafee, Inc. Network analysis system and method utilizing collected metadata
US8385811B1 (en) 2003-02-11 2013-02-26 Data Recognition Corporation System and method for processing forms using color
US7302681B2 (en) * 2003-02-27 2007-11-27 Dell Products L.P. Method and system for customized information handling system support updates
US6901590B2 (en) * 2003-03-03 2005-05-31 Computer Associates Think, Inc. System and method for single transparent deployment flow
US8209375B2 (en) * 2003-03-07 2012-06-26 Ricoh Co., Ltd. Communication of compressed digital images with restricted access and server/client hand-offs
DE10319528A1 (de) * 2003-04-30 2004-11-25 Siemens Ag Verfahren und Anordnung zur transparenten dynamischen Bereitstellung eines Web-Services
US20040225724A1 (en) * 2003-05-08 2004-11-11 Gregory Pavlik RPC type SOAP service access via taglibs for dynamic web content
US8321590B2 (en) * 2003-05-22 2012-11-27 International Business Machines Corporation Application network communication
JP2004362183A (ja) * 2003-06-04 2004-12-24 Hitachi Ltd プログラム管理方法及び実施装置並びに処理プログラム
WO2005006219A2 (en) * 2003-07-11 2005-01-20 Computer Associates Think, Inc. Method and apparatus for translating a web services address
US7210125B2 (en) * 2003-07-17 2007-04-24 International Business Machines Corporation Method and system for application installation and management using an application-based naming system including aliases
US7483914B2 (en) 2003-07-17 2009-01-27 International Business Machines Corporation Method and system for implementing an application-based naming system
CN100349116C (zh) * 2003-08-05 2007-11-14 华为技术有限公司 一种提高接入网络的计算机的功能的方法及装置
US20050038708A1 (en) * 2003-08-10 2005-02-17 Gmorpher Incorporated Consuming Web Services on Demand
US20050038867A1 (en) * 2003-08-14 2005-02-17 International Business Machines Corporation Method, system and program product for integrating web services on a client
US7512949B2 (en) * 2003-09-03 2009-03-31 International Business Machines Corporation Status hub used by autonomic application servers
US20050065879A1 (en) 2003-09-18 2005-03-24 Convergys Information Management Group, Inc. System and method for web service billing
US20050102662A1 (en) * 2003-09-19 2005-05-12 Pctel, Inc. PCTEL-13800U automated updating system for wireless networks
US20050071758A1 (en) * 2003-09-30 2005-03-31 International Business Machines Corporation Client-side processing of alternative component-level views
US7502834B2 (en) * 2003-09-30 2009-03-10 International Business Machines Corporation Autonomic content load balancing
US7529824B2 (en) * 2003-10-14 2009-05-05 International Business Machines Corporation Method for selecting a service binding protocol in a service-oriented architecture
US7380003B1 (en) * 2003-10-30 2008-05-27 Microsoft Corporation Method and system for staged web service upgrade from an existing version to a different version
CA2449534A1 (en) * 2003-11-14 2005-05-14 Ibm Canada Limited - Ibm Canada Limitee On-demand software module deployment
CN1890942B (zh) * 2003-12-10 2010-04-14 国际商业机器公司 重定向对万维网服务的客户端请求的方法
DE602004011455T2 (de) * 2003-12-10 2009-01-22 International Business Machines Corp. Verfahren und System zur automatischen Erzeugung von Dienstschnittstellen für eine dienstorientierte Architektur
US7464142B2 (en) * 2003-12-12 2008-12-09 International Business Machines Corporation Port type agnostic proxy support for web services intermediates
WO2005060212A1 (en) * 2003-12-12 2005-06-30 International Business Machines Corporation Port type agnostic proxy support for web services intermediaries
EP1566940A1 (en) * 2004-02-20 2005-08-24 Alcatel Alsthom Compagnie Generale D'electricite A method, a service system, and a computer software product of self-organizing distributing services in a computing network
JP2005250548A (ja) * 2004-03-01 2005-09-15 Fujitsu Ltd 中継制御方法、中継制御プログラム、および中継制御装置
KR100505344B1 (ko) * 2004-03-03 2005-08-03 함경수 Urn 기능을 사용한 네임 식별자 다중 변환 서비스 및 시스템
US7493563B2 (en) * 2004-03-05 2009-02-17 International Business Machines Corporation Using content aggregation to build administration consoles
US7444633B2 (en) * 2004-03-05 2008-10-28 International Business Machines Corporation Federating legacy/remote content into a central network console
US8327290B2 (en) * 2004-04-06 2012-12-04 International Business Machines Corporation User task interface in a web application
CN100407154C (zh) * 2004-04-29 2008-07-30 国际商业机器公司 在分布式网络体系结构中建模和动态部署服务的系统和方法
US8095658B2 (en) * 2004-05-07 2012-01-10 International Business Machines Corporation Method and system for externalizing session management using a reverse proxy server
FR2870022B1 (fr) 2004-05-07 2007-02-02 Canon Kk Procede et dispositif de distribution de donnees numeriques notamment pour reseau pair-a-pair
WO2005114964A1 (en) * 2004-05-21 2005-12-01 Computer Associates Think, Inc. Method and apparatus for web service communication
US8762981B2 (en) * 2004-05-24 2014-06-24 Sap Ag Application loading and visualization
US7735097B2 (en) * 2004-05-24 2010-06-08 Sap Ag Method and system to implement a deploy service to perform deployment services to extend and enhance functionalities of deployed applications
US7562341B2 (en) * 2004-05-24 2009-07-14 Sap Ag Deploy callback system with bidirectional containers
US7721283B2 (en) * 2004-05-24 2010-05-18 Sap Ag Deploying a variety of containers in a Java 2 enterprise edition-based architecture
US7877735B2 (en) * 2004-05-25 2011-01-25 Sap Ag Application cloning
US7747698B2 (en) * 2004-05-25 2010-06-29 Sap Ag Transaction model for deployment operations
US7882502B2 (en) * 2004-05-25 2011-02-01 Sap Ag Single file update
US20050273507A1 (en) * 2004-06-08 2005-12-08 Yong Yan Method and system for managing heterogeneous resources across a distributed computer network
US7481867B2 (en) * 2004-06-16 2009-01-27 Edwards Limited Vacuum system for immersion photolithography
DE102004054648A1 (de) * 2004-11-11 2006-05-24 Francotyp-Postalia Ag & Co. Kg Verfahren zum Bereitstellen von Diensten zwischen Datenverarbeitungseinrichtungen
US20060149583A1 (en) * 2004-11-26 2006-07-06 Pfeiffer Clemens A Method and apparatus for using software automatically and without user interaction the same way people would use such software
US8347285B2 (en) * 2004-12-16 2013-01-01 Intel Corporation Embedded agent for self-healing software
JP4189379B2 (ja) * 2004-12-27 2008-12-03 株式会社日立製作所 アプリケーション運用制御方法およびシステム
US20060212855A1 (en) * 2005-03-16 2006-09-21 Bournas Redha M Methods, systems and computer program products for implementing production processes
US20060248121A1 (en) * 2005-04-15 2006-11-02 Michael Cacenco System and method for supporting packaging, publishing and republishing of wireless component applications
US7881198B2 (en) * 2005-04-25 2011-02-01 Telefonaktiebolaget L M Ericsson (Publ) Method for managing service bindings over an access domain and nodes therefor
US7698391B2 (en) * 2005-05-16 2010-04-13 Oracle International Corporation Performing a provisioning operation associated with a software application on a subset of the nodes on which the software application is to operate
US8078671B2 (en) 2005-09-21 2011-12-13 Sap Ag System and method for dynamic web services descriptor generation using templates
US20070067388A1 (en) * 2005-09-21 2007-03-22 Angelov Dimitar V System and method for configuration to web services descriptor
US7673028B2 (en) * 2005-09-28 2010-03-02 Sap Ag Method and system for container-managed configuration and administration
CN100442901C (zh) * 2005-10-25 2008-12-10 华为技术有限公司 在设备管理中监控和升级软件的方法及装置
US7702789B2 (en) * 2005-11-03 2010-04-20 International Business Machines Corporation Apparatus, system, and method for reassigning a client
US8533255B2 (en) * 2005-12-13 2013-09-10 Panasonic Corporation Systems and methods for handling failover in a distributed routing environment
US8024425B2 (en) * 2005-12-30 2011-09-20 Sap Ag Web services deployment
US7814060B2 (en) * 2005-12-30 2010-10-12 Sap Ag Apparatus and method for web service client deployment
US20070156872A1 (en) * 2005-12-30 2007-07-05 Stoyanova Dimitrina G Method and system for Web services deployment
US8010695B2 (en) * 2005-12-30 2011-08-30 Sap Ag Web services archive
US20080228459A1 (en) * 2006-10-12 2008-09-18 Nec Laboratories America, Inc. Method and Apparatus for Performing Capacity Planning and Resource Optimization in a Distributed System
CN101192937B (zh) * 2006-11-24 2010-05-12 华为技术有限公司 一种可热部署的方法及其系统
US8504711B1 (en) * 2006-12-12 2013-08-06 Google Inc. Integrating web services with a content item
US8499311B2 (en) * 2006-12-29 2013-07-30 Sap Ag Web container extension classloading
US7822755B2 (en) * 2007-03-06 2010-10-26 Yahoo! Inc. Methods of processing and segmenting web usage information
US20080250097A1 (en) * 2007-04-04 2008-10-09 Adadeus S.A.S Method and system for extending the services provided by an enterprise service bus
US7882301B2 (en) * 2007-05-09 2011-02-01 Stmicroelectronics S.R.L. Wear leveling in storage devices based on flash memories and related circuit, system, and method
US8572286B2 (en) * 2007-05-21 2013-10-29 Sap Ag Method and apparatus for mapping an appropriate service version for a client
US9219705B2 (en) * 2007-06-25 2015-12-22 Microsoft Technology Licensing, Llc Scaling network services using DNS
US8423955B2 (en) * 2007-08-31 2013-04-16 Red Hat, Inc. Method and apparatus for supporting multiple business process languages in BPM
US9058571B2 (en) * 2007-08-31 2015-06-16 Red Hat, Inc. Tool for automated transformation of a business process definition into a web application package
US8825713B2 (en) * 2007-09-12 2014-09-02 Red Hat, Inc. BPM system portable across databases
US8914804B2 (en) * 2007-09-12 2014-12-16 Red Hat, Inc. Handling queues associated with web services of business processes
US20090086269A1 (en) * 2007-09-28 2009-04-02 Kyocera Mita Corporation Image Forming Apparatus and Image Forming System
US8464270B2 (en) 2007-11-29 2013-06-11 Red Hat, Inc. Dependency management with atomic decay
US8832255B2 (en) 2007-11-30 2014-09-09 Red Hat, Inc. Using status inquiry and status response messages to exchange management information
US8954952B2 (en) * 2007-11-30 2015-02-10 Red Hat, Inc. Portable business process deployment model across different application servers
US8145747B2 (en) * 2007-12-11 2012-03-27 Microsoft Corporation Webpage domain monitoring
US8893141B2 (en) * 2008-01-28 2014-11-18 Microsoft Corporation System and method for describing applications for manageability and efficient scale-up deployment
US8316101B2 (en) * 2008-03-15 2012-11-20 Microsoft Corporation Resource management system for hosting of user solutions
US20090235353A1 (en) * 2008-03-15 2009-09-17 Microsoft Corporation Scalable Hosting of User Solutions
MX2009008285A (es) * 2008-08-12 2010-05-17 Bank Of America Procesamiento de automatizacion y peticion de flujo de trabajo.
US8281302B2 (en) * 2008-08-26 2012-10-02 Cisco Technology, Inc. Method and apparatus for dynamically instantiating services using a service insertion architecture
US8645837B2 (en) * 2008-11-26 2014-02-04 Red Hat, Inc. Graphical user interface for managing services in a distributed computing system
US8918761B1 (en) 2008-12-05 2014-12-23 Amazon Technologies, Inc. Elastic application framework for deploying software
US8370613B1 (en) * 2009-06-30 2013-02-05 Symantec Corporation Method and apparatus for automatically optimizing a startup sequence to improve system boot time
US8543686B2 (en) * 2009-07-23 2013-09-24 University-Industry Cooperation Group Of Kyung Hee University Dynamic resource collaboration between network service providers
US8898287B2 (en) * 2010-02-24 2014-11-25 Salesforce.Com, Inc. System, method and computer program product for monitoring data activity utilizing a shared data store
US8627426B2 (en) 2010-04-26 2014-01-07 Vmware, Inc. Cloud platform architecture
US8813065B2 (en) 2010-04-26 2014-08-19 Vmware, Inc. Microcloud platform delivery system
US8572706B2 (en) 2010-04-26 2013-10-29 Vmware, Inc. Policy engine for cloud platform
US9772831B2 (en) * 2010-04-26 2017-09-26 Pivotal Software, Inc. Droplet execution engine for dynamic server application deployment
US9448790B2 (en) 2010-04-26 2016-09-20 Pivotal Software, Inc. Rapid updating of cloud applications
US9483312B2 (en) * 2010-08-16 2016-11-01 International Business Machines Corporation Locating service endpoints from a service registry
KR101201904B1 (ko) * 2010-11-18 2012-11-16 와이즈토드 피티이. 엘티디. 클라우드 컴퓨팅에서의 리소스 분배 장치 및 그 방법
WO2012068465A1 (en) 2010-11-19 2012-05-24 Interdigital Patent Holdings, Inc. Machine-to-machine (m2m) interface procedures for announce and de-announce of resources
US20120131162A1 (en) * 2010-11-24 2012-05-24 Brandt Mark S Using a web service to delete dns records in a server hosting system
US8997078B2 (en) 2011-04-12 2015-03-31 Pivotal Software, Inc. Release lifecycle management system for a multi-node application
US9015320B2 (en) * 2011-07-12 2015-04-21 Bank Of America Corporation Dynamic provisioning of service requests
US9369307B2 (en) 2011-07-12 2016-06-14 Bank Of America Corporation Optimized service integration
US9170798B2 (en) 2012-03-02 2015-10-27 Vmware, Inc. System and method for customizing a deployment plan for a multi-tier application in a cloud infrastructure
JP6061936B2 (ja) 2011-09-20 2017-01-18 イーサワークス エルエルシーAetherworks, Llc ロケーションニュートラルソフトウェアの需要増大に伴う展開に対するシステム及び方法
US10348573B2 (en) * 2012-01-11 2019-07-09 Saguna Networks Ltd. Methods, circuits, devices, systems and associated computer executable code for facilitating local hosting and access of internet based information
US8862984B1 (en) * 2012-02-01 2014-10-14 Amazon Technologies, Inc. Data contracts for network page generation code
US8819477B1 (en) 2012-02-01 2014-08-26 Amazon Technologies, Inc. Error handling in a network page generation environment
US9800455B1 (en) 2012-02-08 2017-10-24 Amazon Technologies, Inc. Log monitoring system
JP2013218670A (ja) * 2012-02-28 2013-10-24 Sap Ag コンピュータ実装方法、コンピュータシステム、およびコンピュータ可読記録媒体
US10031783B2 (en) 2012-03-02 2018-07-24 Vmware, Inc. Execution of a distributed deployment plan for a multi-tier application in a cloud infrastructure
US9047133B2 (en) 2012-03-02 2015-06-02 Vmware, Inc. Single, logical, multi-tier application blueprint used for deployment and management of multiple physical applications in a cloud environment
US9052961B2 (en) 2012-03-02 2015-06-09 Vmware, Inc. System to generate a deployment plan for a cloud infrastructure according to logical, multi-tier application blueprint
US8972968B1 (en) * 2012-05-31 2015-03-03 Amazon Technologies, Inc. Alternate service for applications
US9348652B2 (en) 2012-07-02 2016-05-24 Vmware, Inc. Multi-tenant-cloud-aggregation and application-support system
CN102882984A (zh) * 2012-10-24 2013-01-16 曲阜师范大学 一种云计算平台的资源负载均衡方法
EP2782316A1 (en) * 2013-03-18 2014-09-24 Koninklijke KPN N.V. Localizing and placement of network node functions in a network
JP6052406B2 (ja) 2013-05-31 2016-12-27 日本電気株式会社 分散処理システム、分散処理装置、分散処理方法および分散処理プログラム
CN104243190B (zh) * 2013-06-09 2018-06-15 新华三技术有限公司 一种实现零配置联网协议服务的方法和网络设备
US8745221B1 (en) 2013-09-18 2014-06-03 Limelight Networks, Inc. Dynamic request rerouting
EP3127302B1 (en) * 2014-03-29 2021-11-10 Akamai Technologies, Inc. Traffic on-boarding for acceleration through out-of-band security authenticators
TWI552547B (zh) * 2014-07-22 2016-10-01 廣達電腦股份有限公司 資料傳輸服務切換系統和方法
US9575812B2 (en) 2014-12-31 2017-02-21 Servicenow, Inc. Classification based automated instance management
CN105991687B (zh) 2015-02-03 2019-09-17 阿里巴巴集团控股有限公司 一种服务管理方法和装置
US10320877B2 (en) * 2015-04-20 2019-06-11 Splunk Inc. Systems and methods for indicating deployment of application features
US10749985B2 (en) 2015-05-19 2020-08-18 Amazon Technologies, Inc. Custom communication channels for application deployment
EP3368976A1 (en) * 2015-10-30 2018-09-05 British Telecommunications public limited company Mobile information processing
JP2017126238A (ja) * 2016-01-15 2017-07-20 日本電気株式会社 システム管理装置、情報処理システム、システム管理方法及びプログラム
US10554751B2 (en) 2016-01-27 2020-02-04 Oracle International Corporation Initial resource provisioning in cloud systems
US10521243B2 (en) * 2016-09-16 2019-12-31 Oracle International Corporation Pre/post deployment customization
US10360012B2 (en) * 2017-11-09 2019-07-23 International Business Machines Corporation Dynamic selection of deployment configurations of software applications
US11425085B1 (en) * 2017-11-20 2022-08-23 Amazon Technologies, Inc. Service discovery and renaming
US20190197596A1 (en) * 2017-12-21 2019-06-27 Octraves Technology Sdn Bhd System, apparatus, and method for integrating a plurality of supplier systems
US10884815B2 (en) 2018-10-29 2021-01-05 Pivotal Software, Inc. Independent services platform
US11196837B2 (en) 2019-03-29 2021-12-07 Intel Corporation Technologies for multi-tier prefetching in a context-aware edge gateway
US11184236B2 (en) 2019-04-30 2021-11-23 Intel Corporation Methods and apparatus to control processing of telemetry data at an edge platform
CN112532758B (zh) * 2019-09-19 2023-04-18 贵州白山云科技股份有限公司 一种网络边缘计算系统的创建方法、装置及介质
US20200136921A1 (en) 2019-09-28 2020-04-30 Intel Corporation Methods, system, articles of manufacture, and apparatus to manage telemetry data in an edge environment
US11102630B2 (en) 2019-10-25 2021-08-24 Telefonaktiebolaget Lm Ericsson (Publ) Method for service placement in a multi-access/mobile edge computing (MEC) system
CN111552482A (zh) * 2020-04-21 2020-08-18 深圳市塔洛思技术有限公司 一种适用边缘计算的去中心化的服务动态部署方法及装置
GB2610756A (en) * 2020-05-12 2023-03-15 Harmonic Inc Dynamic adjustment of deployment location of software within a network
US20230221936A1 (en) * 2020-06-25 2023-07-13 Hewlett-Packard Development Company, L.P. Geographic deployment of applications to edge computing nodes
JP7509495B2 (ja) 2020-09-23 2024-07-02 積水ホームテクノ株式会社 浴槽可動式浴室
JP7529342B2 (ja) 2020-09-23 2024-08-06 積水ホームテクノ株式会社 浴槽可動式浴室
JP7509497B2 (ja) 2021-03-31 2024-07-02 積水ホームテクノ株式会社 浴槽可動式浴室

Family Cites Families (35)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US104071A (en) * 1870-06-07 Improved grater
US78167A (en) * 1868-05-19 Improvement in mfting-jack
US5341477A (en) * 1989-02-24 1994-08-23 Digital Equipment Corporation Broker for computer network server selection
US5657451A (en) * 1994-01-24 1997-08-12 Telefonaktiebolaget Lm Ericsson System for determining whether to accept new supplementary services based upon identified types of supplementary service interactions and identified supplementary service interaction criteria
US5907675A (en) * 1995-03-22 1999-05-25 Sun Microsystems, Inc. Methods and apparatus for managing deactivation and shutdown of a server
US5774668A (en) * 1995-06-07 1998-06-30 Microsoft Corporation System for on-line service in which gateway computer uses service map which includes loading condition of servers broadcasted by application servers for load balancing
US6094680A (en) * 1996-06-27 2000-07-25 Microsoft Corporation System and method for managing distributed resources on networks
US6055570A (en) * 1997-04-03 2000-04-25 Sun Microsystems, Inc. Subscribed update monitors
US5983281A (en) * 1997-04-24 1999-11-09 International Business Machines Corporation Load balancing in a multiple network environment
US6256675B1 (en) * 1997-05-06 2001-07-03 At&T Corp. System and method for allocating requests for objects and managing replicas of objects on a network
US6173322B1 (en) * 1997-06-05 2001-01-09 Silicon Graphics, Inc. Network request distribution based on static rules and dynamic performance data
US6363411B1 (en) * 1998-08-05 2002-03-26 Mci Worldcom, Inc. Intelligent network
US6081840A (en) * 1997-10-14 2000-06-27 Zhao; Yan Two-level content distribution system
US6631425B1 (en) * 1997-10-28 2003-10-07 Microsoft Corporation Just-in-time activation and as-soon-as-possible deactivation or server application components
US6167427A (en) * 1997-11-28 2000-12-26 Lucent Technologies Inc. Replication service system and method for directing the replication of information servers based on selected plurality of servers load
US6324543B1 (en) * 1998-03-06 2001-11-27 International Business Machines Corporation Dynamic object migration method using proxy object links to support automatic object distribution in an object-oriented environment
US6167444A (en) * 1998-05-08 2000-12-26 International Business Machines Corporation Method and system for exchanging routing information
US6549932B1 (en) * 1998-06-03 2003-04-15 International Business Machines Corporation System, method and computer program product for discovery in a distributed computing environment
US6421727B1 (en) * 1998-09-22 2002-07-16 Abraham Issachar Reifer Internetworking system and method for a global telecommunications network
US6631512B1 (en) * 1999-01-15 2003-10-07 Gillis E Onyeabor Method and system for database-driven, scalable web page development, deployment-download, and execution
JP3545252B2 (ja) 1999-03-30 2004-07-21 富士通株式会社 情報処理装置
US6745241B1 (en) * 1999-03-31 2004-06-01 International Business Machines Corporation Method and system for dynamic addition and removal of multiple network names on a single server
US6233607B1 (en) * 1999-04-01 2001-05-15 Diva Systems Corp. Modular storage server architecture with dynamic data management
US6553423B1 (en) * 1999-05-27 2003-04-22 Cisco Technology, Inc. Method and apparatus for dynamic exchange of capabilities between adjacent/neighboring networks nodes
US6779032B1 (en) * 1999-07-01 2004-08-17 International Business Machines Corporation Method and system for optimally selecting a Telnet 3270 server in a TCP/IP network
US6418452B1 (en) * 1999-11-03 2002-07-09 International Business Machines Corporation Network repository service directory for efficient web crawling
JP2001306537A (ja) * 2000-04-18 2001-11-02 Hitachi Ltd 分散オブジェクトシステム
EP1292886A1 (en) * 2000-04-21 2003-03-19 Togethersoft Corporation Methods and systems for supporting and deploying distributed computing components
US6654610B1 (en) * 2000-05-05 2003-11-25 Lucent Technologies Inc. Two-way packet data protocol methods and apparatus for a mobile telecommunication system
US6880156B1 (en) * 2000-07-27 2005-04-12 Hewlett-Packard Development Company. L.P. Demand responsive method and apparatus to automatically activate spare servers
US6704024B2 (en) * 2000-08-07 2004-03-09 Zframe, Inc. Visual content browsing using rasterized representations
US6970939B2 (en) 2000-10-26 2005-11-29 Intel Corporation Method and apparatus for large payload distribution in a network
US6993577B2 (en) * 2000-12-20 2006-01-31 Comverse, Inc. System and method for migration of subscriber data
US6990574B2 (en) * 2001-05-01 2006-01-24 General Electric Company Object oriented framework for scanner/workstation configuration
US8180871B2 (en) * 2001-05-23 2012-05-15 International Business Machines Corporation Dynamic redeployment of services in a computing network

Cited By (23)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN1881976B (zh) * 2005-06-16 2010-06-23 国际商业机器公司 基于协议的自动服务供应方法与设备
CN101013957B (zh) * 2005-11-21 2014-05-28 Sap股份公司 智能项目的服务-设备重映射的分级多层映射和监视架构
CN101013956B (zh) * 2005-11-21 2014-05-21 Sap股份公司 智能项目的分级的多层映射和监视架构
US8005879B2 (en) 2005-11-21 2011-08-23 Sap Ag Service-to-device re-mapping for smart items
US8156208B2 (en) 2005-11-21 2012-04-10 Sap Ag Hierarchical, multi-tiered mapping and monitoring architecture for service-to-device re-mapping for smart items
US8522341B2 (en) 2006-03-31 2013-08-27 Sap Ag Active intervention in service-to-device mapping for smart items
CN101410863A (zh) * 2006-04-07 2009-04-15 国际商业机器公司 客户可配置的工作流系统
US8131838B2 (en) 2006-05-31 2012-03-06 Sap Ag Modular monitor service for smart item monitoring
CN101083587B (zh) * 2006-05-31 2011-04-20 Sap股份公司 在分层级的监视器服务中的设备注册
US8296413B2 (en) 2006-05-31 2012-10-23 Sap Ag Device registration in a hierarchical monitor service
US8751644B2 (en) 2006-05-31 2014-06-10 Sap Ag Modular monitor service for smart item monitoring
CN101083586B (zh) * 2006-05-31 2012-05-30 Sap股份公司 用于智能物件监视的模块化监视器服务系统和方法
US8396788B2 (en) 2006-07-31 2013-03-12 Sap Ag Cost-based deployment of components in smart item environments
US8181071B2 (en) 2007-06-29 2012-05-15 Microsoft Corporation Automatically managing system downtime in a computer network
CN101689161B (zh) * 2007-06-29 2016-03-09 微软技术许可有限责任公司 自动管理计算机网络中的系统停机时间
US8527622B2 (en) 2007-10-12 2013-09-03 Sap Ag Fault tolerance framework for networks of nodes
CN101951402A (zh) * 2010-09-17 2011-01-19 山东中创软件工程股份有限公司 一种Web Service可用性跟踪检测方法、装置及系统
CN101951402B (zh) * 2010-09-17 2013-02-20 山东中创软件工程股份有限公司 一种Web Service可用性跟踪检测方法、装置及系统
CN108574598A (zh) * 2017-03-14 2018-09-25 安移通网络公司 网络部署
CN111343002A (zh) * 2020-02-10 2020-06-26 腾讯科技(深圳)有限公司 服务器扩容部署的方法、装置及服务器
CN113453194A (zh) * 2020-03-24 2021-09-28 大唐移动通信设备有限公司 一种移动边缘业务更新方法、装置、系统、设备及介质
WO2021189938A1 (zh) * 2020-03-24 2021-09-30 大唐移动通信设备有限公司 一种移动边缘业务更新方法、装置、系统、设备及介质
CN113453194B (zh) * 2020-03-24 2022-08-23 大唐移动通信设备有限公司 一种移动边缘业务更新方法、装置、系统、设备及介质

Also Published As

Publication number Publication date
CA2415314A1 (en) 2002-11-28
US7523177B2 (en) 2009-04-21
TW591909B (en) 2004-06-11
US7325047B2 (en) 2008-01-29
IL152963A0 (en) 2003-06-24
US20020178244A1 (en) 2002-11-28
KR20040000441A (ko) 2004-01-03
EP1402385A4 (en) 2007-05-16
JP2004533687A (ja) 2004-11-04
US20080028024A1 (en) 2008-01-31
EP1402385A1 (en) 2004-03-31
WO2002095605A1 (en) 2002-11-28
US20020178214A1 (en) 2002-11-28
US8180871B2 (en) 2012-05-15
US20020178254A1 (en) 2002-11-28

Similar Documents

Publication Publication Date Title
CN1620653A (zh) 计算网络中服务的动态部署
CN1197027C (zh) 计算机网络的分布式宿主构架,网页供应和内容传送方法
US9219705B2 (en) Scaling network services using DNS
US6327622B1 (en) Load balancing in a network environment
US10419289B2 (en) System and method for configuration management service
CN1311380C (zh) 有助于从网络的移动设备中选择本地注册表主机的方法和系统
US8972998B2 (en) Processing annotation requests using multithreaded constituent task and independent input/output tasks
US8356274B2 (en) System and methods to create a multi-tenancy software as a service application
CN1113504C (zh) 服务器侧的异步格式管理
US20130332550A1 (en) Methods and systems for providing customized domain messages
US20040205162A1 (en) Method of executing an edge-enabled application in a content delivery network (CDN)
KR20180090180A (ko) 웹사이트 액세스 방법, 장치, 및 웹사이트 시스템
US20060136235A1 (en) Dynamic grid paths
CN1689019A (zh) 用于在万维网服务架构中对服务进行排名的方法和系统
JPH10312350A (ja) リソース命名方法及び機構
CN103841134A (zh) 基于api发送、接收信息的方法、装置及系统
JP6485980B2 (ja) ネットワークアドレスの解決
CN103391312A (zh) 资源离线下载方法及装置
CN102523308A (zh) 一种应用开发方法和运行该方法所开发应用的平台系统
CN1791105A (zh) 控制到客户机的数据传送及更新数据的执行的方法
CN100461174C (zh) 用于动态地创建web服务的方法和系统
EP1325424A2 (en) Method and system for assembling concurrently-generated content
US20080294728A1 (en) Service Discovery for Electronic Messaging Clients
CN109190072A (zh) 一种发送网页资源的方法和装置
CN118819685A (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
C12 Rejection of a patent application after its publication
RJ01 Rejection of invention patent application after publication