The present invention relates generally to middleware, and relates more particularly to the assembly of a middleware system from discrete middleware components. Specifically, the present invention provides a method and apparatus for dynamic assembly and adaptation of middleware components.
Systems software that functions as an intermediary between different components (e.g., applications and services) is generally referred to in the computer industry as middleware. Middleware is a mechanism used to simplify the development of software systems by adding one layer of indirection between the operating system and the application. It is often employed to integrate and coordinate the interoperation of distributed, heterogeneous applications over a network. For example, middleware may allow a program written for access to a particular database to access other databases as well. Middleware is also used by applications to coordinate updates to multiple databases. In yet another example, middleware may also allow a program written in one programming language to interoperate with a (seemingly incompatible) program written in a different programming language. In all cases, the role of middleware is to functionally mediate between (software, hardware and networking) infrastructure and applications; middleware is specialized software that enables other software (e.g., applications and services) to interoperate.
Traditional middleware models, while configurable, are static; that is, specific middleware components with specific sets of features and functions are typically selected prior to application development, deployment and execution. The middleware components are installed on a specific client at which an application executes, and execution of application programs by the client is limited to the installed middleware technology.
When middleware is deployed within a service-oriented architecture, such a static model may not be optimal. In such architectures, applications will tend to dynamically find and interact with each other. Thus, the required or desired features and functions to be provided by the middleware may not be known until runtime (e.g., for services only discovered at runtime), may depend on changing system conditions (e.g., network load or global security policies), or may change over time as new versions of middleware features and functions become available.
Thus, there is a need in the art for a method and apparatus for dynamic middleware assembly.
In one embodiment, the present invention is a method and apparatus for dynamic middleware assembly. One embodiment of the inventive method for dynamically assembling middleware at a client involves selecting a middleware component from a group of middleware components, where the selection is based at least in part on a first profile defining characteristics of the client and a second profile defining characteristics of the selected middleware component. The selected middleware component is then dynamically assembled (installed and configured) at the client.
So that the manner in which the above recited embodiments of the invention are attained and can be understood in detail, a more particular description of the invention, briefly summarized above, may be obtained by reference to the embodiments thereof which are illustrated in the appended drawings. It is to be noted, however, that the appended drawings illustrate only typical embodiments of this invention and are therefore not to be considered limiting of its scope, for the invention may admit to other equally effective embodiments.
To facilitate understanding, identical reference numerals have been used, where possible, to designate identical elements that are common to the figures.
In one embodiment, the present invention is a method and apparatus for dynamic middleware assembly. The method and apparatus of the present invention allow applications to be developed, deployed and executed simply by declaring which middleware features and functions are needed; however, unlike traditional middleware architectures, an actual presence and/or prior installation of middleware components on a client is not necessary. The required middleware components are automatically assembled and configured when necessary.
Each of the clients 102, services 104 and middleware components 106 is defined by a respective profile. The profiles are declarative specifications (e.g., metadata) that can be compared against other profiles in order to dynamically select and configure particular middleware components 106 that will enable an application at a given client 102 to interact with a specific service 104 or other application, as described in further detail below. In one embodiment, one or more profiles are expressed using known declarative languages that support the definition of requirements and/or assertions of middleware functions and features. For example, in one embodiment, the language defined in the extensible markup language (XML)-based Web Services Policy Framework is used to express the profiles.
In one embodiment, each client 102 is defined by a client profile comprising a declarative specification of the functional and non-functional requirements, capabilities and/or desired quality-of-service of the applications deployed on the client. For example, a client profile may declare secure authentication as a requirement for interaction (e.g., with services or other applications), may specify the preferred use of a reliable messaging protocol with exactly-once delivery semantics, or may require the support of a distributed transaction interoperability protocol for transactional interaction. In one embodiment, the client profile also reflects (directly or indirectly) the middleware components 106 that are already installed at the client 102.
In one embodiment, each service 104 is defined by a service profile comprising a declarative specification of the service's requirements and capabilities (e.g., similar to the client profile). In one embodiment, a service profile is attached to the actual deployed service, for example utilizing known attachment mechanisms such as Web Services Policy Attachment.
In one embodiment, each middleware component 106 in the middleware repository 108 is defined by a component profile comprising a declarative specification of the functional and non-functional properties of the component (e.g., similar to the client or service profile). For example, the component profile of a middleware component that produces security context tokens might describe middleware component's supported functions and security model, or a component profile of a middleware component that implements transactional coordination might describe the middleware component's supported transaction model and transaction protocols. In further embodiments, a component profile of a middleware component may define supported interoperability protocols and/or supported quality of service models.
The method 200 is initialized at step 202 and proceeds to step 204, where the method 200 selects (e.g., from the middleware repository 108) one or more middleware components for deployment at a client. In one embodiment, the middleware components are selected based on one or more profiles pertaining to at least one of the client, a middleware component and a service, as described above with respect to
The method 200 then proceeds to step 206 and assembles the selected middleware components at the client. Assembling the selected middleware components in accordance with step 206 includes installing and configuring the selected middleware components at the client. In one embodiment, step 206 further includes uninstalling one or more existing or previously installed middleware components. The method 200 then terminates in step 208. The method 200 may be repeated any number of times in order to configure one or more clients or applications for interaction with one or more services.
The method 200, as described above, enables a first application residing at a client to simply specify one or more services or other applications with which the first application wishes to interact, and then dynamically selects and configures the middleware components necessary to support the desired interaction. Thus, the first application, or the client on which the first application resides, need not do anything further than specify the desired interactions.
Moreover, the use of profiles in the selection of middleware components offers an increased level of flexibility for application development, deployment and execution. For example, middleware components may be flexibly distributed between applications and services, or middleware components may be “offloaded” or “hosted” off the network (e.g., network 100) to accommodate changes in computing environments and/or application interaction requirements (e.g., computing load, required reliability or security levels, and the like). For example, an application may require support for the transactional coordination of multiple databases. One solution is to locally install a transaction coordination middleware component at the client. Another solution is to install a smaller middleware component at the client only, and use a remote middleware component that offers transactional coordination as a service. The remote component in the latter case is “hosted” and provided by a third party. Using the methods of the present invention, an application can flexibly switch between these two options over time. This flexibility enables a network that implements a dynamic middleware system of the present invention to better respond to client needs under changing network, application and service conditions.
In one embodiment, the consideration of environmental conditions is a default step, but may optionally be bypassed. Bypass may be desirable, for example, in a case where a client already knows which middleware components are needed and wants to install these components independent of environmental conditions (requirements for interaction with a particular service may have been communicated in other forms). The client would still require implementation of the present invention for flexible middleware assembly.
If the method 300 determines in step 304 that one or more environmental conditions should be considered, the method 300 proceeds to step 306 and gathers and evaluates relevant environmental data and criteria. The method 300 then proceeds to step 308 and determines whether a profile matching step is required. Alternatively, if the method 300 determines in step 304 that no environmental conditions need to be considered, the method 300 may bypass step 306 and proceed directly to step 308. In one embodiment, the method 300 concludes that profile matching is not required if middleware components are to be installed at the client independent of a particular service interaction (e.g., if an application at the client wishes to install components based on requirements specified by something other than by a particular service); in all or most other cases, profile matching is required.
If the method 300 determines in step 308 that profile matching is required, the method 300 proceeds to step 310 and performs profile matching. In one embodiment, profile matching in accordance with step 310 involves matching a client profile to one or more service profiles. The profile matching step 310 determines whether the client profile and the one or more service profiles are compatible, and if so, which middleware components are required for service interaction.
In one embodiment, known matching techniques are implemented in accordance with step 310. For example, one appropriate matching technique is described by Wohlstadter et al. in “GlueQoS: Middleware to Sweeten Quality-of-Service Policy Interactions”, Proceedings IEEE 26th International Conference on Software Engineering (ICSE'04), Edinburgh, Scotland, United Kingdom, May 2004. In one embodiment, an acceptable threshold for compatibility between two or more profiles is dependent upon the interaction to be supported. For example, in one embodiment, interactions involving protocols require the profiles to be perfect matches. However, other interactions may tolerate a profile match that is less than perfect or exact.
For example, if a client profile specifies a requirement for a security mechanism, and a service profile of a service desired for interaction specifies a requirement for the same security mechanism, the client profile and the service profile are considered to be compatible in regards to the security aspect by the method 300. Accordingly, a middleware component supporting the specified security mechanism is required for installation at the client. Alternatively, if the service profile specifies a requirement for a security mechanism that is not included in the client profile, the method 300 may still consider the client profile and the service profile to be compatible, and a middleware component supporting the security mechanism specified by the service profile will be required for installation at the client. However, if the client profile explicitly states that it does not support the security (or any other) mechanism required by the service profile, the method 300 will conclude that the client profile and the service profile are not compatible, and the application and the client will be considered incapable of interacting with the desired service.
Once profile matching is completed, the method 300 proceeds to step 312 and determines whether a middleware component search (e.g., using a repository of middleware components) is necessary. However, if the method 300 concludes at step 308 that no profile matching is required, the method 300 may bypass the profile matching step 310 and proceed directly to step 312.
In one embodiment, a middleware component search is necessary if one or more middleware components necessary to support interaction of a matched client and service are not already installed at the client. If the method 300 determines that a middleware component search is necessary, the method 300 proceeds to step 314 and queries the middleware component repository to locate the necessary middleware components (e.g., middleware the will support interaction between a matched client and service). In one embodiment, the repository is searched using data contained one or more of the client profile, environmental data and profile matching results. One or more of the middleware components yielded by the repository search are then selected for installation at the client. In one embodiment, selection of a middleware component is accomplished by verifying the middleware component's compatibility with respect to other middleware components already installed at the client.
In some embodiments, search of the repository may not yield a middleware component having the desired functionality, or may alternatively yield a set of alternative middleware components from which a subset of middleware components can be selected for assembly.
Once the appropriate middleware components have been located and selected, the method 300 proceeds to step 316 and determines whether all middleware components necessary to support interaction of the client and the desired service have been selected. However, if the method 300 determines in step 312 that a component search is not necessary, the method 300 bypasses step 314 and proceeds directly to step 316.
If the method 300 concludes in step 316 that all necessary middleware components have been selected, the method 300 terminates in step 318. Alternatively, if the method 300 determines that one or more additional middleware components still need to be selected, the method 300 returns to step 304 and proceeds as described above. In one embodiment, the method 300 repeats this iterative process until all required middleware components have been selected.
In step 406, the method 400 determines whether it is necessary to uninstall any previously installed or preexisting middleware components at the client (e.g., if the preexisting middleware component is no longer needed and if its presence conflicts with a new middleware component). If the method 400 concludes that one or more preexisting middleware components need to be uninstalled at the client, the method 400 proceeds to step 408 and uninstalls the preexisting component.
The method 400 then proceeds to step 410 and updates the client profile to reflect the newly installed and/or newly uninstalled middleware components and any other changes that impact the client profile. If the method 400 concludes in step 406 that there are no preexisting middleware components that need to be uninstalled at the client, the method 400 bypasses step 408 and proceeds directly to step 410 to update the client profile.
In step 412, the method 400 determines whether all of the selected middleware components have been installed at the client. If the method 400 concludes that all selected middleware components have been installed, the method 400 terminates at step 414. Alternatively, if the method 400 determines that there are one or more selected middleware components that still require installation, the method 400 returns to step 404 and proceeds as described above. In one embodiment, the method 400 repeats this iterative process until all selected middleware components have been installed at the client.
Alternatively, the middleware assembly module 505 can be represented by one or more software applications (or even a combination of software and hardware, e.g., using Application Specific Integrated Circuits (ASIC)), where the software is loaded from a storage medium (e.g., I/O devices 506) and operated by the processor 502 in the memory 504 of the general purpose computing device 500. Thus, in one embodiment, the middleware assembly module 505 for dynamically selecting and configuring middleware components at a client described herein with reference to the preceding Figures can be stored on a computer readable medium or carrier (e.g., RAM, magnetic or optical drive or diskette, and the like).
In other embodiments, the apparatus or methods of the present invention may be provided as a business service. For example, a business might host services, or might host a middleware component repository that can be queried on behalf of one or more user applications in order to locate and/or configure middleware components that support a desired interaction. To this end, the business might receive one or more requests from a user specifying services or applications with which the user wishes to interact. The business may then perform one or more profile matching and query operations as described above in order to properly configure the user's machine or application for the desired interaction.
Thus, the present invention represents a significant advancement in the field of middleware configuration. The system and methods of the present invention allow applications to be dynamically developed, deployed and executed simply by declaring which middleware features and functions are needed. This enables a network that implements a dynamic middleware system of the present invention to better respond to client needs under changing network, application and service conditions.
While foregoing is directed to the preferred embodiment of the present invention, other and further embodiments of the invention may be devised without departing from the basic scope thereof, and the scope thereof is determined by the claims that follow.
This application is a continuation of U.S. patent application Ser. No. 10/991,149, filed Nov. 17, 2004 (now U.S. Pat. No. 7,797,698), which is herein incorporated by reference in its entirety.
Number | Name | Date | Kind |
---|---|---|---|
5805897 | Glowny | Sep 1998 | A |
5892953 | Bhagria et al. | Apr 1999 | A |
5960204 | Yinger et al. | Sep 1999 | A |
6189051 | Oh et al. | Feb 2001 | B1 |
6279154 | Davis | Aug 2001 | B1 |
6301708 | Gazdik et al. | Oct 2001 | B1 |
6351850 | van Gilluwe et al. | Feb 2002 | B1 |
6378128 | Edelstein et al. | Apr 2002 | B1 |
6401238 | Brown et al. | Jun 2002 | B1 |
6494979 | DiChiara, Jr. | Dec 2002 | B1 |
6681392 | Henry et al. | Jan 2004 | B1 |
6721946 | Fogarty et al. | Apr 2004 | B1 |
6769118 | Garrison et al. | Jul 2004 | B2 |
6854112 | Crespo et al. | Feb 2005 | B2 |
6918112 | Bourke-Dunphy et al. | Jul 2005 | B2 |
6985939 | Fletcher et al. | Jan 2006 | B2 |
7058942 | Bourke-Dunphy et al. | Jun 2006 | B2 |
7103874 | McCollum et al. | Sep 2006 | B2 |
7185336 | Vaughan | Feb 2007 | B2 |
7203937 | Kyle et al. | Apr 2007 | B1 |
7228189 | Gaddy et al. | Jun 2007 | B1 |
7228542 | Bryant et al. | Jun 2007 | B2 |
7340739 | Alam | Mar 2008 | B2 |
7343601 | Azagury et al. | Mar 2008 | B2 |
7353281 | New et al. | Apr 2008 | B2 |
7363623 | Kishida | Apr 2008 | B2 |
7500237 | Saiyed et al. | Mar 2009 | B1 |
7584471 | Bjare et al. | Sep 2009 | B2 |
7676448 | Henderson et al. | Mar 2010 | B2 |
7797698 | Diament et al. | Sep 2010 | B2 |
7844963 | Pitzel et al. | Nov 2010 | B2 |
8042107 | Amodio et al. | Oct 2011 | B2 |
8156489 | Kane | Apr 2012 | B2 |
20020091939 | Garrison et al. | Jul 2002 | A1 |
20020133814 | Bourke-Dunphy et al. | Sep 2002 | A1 |
20030037327 | Cicciarelli et al. | Feb 2003 | A1 |
20030037328 | Cicciarelli et al. | Feb 2003 | A1 |
20030046682 | Crespo et al. | Mar 2003 | A1 |
20040068722 | Amodio et al. | Apr 2004 | A1 |
20040093593 | Jhanwar et al. | May 2004 | A1 |
20040098715 | Aghera et al. | May 2004 | A1 |
20040123284 | Bryant et al. | Jun 2004 | A1 |
20050071838 | Haasaki | Mar 2005 | A1 |
20050120344 | Asare et al. | Jun 2005 | A1 |
20050172285 | Bourke-Dunphy et al. | Aug 2005 | A1 |
20060005181 | Fellenstein et al. | Jan 2006 | A1 |
20060080656 | Cain et al. | Apr 2006 | A1 |
20060130054 | Bocking et al. | Jun 2006 | A1 |
20070214028 | Stich et al. | Sep 2007 | A1 |
20080244559 | Imasato et al. | Oct 2008 | A1 |
Entry |
---|
Microsoft Computer Dictionary 5th Edition, published by Microsoft, 2002, ISBN 0-7356-1495-4, p. 340. |
Schantz et al., Middleware for Distributed Systems Evolving the Common Structure for Network-centric Applications, published in Encyclopedia of Software Engineering, J. Marciniak, and G. Telecki, Eds. John Wiley & Sons, Inc., New York, 2001, pp. 1-15. |
Gokhale et al., Applying Model-Integrated Computing to Component Middleware and Enterprise Applications, published by Communications of The ACM Oct. 2002/vol. 45, No. 10, pp. 65-70. |
Number | Date | Country | |
---|---|---|---|
20100306761 A1 | Dec 2010 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 10991149 | Nov 2004 | US |
Child | 12853037 | US |