The present invention is in the field of systems, methods, and computer program products for creating and using service dependency graphs to automate the development and deployment of service oriented applications.
The increasing adoption of service oriented architectures is accelerating the development, deployment, and usage of service oriented business applications. Enterprises are creating and maintaining environments for hosting different types of services including those that are bound and discovered over the Internet (e.g., web services), and those that are discovered and bound inside a Java Virtual Machine (JVM), e.g., Open Services Gateway Initiative (OSGI) services.
A JVM is a set of computer software programs and data structures which use a virtual machine model for the execution of other computer programs and scripts. The model used by a JVM accepts a form of computer intermediate language commonly referred to as Java bytecode. This language conceptually represents the instruction set of a stack-oriented, capability architecture.
An embodiment of the invention provides a method for identifying and combining services. More specifically, the method identifies services in a domain by querying registries for services provided over the Internet and/or services inside of a Java virtual machine. The services inside of the Java virtual machine include services deployed in an OSGI platform. Domain concepts are identified within the domain, wherein the domain concepts are input and output of the services. A network of services is created, which includes metadata of the services and relationship data of the services. The relationship data of the services includes relationships of the services to one another and relationships of the services to the domain concepts. A domain ontology is also created, which includes the domain concepts and relationship data of the domain concepts. The relationship data of the domain concepts includes relationships of the domain concepts to one another and relationships of the domain concepts to the services.
The method receives a request from a user for a service that satisfies constraints based on the domain concepts. At least two services within the network are selected that satisfy the constraints to create selected services, wherein the services are selected based on the relationship data of the domain concepts in the domain ontology. In one embodiment, the constraints can only be satisfied by two or more of the services. In at least one embodiment, a first service and at least one second service are selected from the network. An output of the first service is obtained; and, all or part of the output is input into the second service. Moreover, an output of at least one third service is obtained; and, all or part of that output is input into the first service. In an alternative embodiment, the output of the first service is transformed to create a transformed domain concept; and, the transformed domain concept is input into the second service. The selected services are combined to create a combined service; and, the user is notified of the combined service.
A system according to an embodiment of the invention includes a domain having domain concepts, wherein the domain concepts are input into services and output from the services. A network of services is provided, wherein the network includes metadata of the services and relationship data of the services. The relationship data includes relationships of the services to one another and relationships of the services to the domain concepts. A domain ontology is also provided having the domain concepts and relationship data of the domain concepts. The relationship data includes relationships of the domain concepts to one another and relationships of the domain concepts to the services.
The system further includes a user interface for receiving a request from a user for a service that satisfies constraints based on the domain concepts. A processor combines at least two services within the network that satisfy the constraints. In one embodiment, the constraints can only be satisfied by two or more of the services. The processor combines the services based on the relationship data of the domain concepts in the domain ontology. In at least one embodiment, the services include a first service and at least one second service from the network. The first service includes an output, wherein all or a part of the output is input into the second service. Moreover, at least one third service from the network has an output that is input into the first service. In an alternative embodiment, the system has a second processor for transforming the output of the first service into a transformed domain concept, wherein the transformed domain concept is input into the second service.
The present invention is described with reference to the accompanying drawings. In the drawings, like reference numbers indicate identical or functionally similar elements.
Exemplary, non-limiting, embodiments of the present invention are discussed in detail below. While specific configurations are discussed to provide a clear understanding, it should be understood that the disclosed configurations are provided for illustration purposes only. A person of ordinary skill in the art will recognize that other configurations may be used without departing from the spirit and scope of the invention.
With the proliferation of services, and with the rapid introduction of new services, an embodiment of the invention provides tools and methods to discover and combine services to maximize the benefits of the vast collection of services that are increasingly made available. Thus, users are given tools and methods that allow them to easily and dynamically (at run-time) discover new services, and to combine the outputs of existing services to achieve their requirements. These tools can greatly reduce the cost of developing service oriented business applications because they help maximize reuse through the implementation of flexible and dynamically configurable systems.
When planning, architecting, and designing an information technology (IT) solution to meet certain requirements, an IT architect is provided with all available services in the environment (the enterprise), and how these services relate to each other and to the domain ontology. An ontology describes the logical structure of a domain, its concepts and the relations between them. Moreover, ontology refers to computer-based resources that represent agreed domain semantics. An ontology consists of relatively generic knowledge that can be reused by different kinds of applications or tasks.
An embodiment of the invention discovers services to create and maintain an explicit Service Dependency Network (also referred to herein as “SDN” or the “network”). The SDN is used not only to provide the architect or solution designer with a relational view of all of the services in the environment, but in addition, the SDN is used by the system (also referred to herein as the “tool”) of an embodiment of the invention to dynamically combine services to satisfy the requirements (requests and constraints) of the user. The specific result a user may desire often could not be provided by a single service. However, the desired result could be arrived at by a combination of services, each providing a piece of the puzzle. A tool is provided that allows a user (human or machine) to easily create a situational application that satisfies his/her requirements. This tool allows the user to specify his/her request via a high-level constraint (rule). The elements (parameters or variables) of the user's (or client) constraint are concepts included in a domain ontology. Based on the user's constraint, the tool is then able to create and deploy a new service that satisfies the user's constraint. The new service is typically a combination (choreograph) of existing services discovered via the SDN created by the tool.
At least one embodiment of the invention provides systems and methods to automate the development and deployment of service-oriented applications by creating and using a service dependency model. The system discovers all types of services deployed in the enterprise, which includes but not limited to: services that are bound and discovered over the Internet (web services) and services that are bound and discovered inside a JVM, e.g., services deployed in the OSGI platform.
The SDN and model are created, which include service metadata and the relationship to the domain ontology. The system accepts requests from users which include constraints on the ontological concepts in the domain, and a request to find a service or create a new service to satisfy the constraints. The SDN and domain ontology are used to fulfill the user's request.
The actual price 320 a customer pays for a certain product depends on the type of discount rate 310 the customer has as established in the contract maintained between the customer and the enterprise. So, a service 300 is created to calculate the actual price 320 based on the discount rate 310 and part number 220 as illustrated in
As illustrated in
As certain states and countries began enforcing regulations to charge recycling fees on computer products (e.g., screens, monitors, and other computer components), the prices of certain products have to be increased by the amount of the recycle fee paid on that product for the state or country it was sold in. For example, as illustrated in
The business process and business applications modify the services and replace it with the new service 500 that calculates the new product price 321 (base product price 320 plus the product recycle fee 520). The development of the service 500 and the replacement of the previous service with the new service 500 (by every client application that uses the service 500) is a costly and time consuming process. These development tasks are completed automatically by the system and methods herein for identifying and combining services. Therefore, the development costs are avoided or reduced.
Using the systems provided herein, a client can view the SDN created, and is able to select the product price domain concept, right click on it, and then declaratively specify a constraint (rule). For example, the user can specify the constraint: Price=Price+Recycle Fee. Using the tool, the user can additionally specify that he wants to create and deploy a service to satisfy the above constraint. The tool examines the specified constraint (Price=Price+Recycle Fee), and using the SDN created and maintained by the tool, the tool determines the Price and Recycle Fee for each of the concepts. Thus, the tool avoids or reduces the costs of developing or purchasing a new service.
For example, in regards to price, the service 300 provides the product price 320 if the product part number 220 and the discount rate 310 are available. A service 550 can provide the discount rate 310 given a customer ID 560. In at least one example, checking the SDN, no service is found that provides the customer ID 560, so the tool checks the ontological representation of the SDN (i.e., the domain ontology).
As illustrated in
In the same example, the service 530 provides the product recycle fee 520 given the part number 220. The tool uses the domain ontology as represented in
The original service is now replaced with the new service 500. The inputs and outputs of the service 500 are the same as those of the previous service. The only change is the addition of a process flow at the output of the service 300 that implements the new user constraint. The tool generated the SDN, related the SDN to the domain ontology, and used the SDN to satisfy the new user requirement (constraint).
A network of services (also referred to herein as the “Service Dependency Network” or “SDN”) is created, which includes metadata of the services and relationship data of the services (930). The relationship data of the services includes relationships of the services to one another and relationships of the services to the domain concepts. As described above, services are discovered to create and maintain an explicit SDN. The SDN provides the architect or solution designer with a relational view of all of the services in the environment.
A domain ontology is also created, which includes the domain concepts and relationship data of the domain concepts (940). The relationship data of the domain concepts includes relationships of the domain concepts to one another and relationships of the domain concepts to the services. An ontology describes the logical structure of a domain, its concepts and the relations between them. Moreover, ontology refers to computer-based resources that represent agreed domain semantics. An ontology consists of relatively generic knowledge that can be reused by different kinds of applications or tasks.
The method receives a request from a user for a service that satisfies constraints based on the domain concepts (950). At least two services within the network are selected that satisfy the constraints to create selected services (960), wherein the services are selected based on the relationship data of the domain concepts in the domain ontology. In one embodiment, the constraints can only be satisfied by two or more of the services. A tool is provided that allows a user (human or machine) to easily create a situational application that satisfies his/her requirements. This tool allows the user to specify his/her request via a high-level constraint (rule). The elements (parameters or variables) of the user's (or client) constraint are concepts included in the domain ontology. Based on the user's constraint, the tool is then able to create and deploy a new service that satisfies the user's constraint.
In at least one embodiment of the invention, a first service and at least one additional service (also referred to herein as the “second service”) are selected from the network. An output of the first service is obtained; and, at least a portion of the output is input into the additional service. For example, as illustrated in
The selected services are combined to create a combined service (970); and, the user is notified of the combined service (980). The SDN is used by the system to dynamically combine services to satisfy the requirements (requests and constraints) of the user. The specific result a user may desire often could not be provided by a single service. However, the desired result could be arrived at by a combination of services, each providing a piece of the puzzle.
A network of services 1120 is provided, wherein the network includes metadata 1124 of the services 1122 and relationship data 1126 of the services 1122. The relationship data 1126 includes relationships of the services 1122 to one another and relationships of the services 1122 to the domain concepts 1112. As described above, services are discovered to create and maintain an explicit SDN. The SDN provides the architect or solution designer with a relational view of all of the services in the environment.
A domain ontology 1130 is also provided having the domain concepts 1112 and relationship data 1132 of the domain concepts 1112. The relationship data 1132 includes relationships of the domain concepts 1112 to one another and relationships of the domain concepts 1112 to the services 1122. An ontology describes the logical structure of a domain, its concepts and the relations between them. Moreover, ontology refers to computer-based resources that represent agreed domain semantics. An ontology consists of relatively generic knowledge that can be reused by different kinds of applications or tasks.
The system further includes a user interface 1140 for receiving a request from a user for a service that satisfies constraints based on the domain concepts 1112. A processor 1150 combines at least two services 1122 within the network 1122 that satisfy the constraints. In one embodiment, the constraints can only be satisfied by two or more of the services 1122. A tool is provided that allows a user (human or machine) to easily create a situational application that satisfies his/her requirements. This tool allows the user to specify his/her request via a high-level constraint (rule). The elements (parameters or variables) of the user's (or client) constraint are concepts included in the domain ontology. Based on the user's constraint, the tool is then able to create and deploy a new service that satisfies the user's constraint.
The processor 1150 combines the services 1122 based on the relationship data 1132 of the domain concepts 1112 in the domain ontology 1130. The SDN is used by the system to dynamically combine services to satisfy the requirements (requests and constraints) of the user. The specific result a user may desire often could not be provided by a single service. However, the desired result could be arrived at by a combination of services, each providing a piece of the puzzle.
In at least one embodiment, the services 1122 include a first service and at least one additional service (also referred to herein as the “second service”) from the network. The first service includes an output, wherein at least a portion of the output is input into the additional service. Moreover, at least one sub-service (also referred to herein as the “third service”) from the network has an output that is input into the first service. In an alternative embodiment, the system has a second processor for transforming the output of the first service into a transformed domain concept, wherein the transformed domain concept is input into the additional service.
At least one embodiment of the invention can take the form of an entirely hardware embodiment, an entirely software embodiment or an embodiment including both hardware and software elements. In a preferred embodiment, the invention is implemented in software, which includes but is not limited to firmware, resident software, microcode, etc.
Furthermore, at least one embodiment of the invention can take the form of a computer program product accessible from a computer-usable or computer-readable medium providing program code for use by or in connection with a computer or any instruction execution system. For the purposes of this description, a computer-usable or computer readable medium can be any apparatus that can e, store, communicate, propagate, or transport the program for use by or in connection with the instruction execution system, apparatus, or device.
The medium can be an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system (or apparatus or device) or a propagation medium. Examples of a computer-readable medium include a semiconductor or solid state memory, magnetic tape, a removable computer diskette, a random access memory (RAM), a read-only memory (ROM), a rigid magnetic disk and an optical disk. Current examples of optical disks include compact disk-read only memory (CD-ROM), compact disk-read/write (CD-R/W) and DVD.
A data processing system suitable for storing and/or executing program code will include at least one processor coupled directly or indirectly to memory elements through a system bus. The memory elements can include local memory employed during actual execution of the program code, bulk storage, and cache memories which provide temporary storage of at least some program code in order to reduce the number of times code must be retrieved from bulk storage during execution.
Input/output (I/O) devices (including but not limited to keyboards, displays, pointing devices, etc.) can be coupled to the system either directly or through intervening I/O controllers. Network adapters may also be coupled to the system to enable the data processing system to become coupled to other data processing systems or remote printers or storage devices through intervening private or public networks. Modems, cable modem and Ethernet cards are just a few of the currently available types of network adapters.
A representative hardware environment for practicing at least one embodiment of the invention is depicted in
While it is understood that process software may be deployed by manually loading directly in the client, server and proxy computers via loading a storage medium such as a CD, DVD, etc., the process software may also be automatically or semi-automatically deployed into a computer system by sending the process software to a central server or a group of central servers. The process software is then downloaded into the client computers that will execute the process software. Alternatively the process software is sent directly to the client system via e-mail. The process software is then either detached to a directory or loaded into a directory by a button on the e-mail that executes a program that detaches the process software into a directory. Another alternative is to send the process software directly to a director on the client computer hard drive. When there are proxy servers, the process will, select the proxy server code, determine on which computers to place the proxy servers' code, transmit the proxy server code, then install the proxy server code on the proxy computer. The process software will be transmitted to the proxy server then stored on the proxy server.
Next, a determination is made on whether the process software is be deployed by having users access the process software on a server or servers 102. If the users are to access the process software on servers then the server addresses that will store the process software are identified 103.
A determination is made if a proxy server is to be built 200 to store the process software. A proxy server is a server that sits between a client application, such as a Web browser, and a real server. It intercepts all requests to the real server to see if it can fulfill the requests itself. If not, it forwards the request to the real server. The two primary benefits of a proxy server are to improve performance and to filter requests. If a proxy server is required then the proxy server is installed 201. The process software is sent to the servers either via a protocol such as FTP or it is copied directly from the source files to the server files via file sharing 202. Another embodiment would be to send a transaction to the servers that contained the process software and have the server process the transaction, then receive and copy the process software to the server's file system. Once the process software is stored at the servers, the users via their client computers, then access the process software on the servers and copy to their client computers file systems 203. Another embodiment is to have the servers automatically copy the process software to each client and then run the installation program for the process software at each client computer. The user executes the program that installs the process software on his client computer 212 then exits the process 108.
In step 104 a determination is made whether the process software is to be deployed by sending the process software to users via e-mail. The set of users where the process software will be deployed are identified together with the addresses of the user client computers 105. The process software is sent via e-mail to each of the users' client computers. The users then receive the e-mail 205 and then detach the process software from the e-mail to a directory on their client computers 206. The user executes the program that installs the process software on his client computer 212 then exits the process 108.
Lastly a determination is made on whether to the process software will be sent directly to user directories on their client computers 106. If so, the user directories are identified 107. The process software is transferred directly to the user's client computer directory 207. This can be done in several ways such as but not limited to sharing of the file system directories and then copying from the sender's file system to the recipient user's file system or alternatively using a transfer protocol such as File Transfer Protocol (FTP). The users access the directories on their client file systems in preparation for installing the process software 208. The user executes the program that installs the process software on his client computer 212 then exits the process 108.
The terminology used herein is for the purpose of describing particular embodiments only and is not intended to be limiting of the invention. As used herein, the singular forms “a”, “an” and “the” are intended to include the plural forms as well, unless the context clearly indicates otherwise. It will be further understood that the root terms “include” and/or “have”, when used in this specification, specify the presence of stated features, integers, steps, operations, elements, and/or components, but do not preclude the presence or addition of one or more other features, integers, steps, operations, elements, components, and/or groups thereof.
The corresponding structures, materials, acts, and equivalents of all means plus function elements in the claims below are intended to include any structure, or material, for performing the function in combination with other claimed elements as specifically claimed. The description of the present invention has been presented for purposes of illustration and description, but is not intended to be exhaustive or limited to the invention in the form disclosed. Many modifications and variations will be apparent to those of ordinary skill in the art without departing from the scope and spirit of the invention. The embodiment was chosen and described in order to best explain the principles of the invention and the practical application, and to enable others of ordinary skill in the art to understand the invention for various embodiments with various modifications as are suited to the particular use contemplated.