This application claims priority under 35 U.S.C. § 119 to European Application No. 04030451.1, filed Dec. 22, 2004, and titled, “A METHOD AND A SYSTEM FOR INTEGRATING SEMANTIC WEB SERVICES INTO AN EXISTING WEB SERVICE INFRASTRUCTURE,” which is incorporated by reference herein.
The present description relates generally to the field of semantic web services, and more particularly to a system and a method for integrating semantic web services into at least one existing web service infrastructure.
An example goal of a specific architectural style, called service oriented architecture (SOA) is to achieve loose coupling among interacting software agents and to ease the reuse of existing application functionality exposed as (web) services in order to create new functionality or new applications. In addition, services may also be used in integrating applications across company boundaries. Although the ideas behind the service oriented architecture have been around for several years and different technologies can be used for implementing services, service oriented architecture has gained a lot momentum due to an emergence of XML (Extensible Mark-Up Language) and web services.
A web service is an interface that describes a collection of operations that are network-accessible through standardized XML messaging. A web service is described using a standard, formal XML notion, called its service description. It covers all the details necessary to interact with the service, including message formats, transport protocols and location. The interface hides the implementation details of the service, allowing it to be used independently of the hardware or software platform on which it is implemented and also independently of the programming language in which it is written. Web services fulfill a specific task or a set of tasks. They can be used alone or with other web services to carry out a complex aggregation or a business transaction.
Generally, web services may allow companies to reduce the cost of doing e-business, to deploy solutions faster and to open up new opportunities. Web services are based on a common program-to-program communications model, built on existing and emerging standards such as HTTP, XML, SOAP (Simple Object Access Protocol), WSDL (Web Service Description Language) and UDDI (Universal Description, Discovery and Integration). Web services allow applications to be integrated more rapidly, easily and less expensively than before.
Although early use of web services is peer-wise, it still addresses the problem of program-to-program communications including describing, publishing and finding interfaces. And, as the use of web services grows and the industry matures, more dynamic models of application integration will develop. Eventually systems integration through web services will happen dynamically at runtime. Just-in-time integration will herald a new era of business-to-business integration over the Internet.
Although the service oriented architecture, as already mentioned, provides one approach, it currently does not solve all integration problems. Data format mismatches, process mismatches and automatic service compositions are examples of such integration problems.
Currently, a lot of effort is put into research projects in the area of so-called semantic web and semantic web services. The semantic web is an extension of the current web in which information is given well-defined meaning, better enabling computers and people to work in cooperation. This meaning is provided by augmenting resources in the web with meta-data based on several standards like RDF (Resource Description Framework). The infrastructure of the semantic web would allow machines as well as humans to make deductions and organize information. Architectural components of the semantic web include semantics, that means meaning of elements, structure, which means organization of the elements, and syntax, which corresponds to communication.
Vendors of enterprise application platforms may support a usage and development of web services in their applications. In addition to enabling developers to develop and deploy services, these suites may contain workflow engines, enabling a creation of complex business processes from simple building blocks like simple web services. In the meantime many different languages for a description of complex business process on the basis of simple web services have been developed, as for example WSCI (Web Service Choreography Interface), XLANG, and, one of the most popular, BPEL4WS (Business Process Execution Language for Web Services). Those languages clearly define a data flow as XML documents, a control flow (block structured or transition based), a message flow (web services) and a transaction flow.
According to a general aspect(s), a method and a system for integrating semantic web services into existing web service infrastructures are provided.
Accordingly, a method is provided for integrating semantic web services into at least one existing web service infrastructure with an execution environment by placing a proxy component between the execution environment of the existing web service infrastructure and the semantic web services, so that the execution environment invoking the proxy component may utilize, or interact with, semantic web services for achieving a predefined goal. The proxy component may select services among the semantic web services based on the predefined goal, compose an executable service from the selected services, execute the executable service, and return the result of the service execution to the execution environment.
The invoking of the proxy component corresponds to a demand of a specific predefined goal. For each specific goal a user wants to achieve, a goal specific proxy component may be invoked which is specialized in achieving that specific predefined goal.
The composing of an executable service can be done, for example, in a form of a script. Such a script specifies a sequence of operations to be performed in order to achieve the predefined goal.
A proxy is an intermediary program that acts as both a server and a client for the purpose of making requests on behalf of other clients. Proxies are often used as helper applications for handling requests via protocols not implemented by a user agent. Therefore, a proxy functions as an intermediate link between a client application and a real server. It therefore may accept requests from clients, and transmit those requests on to the semantic web services environment.
Based on the description provided herein, a gradual transition from current already existing web service environments to semantic web service environments is possible. It is possible that a designer of a complex service wants to define some services exactly during design-time and leave others open for discovery during runtime. In the following this scenario is called a mixed usage scenario. Using the semantic web service environment described herein, mixed usage scenarios may be implemented, e.g., by placing a proxy between the execution environment and the semantic web services. During runtime an execution environment of the existing web service infrastructure, for example a BPEL (Business Process Execution Language) engine, calls the proxy component instead of a real service. The proxy component may then take care of discovering, selecting and invoking an appropriate semantic web service. These processes may be completely transparent to the execution environment. For the execution environment, all this functionality may be hidden behind a simple web service call. The proxy component, in some implementations, is not a generic execution environment but an object capable of discovering, selecting and invoking one specific kind of semantic web services. The proxy component may, for example, either be manually developed, or customizable service templates could be provided to a designer.
The proxy component may generally controlled by a controller when selecting, composing and executing a semantic web service. This controller is part of the proxy component. That means the controller is integrated within the proxy component.
Furthermore, it is possible that the predefined goal which can be achieved by invoking the proxy component is first divided into several sub-goals. This can be the case, for example, if the predefined goal of the proxy component can only be achieved by a composition of several web services, each achieving a specific sub-goal.
In an additional or alternative example embodiment, selecting services among the semantic web services is done by invoking a discovery unit which is external to the proxy component and listing the selected services into a list. The discovery unit may be part of the semantic web service environment. It can be a semantic web service itself.
Referring, for example, to “book travel” as a predefined goal to be achieved, a specific proxy component is called by an execution environment of an existing web service infrastructure, as for example by a travel portal. The proxy component first searches for a semantic web service based on the predefined goal by invoking a discovery unit which is part of a semantic web service environment. The discovery unit returns services that can achieve the corresponding sub-goals, in this example services capable of “booking flights”, services capable of “booking hotels” and services capable of “booking rental cars”. It is possible that further services offering further information about travel booking are discovered and returned to the proxy component. Furthermore, it is possible that two or more of those services are already semantically combined and merely some services are still left open for discovery. The services can then be registered within a list. Afterwards, the proxy component composes an executable service based on the specific predefined goal with the selected services stored within the list. The executable service, in this example, is then executed by invoking first a mediation unit of the semantic web service environment before invoking a real web service as a part of the composed service. The execution results are then returned to the travel portal which has called the proxy component first.
It has to be noted that the execution environment calls the proxy component instead of a real web service. The processes performed by the proxy component, namely discovering, selecting and invoking an appropriate semantic web service, are completely transparent to the execution environment. Thus, for the execution environment all this functionality may be hidden behind a simple web service call.
It is possible that composing the executable service comprises invoking a mediation unit to enable interoperability of the selected services. That means that during composing of an executable script, for example, invocations to a mediation unit may be inserted. After discovery, for each sub-goal a list of appropriate semantic web services stored within a selection unit of the proxy component may be available for achieving that sub-goal. Among those services, one is selected for each sub-goal. Then, a composition unit of the proxy component may compare the different services to be composed. The in- and output formats of the services are checked. It is possible that the different services match among each other. At best the in- and output formats are identical. In that case the services can be written one after the other within an appropriate script, so that they can easily be performed successively when executing that executable script.
In a second case, the in- and output formats of the different services do not match among each other. In that case, the composition unit may add a call to an external mediation unit within the corresponding script of the executable service, namely between the services.
In still another possible example embodiment, selecting services among the semantic web services may comprise a calculation of conformance of the selectable services with predefined selection criteria. Those selection criteria may also include user preferences.
Further, a proxy component for integrating semantic web services into at least one existing web service infrastructure may be provided. The proxy component may comprise a selection unit for selecting services among the semantic web services based on a predefined goal, a composition unit for composing an executable service from the selected services and an execution unit for executing the executable service.
The proxy component is locatable between a semantic web service environment and an existing web service infrastructure and accessible by an execution environment of the existing web service infrastructure.
It is possible that the proxy component comprises a controller for controlling the selection unit, the composition unit and/or the execution unit.
Furthermore, it is possible, that the proxy component has access to an external discovery unit and an external mediation unit. The external discovery unit and the external mediation unit are part of a semantic web service environment. Both can also be semantic web services themselves.
Furthermore, there may be a pool of semantic web services to which the proxy component has access. The proxy component may be specific for a certain kind of semantic web service(s). An execution environment calling the proxy component may thereby achieve a predefined specific goal. For each goal, a specific proxy component may be called in order to find or to create a semantic web service to achieve this predefined goal.
Furthermore, it is possible that a selection unit of the proxy component comprises a calculation unit for calculating conformance of selectable services with predefined selection criteria. Those selected criteria can also correspond to certain specific user preferences.
According to another general aspect, a system comprises semantic web services, an existing web service infrastructure and a proxy component such as described above. Within such a system, the proxy component may be placed between the semantic web services and an execution environment of the existing web service infrastructure, as described.
According to another general aspect, a computer program product with a computer-readable medium and a computer program stored on the computer-readable medium with a program code, that, when executed, causes the computer program to select semantic web services among a pool of semantic web services based on a predefined goal, compose an executable service from the selected services, execute the executable service, and return the result of the execution to an invoking execution environment.
According to another general aspect, a computer program includes a program code which is suitable for carrying out a method comprising at least selecting semantic web services among a pool of semantic web services based on a predefined goal, composing an executable service from the selected services, executing the executable service, and returning the result of the execution to an invoking execution environment.
According to another general aspect, an appropriate computer-readable medium has a computer program stored thereon, the computer program comprising a program code which is suitable for carrying out a method comprising at least selecting semantic web services among a pool of semantic web services based on a predefined goal, composing an executable service from the selected services, executing the executable service, and returning the result of the execution to an invoking execution environment.
For purposes of clarity, the present description refers to an abstract example of a web service environment. However, described examples of methods and systems may operate with a wide variety of types of network systems, including, for example, networks and communication systems dramatically different from the specific example described herein and/or illustrated in the following drawings.
Further, it should be understood that while the present description is provided in terms of a specific system, applications exist in a variety of communication systems, such as, for example, advanced cable-television systems, advanced telephone networks or any other communication system that would benefit from the described systems or methods. Thus, for example, it is intended that the system as used in the specification and claims be understood to include any communication system unless the context requires otherwise.
The details of one or more implementations are set forth in the accompanying drawings and the description below. Other features will be apparent from the description and drawings, and from the claims.
As semantic web services can be seen as one of the next evolutionary steps of current web service technology, at least two scenarios for an adoption of semantic web services in future business applications are possible. Either current web service environments may be augmented with semantic web services technology, or current web service environments are replaced by semantic web service enabled environments.
As companies have invested a lot of money in IT infrastructures it is much more likely that a transition will take place where first existing environments are augmented with semantic web services technology and thereby, after some time, the semantic web service enabled environment will be achieved. In order to allow such a transition, the semantic web services environment need to be defined flexible enough to support an augmentation of current environments as well as their future replacement.
As main building blocks for semantic web services ontologies, goals, mediators and web service descriptions are specified. Ontologies provide a common terminology used by other components, while web service descriptions specify capabilities and interfaces of the services, and mediators are used to overcome interoperability problems. Goals are used to express a client's desire. Goals may be achieved, for example, by decomposing them into sub-goals and then discovering web services capable of achieving the sub-goals. Such a goal decomposition might be a recursive process.
On an abstract level, a semantic web service environment may use (a) a discovery component to discover web services, (b) a mediation component to cope with heterogeneity on both the data and the process level, (c) a composition component to compose new semantic web services from either existing services or by specifying goals and the necessary composition, and (d) an execution unit for executing the semantic web services after they have been deployed. The mediation component may execute mappings between different data formats and processes that are created during composition. Components of an abstract semantic web service environment may need access to a semantic backbone that is offering access to ontologies and reasoning. Accordingly, a central, high-speed network for transporting such information between the different components may be provided.
Such a goal may be, for example, “book travel”. For example, in order to create a travel booking service, the selection unit 21 of the proxy component 20 may first discover services based on that predefined goal by invoking the discovery unit 31. The overall goal “book travel” may need to be decomposed into specific adequate sub-goals. In case of “book travel”, for example, these sub-goals might be “book flight”, “book hotel” and “book rental car”. For each of said sub-goals the discovery unit 31 returns a set of discovered adequate services adapted to the particular sub-goals of the predefined goal. The selection unit 21 now selects services from the returned set of discovered services and invokes, in a next step, the composition unit 22 with the selected services. In one implementation, the selected services may be deposited by the selection unit 21 into a list.
Furthermore, the selection unit 21 may calculate conformance of the selected services with selection criteria or user preferences. The composition unit 22 may thus compose an executable service from the selected services. A script may be written according to which the executable service may be performed. In some implementations, the composition unit 22 may install mediation calls in order to guarantee interoperability of the selected services. After having composed an executable service, e.g., in form of a script, the composition unit 22 invokes the execution unit 23 for executing the composed service. The execution unit 23 may invoke, for executing the composed service, the mediation unit 32 for an associated mediation. The mediation unit 32 may thus be used to cope with heterogeneity on both data and/or process level. The mediation unit 32 may, for example, execute mappings between different data formats and processes that are created during design time. It is possible that the different semantic web services to be executed successively use, or are written in, different formats which are not compatible. The “booking flight”—service can use for example a date format as “day.month.year” while the “booking hotel”—service provides the date as “monthdayyear”. In such a case the mediation unit 32 may be used to match and consort the different formats. After mediation the execution unit 23 may invoke a corresponding real semantic web service from the pool 33 of semantic web services. In case that this semantic web service does not already cover exactly the whole service for achieving the predefined goal, the execution unit 23 may invoke a further real semantic web service from the pool 33 of semantic web services according to the script of the composed executable service in order to complete the composed service for achieving the predefined goal. Then the execution unit 23 may return the execution result to the execution environment 10, which has called the proxy component 20 for achieving the predefined goal.
Referring to
Based on the predefined goal a selection unit of the proxy component identifies in step 4 those services which achieve specific sub-goals as for example “only vegetarian recipes” or “buy only in groceries situated near a given home”. The selection unit either uses semantic information already given by the discovery unit (e.g. vegetarian recipes, specific stores) or searches for an adequate recipe/store combination within the lists of services returned by the discovery unit. From that procedure, a list of services that have to be invoked according to a specific sequence, results. That list is forwarded in step 5 to a composition unit.
The composition unit generates in step 6 an executable service, e.g. in form of a script. The composition unit may identify the need for invoking a mediation unit because of incompatibilities between the selected services in the list. It therefore adds calls to an external mediation component into the executable script. Note that there might be a number of mediation services available, resulting in discovery and selection steps for the mediation component as described before.
Finally, an execution unit is invoked in step 7 which executes the executable service by invoking each service in the script. Therefore, in step 8 the mediation unit is invoked if necessary which returns in step 9 the corresponding mediation results. In step 10 the listed external services are invoked. The result, as for example a recipe together with an appropriate grocery, is returned in step 11 to the proxy component. When all steps within the script have been executed, the proxy component returns the result finally in step 12 to the execution environment.
In the following, a pseudo-code explains a further embodiment of an example method. It describes functionality of a controller, which is located inside the proxy component in order to control the execution of the selection, composition and execution of the proxy component.
The selection could be implemented as follows:
The composition could be implemented as follows:
While certain features of the described implementations have been illustrated as described herein, many modifications, substitutions, changes and equivalents will now occur to those skilled in the art. It is, therefore, to be understood that the appended claims are intended to cover all such modifications and changes as fall within the true spirit of the embodiments of the invention.
Number | Date | Country | Kind |
---|---|---|---|
04030451.1 | Dec 2004 | EP | regional |