1. Technical Field
The invention relates generally to web services, and more particularly, to a method, system, and program product for coordinating the actions of distributed web services using an imbedded orchestration engine.
2. Background Art
Web services provide many functions and are capable of performing various tasks, such as database queries, computational functions, graphical and/or auditory rendering, message delivery, etc. In some instances, it is desirable or necessary to utilize more than one web service to complete a particular task or function. However, the web services needed may be provided by disparate providers and employ different protocols. Often, such protocols are proprietary or platform-specific, making the interoperability of web services difficult or impossible. For example, even though two web services utilize an extensible markup language (XML) calling convention, their XML payloads may differ. In order for two such web services to communicate, each must know (1) the other's address and (2) the other's XML payload. Often, all XML payloads are not supported, making the interoperability of web services with unsupported XML payloads impossible.
Attempts have been made to facilitate the interoperability of web services, regardless of their individual protocols. For example, Web Services Coordination (WS-Coordination) provides an extensible framework of coordination protocols that enables disparate web services to cooperate in the performance of a multi-part function or task. However, WS-Coordination and similar approaches do not coordinate or standardize the various protocols of web services. Rather, they provide additional protocols that permit web services to cooperate. As a result, it is necessary to know of and provide for each web service protocol that may be encountered. If a particular protocol is not provided for in the coordination protocol, a web service utilizing that protocol may not be integrated into the group of web services available to a user.
For example, WS-Coordination utilizes protocol models, such as Simple Object Access Protocol (SOAP) and Web Services Description Language (WSDL). Web services that are SOAP- and/or WSDL-enabled may be coordinated using WS-Coordination. A web service that is not SOAP- and/or WSDL-enabled cannot be combined with SOAP- and/or WSDL-enabled web services and cannot be coordinated using WS-Coordination.
To this extent, a need exists for a method of orchestrating web services that does not suffer from the deficiencies above.
The invention provides a method, system, and program product for orchestrating web services. In one embodiment, the method includes accessing a plurality of web services, each web service including an orchestration engine; and employing a program including an instruction for work executed by at least one of the plurality of web services.
A first aspect of the invention provides a method of orchestrating web services, the method comprising: accessing a plurality of web services, each web service including an orchestration engine; and employing a program including an instruction for work executed by at least one of the plurality of web services.
A second aspect of the invention provides a system for orchestrating web services, the system comprising: a system for accessing a plurality of web services, each web service including an orchestration engine; and a system for employing a program including an instruction for work executed by at least one of the plurality of web services.
A third aspect of the invention provides a program product stored on a computer-readable medium, which when executed, orchestrates web services, the program product comprising: program code for accessing a plurality of web services, each web service including an orchestration engine; and program code for employing a program including an instruction for work executed by at least one of the plurality of web services.
A fourth aspect of the present invention is directed to a method for orchestrating web services, the method comprising: providing a computer infrastructure being operable to: access a plurality of web services, each web service including an orchestration engine; and employ a program including an instruction for work executed by at least one of the plurality of web services.
A fifth aspect of the present invention is directed to computer software embodied in a propagated signal for orchestrating web services, the computer software comprising instructions to cause a computer system to perform the following functions: access a plurality of web services, each web service including an orchestration engine; and employ a program including an instruction for work executed by at least one of the plurality of web services.
The illustrative aspects of the present invention are designed to solve the problems herein described and other problems not discussed, which are discoverable by a skilled artisan.
These and other features of this invention will be more readily understood from the following detailed description of the various aspects of the invention taken in conjunction with the accompanying drawings that depict various embodiments of the invention, in which:
It is noted that the drawings of the invention are not to scale. The drawings are intended to depict only typical aspects of the invention, and therefore should not be considered as limiting the scope of the invention. In the drawings, like numbering represents like elements between the drawings.
As indicated above, the invention provides a method, system, and program product for orchestrating web services.
Turning to the drawings,
Computing device 14 is shown including a processing unit 20, a memory 22, an input/output (I/O) interfaces 26, and a bus 24. Further, computing device 14 is shown in communication with an external I/O devices 28 and a storage system 30. As is known in the art, in general, processing unit 20 executes computer program code, such as orchestrating system 40, that is stored in memory 22 and/or storage system 30. While executing computer program code, processing unit 20 can read and/or write data, such as orchestrating system 40, to/from memory 22, storage system 30, and/or I/O interface 26. Bus 24 provides a communication link between each of the components in computing device 14. I/O device 28 can comprise any device that enables a user to interact with computing device 14 or any device that enables computing device 14 to communicate with one or more other computing devices.
In any event, computing device 14 can comprise any general purpose computing article of manufacture capable of executing computer program code installed by a user (not shown) (e.g., a personal computer, server, handheld device, etc.). However, it is understood that computing device 14 and orchestrating system 40 are only representative of various possible computing devices that may perform the various process steps of the invention. To this extent, in other embodiments, computing device 14 can comprise any specific purpose computing article of manufacture comprising hardware and/or computer program code for performing specific functions, any computing article of manufacture that comprises a combination of specific purpose and general purpose hardware/software, or the like. In each case, the program code and hardware can be created using standard programming and engineering techniques, respectively.
Similarly, computer infrastructure 12 is only illustrative of various types of computer infrastructures for implementing the invention. For example, in one embodiment, computer infrastructure 12 comprises two or more computing devices (e.g., a server cluster) that communicate over any type of wired and/or wireless communications link, such as a network, a shared memory, or the like, to perform the various process steps of the invention. When the communications link comprises a network, the network can comprise any combination of one or more types of networks (e.g., the Internet, a wide area network, a local area network, a virtual private network, etc.). Regardless, communications between the computing devices may utilize any combination of various types of transmission techniques.
As previously mentioned and discussed further below, orchestrating system 40 enables computing device 14 to orchestrate web services. To this extent, orchestrating system 40 is shown including an optional instruction generator 42, an instruction deployer 44, an optional instruction receiver 46, and other system components 48. Optional instruction generator 42 generates instructions for work to be executed by one or more of a plurality of web services 52. Instruction deployer 44 deploys instructions for work to the plurality of web services 52, whether the instructions for work are generated by optional instruction generator 42 or otherwise. Optional instruction receiver 46 receives updated instructions for work from one or more of the plurality of web services 52. Other system components 48 may include any component providing functionality to orchestrating system 40 including, for example, transmission systems, communication systems, etc. However, it is understood that some of the various systems shown in
Regardless, the invention provides a method, system, and program product for orchestrating web services. To this extent,
Still referring to
Upon receipt of program 60, WS1 72 executes task1 62 and passes 90 program 60 to WS2 74. WS2 74 then executes task2 64 and passes 92 program 60 to WS5 76. Finally, WS5 76 executes task5 66 and passes 94 program 60 to WS4 78, which executes task4 68. Program 60 may include a predefined order in which its tasks are to be executed. Alternatively, program 60 may include no such predefined order, with the order in which the tasks are executed being determined by the availability of particular web services. In the case that program 60 contains no such predefined order of task execution, program 60 may be passed between web services in any number of orders, based, in part, on the availability of individual web services. For example, still referring to
In some cases, program 60 may include a predefined order of task execution. For example, the execution of some tasks may be dependent upon the earlier execution of other tasks. For example, still referring to
Referring now to
For example, still referring to
While shown and described herein as a method, system, and program product for orchestrating web services, it is understood that the invention further provides various alternative embodiments. For example, in one embodiment, the invention provides a computer-readable medium that includes computer program code to enable a computer infrastructure to orchestrate web services. To this extent, the computer-readable medium includes program code, such as orchestrating system 40 (
In another embodiment, the invention provides a business method that performs the process steps of the invention on a subscription, advertising, and/or fee basis. That is, a service provider, such as an Internet Service Provider, could offer to orchestrate web services as described above. In this case, the service provider can create, maintain, support, etc., a computer infrastructure, such as computer infrastructure 12 (
In still another embodiment, the invention provides a method of generating a system for orchestrating web services. In this case, a computer infrastructure, such as computer infrastructure 12 (
As used herein, it is understood that the terms “program code” and “computer program code” are synonymous and mean any expression, in any language, code or notation, of a set of instructions intended to cause a computing device having an information processing capability to perform a particular function either directly or after either or both of the following: (a) conversion to another language, code or notation; and (b) reproduction in a different material form. To this extent, program code can be embodied as one or more types of program products, such as an application/software program, component software/a library of functions, an operating system, a basic I/O system/driver for a particular computing and/or I/O device, and the like.
The foregoing description of various aspects of the invention has been presented for purposes of illustration and description. It is not intended to be exhaustive or to limit the invention to the precise form disclosed, and obviously, many modifications and variations are possible. Such modifications and variations that may be apparent to a person skilled in the art are intended to be included within the scope of the invention as defined by the accompanying claims.