The present invention relates generally to automatic composition of networks and, more particularly, to a method and system for composing registries and other information databases during network composition.
In the near future, consumers are expected to carry multiple devices that communicate with one another to form small, personal area networks (PANs) that move with the user. In a given area, there may be many users, each with his/her own PAN. The PANs of different users are likely to comprise different devices, use different technologies, and have different resources and capabilities. It would benefit users to make the resources and capabilities of one PAN available to other PANs. For example, one PAN may have Internet access that can be shared with other PANs.
Network interworking allows the sharing of resources between networks so that users in one network can have access to resources in another network. BLUETOOTH and IEEE 802.15 both allow interworking between PANs. However, such interworking typically requires manual configuration and off-line negotiation.
The concept of network composition is gaining acceptance as a viable technique for the seamless and automatic creation of ad-hoc networks without user intervention. Automatic network composition enables interworking between networks “on the fly” in a manner that is transparent to the user. For example, the Ambient Networks Project is currently developing standards for networks called Ambient Networks. An Ambient Network can be defined as one or more network nodes and/or devices that share a common network control plane called the Ambient Control Space (ACS). The ACS contains all of the network control and management functions, which are organized into functional areas (FAs). Each FA represents a different management task (e.g., QoS, mobility, composition, security, congestion control, etc.). The ACS includes two interfaces: the Ambient Network Interface (ANI) and the Ambient Service Interface (ASI). The ANI enables communication between different Ambient Networks, and the ASI allows access to the services offered by the Ambient Network. The ACS enables automatic composition of networks in a transparent fashion, without manual configuration and off-line negotiation, while taking into account user needs, preferences, locations, and devices.
Current work on Ambient networks addresses the problem of seamless interworking between networks, but fails to address the problem of how resources in the composed network should be consolidated. As an example, consider a scenario where two PANs, each PAN having its own registry for a specific type of information, compose. After composition the composed network includes two separate registries containing the same type of information. While the information in both registries is available to clients in the composed network, it is not be convenient for clients to interact with two databases to find desired information. Therefore, it would be beneficial to users if registries and other databases could be consolidated during network composition.
The present invention relates to a method and system for composing two or more individual registries in separate networks into a merged registry when the separate networks compose. Each of the networks being composed includes a registry composition entity (RCE). The RCEs in the separate networks communicate with one another to coordinate the composition of the individual registries existing in the separate networks prior to composition into a merged registry for the composed network. In one exemplary embodiment, the registry composition entity comprises a coordination module to enable communication with remote registry composition entities in other networks, a composability check module for verifying the composability of the individual registries and for negotiating a composition agreement with remote registry composition entities, and a composition manager to execute the composition agreement to create the merged registry.
The merged registry may comprise one or more constituent registries. The constituent registries in a merged registry may exist prior to composition of the registries, or may be created during the composition process. In one embodiment, a merged registry is created by logically linking constituent registries existing prior to composition to enable interworking between the constituent registries. In another embodiment, the merged registry is created by creating a new registry for shared resources of the pre-composition registries, and logically linking the new registries with the pre-existing registries. In another embodiment, the merged registry is created by transferring the contents of the pre-existing registries to a newly-created registry.
In one exemplary embodiment, an overlay network is created during the registry composition process to enable interworking between post-composition registries. The overlay network is created by assigning post-composition registries in the composed network to groups, creating a virtual registry for each group, and selecting a post-composition registry in each group to support the virtual registry for that group. The virtual registries are linked to enable interworking between the virtual registries. The post-composition registries are linked to corresponding virtual registries.
Network composition enables “on the fly” interworking between heterogeneous networks without manual configuration or prior offline negotiation. Network composition results in the creation of a new post composition network, referred to herein as the composed network, in which resources of the pre-composition networks may be shared.
The network control space 14 comprises a set of control functions to enable interworking between networks 10. These control functions, also referred to as functional areas (FAs), each handle a specific management task, such as Quality of Service (QoS), mobility, security, context awareness, and network composition. The composition FA is responsible for composition related functions as will be hereinafter described. Depending on the type of composition, a new network control space 14 may be created for the composed network.
The network control space 14 includes three interfaces: the network interface 16, the service interface 18, and the resource interface 20. The network interface 16 provides a standard mechanism to enable cooperation between the network control spaces 14 of different networks 10 and hides the complexities of the underlying network technologies so that networks 10 using different technologies appear the same. The networks use a technology independent signaling protocol, such as the Generic Ambient Network Signaling Protocol (GANS), to exchange information over the network interface 16. Applications or clients residing on network nodes 22 use the service interface 18 to access the services provided by the network control space 12. When two networks 10 compose, a single service interface 18 is created for the composed network. The resource interface 20 provides a mechanism to manage the resources residing in the connectivity layer. Applications use the resource interface to access the resources residing on network nodes 22 in the connectivity layer 14.
Individual networks 10 can compose to form composed networks, which can also compose with other networks 10. Network composition enables dynamic and instantaneous interworking of heterogeneous networks 10 on demand and in a transparent fashion without manual configuration or offline negotiation. When two networks 10 compose, they communicate with one another over the network interface 16 to negotiate a network composition agreement (NCA). The NCA specifies the resources that will be shared, the services that will be provided, and the policies that will be implemented to coordinate interoperation of the network control spaces 14 of the pre-composition networks 10. The result of the composition may be a newly composed network that includes all of the logical and physical resources contributed by the pre-composition networks 10. Composition, however, does not necessarily result in a new composed network.
Three types of network composition are possible: network interworking, control sharing, and network integration. In the first type, each network 10 controls and manages its own resources and no composed network is created. In the second type, some of the resources of the composing networks 10 are contributed to a new composed network. This composed network has its own logical network control space. The composing networks 10 exercise joint control over the shared resources and keep control over the remainder of their own resources. In the third type of network composition, all of the participating networks 10 merge into a new composed network. The composed network consists of all logical and physical resources in the composing networks. A new logical network control space 14 is created during composition and manages the composed network.
The pre-composition networks 10 may include registries 24 that can be accessed by applications. A registry 24 is any authoritative store of information or repository of data, such as a database. The registries 24 hosted by the pre-composition networks 10 can be of different types (e.g. centralized, distributed), they can store different types of information using different formats (e.g. Object oriented database, relational database), and they can rely on different interfaces to access the stored information (i.e. protocols such as P2P information discovery protocols or programming interfaces such as UDDI APIs).
According to the present invention, the concept of composition is extended beyond simple network composition to include composition of registries 24 existing in the pre-composition networks 10. When two networks 10 compose, two or more individual registries 24 in the constituent networks 10 are merged into a single logical registry, referred to herein as a merged registry 26. As used herein, the term “merge” does not necessarily imply the physical merging of the registries 24, but also includes the logical linking of registries 24 so that the combined resources appear to an application in the composed network as a single registry 24. Clients are provided the ability to automatically and seamlessly access the content of the various post composition registries that comprise the merged registry 26. This objective is achieved by providing an overlay architecture for information discovery and publication after network composition.
According to the present invention, a new functional entity in the network control space 14 called the registry composition entity (RCE) 30 is created to coordinate the composition of registries 24 and the creation of the overlay network 50. The RCE 30 may be incorporated into the composition FA, or may be a separate FA. Additionally, a registry discovery protocol (RDP) is added to each registry 24 to enable the automatic discovery of registries 24. The RDP is needed for peer-to-peer and mobile ad hoc networks 10 so that the networks 10 can acquire the addresses of existing registries 24 when they join or compose with an existing network 10.
The composition process for registry composition should preferably satisfy the following requirements:
The RCE 30 includes a coordination module 32, and a composition module 33. The coordination module 32 enables communications between RCEs for different networks 10. The composition module 33 represents the main functionality of the RCE 30. The composition module 33 includes a composability check module 34, and a composition manager 36. The composability check module 34 checks the degree of composability of the existing registries and negotiates a registry composition agreement (RCA) with the composition modules 33 of other constituent networks. The composition manager 36 is responsible for executing the registry composition agreement.
When the registry composition process is initiated, the composability check module 34 checks, for each registry 24, the protocol stack used for publication and discovery (e.g. UDDI APIs, SOAP v1 over HTTP v2 in the specific case of Web services), the type of discovery approach used (centralized, peer-to-peer), the information publication and discovery protocol, and the RDP version used. Using this information, the different composability check modules 34 for the different networks 10 communicate through the coordination module 32 to negotiate the registry composition agreement. The registry composition agreement may be incorporated into part of the network composition agreement. The composability check modules 34 negotiate the interworking protocols to determine which, if any, they will use, verify whether these protocols exist or can be generated on the fly, and verify whether it is possible to make them available by checking resources availability. The composability check modules 34 also negotiate the type of registry composition to use (e.g. create a new registry, use only existing registries). The composability check may indicate that composability is not feasible for several reasons. One example is when an interworking protocol is required but either this protocol cannot be found and cannot be generated on the fly, or it cannot be made available (e.g. security issues, resources not available).
Similar to network composition, there are three types of registry composition: non-integration, partial integration, and full integration. The registry composition agreement can take any one of three approaches to registry composition depending on the type of information contained in the registries.
The non-integration approach, illustrated in
The partial integration approach, illustrated in
The full integration approach illustrated in
When the non-integration or partial integration approaches are used, the preexisting registries 24 involved may use different protocols. Intercommunication between the constituent registries can be enabled by two mechanisms. The first is the use of gateways for interworking. The second is automatic protocol deployment. In the second case, if there are two registries R1 and R2 using protocols P1 and P2 respectively, registry R1 can deploy protocol P2 or registry R2 can deploy protocol P1. Another possibility is to specify a standard protocol PS that is deployed in each registry that does not already support it. This last possibility will limit the number of protocols to deploy and hence provide more scalability.
To enable the automatic creation of gateways, the RCEs 30 can store the formal specifications for the needed protocols in memory. Each RCE 30 maintains the formal specifications of the IDP protocols of its network 10. When an interworking protocol is needed, the RCEs 30 elect a master RCE 30 and download the different protocol specifications to the elected master RCE 30. The master RCE 30 creates the required internetworking protocols, which will be downloaded and installed in the gateways. This approach implies that the gateways are programmable nodes 22, in order to make them change their behavior on the fly. It also implies that it must be possible to send active packets to the gateways to deploy the new protocol.
An alternative approach to automatic gateway creation is to use the RCEs 30 as protocol servers that store some commonly used interworking protocols. In this case, when an interworking protocol is needed, the RCEs 30 can check whether the needed protocol is stored in one of the other RCEs 30. If it is not, the composability check module 34 will fail, and the composition process will abort.
With protocol deployment, each RCE 30 maintains the RDP and IDP for its pre-composition network 10. When protocol deployment is needed, the RCEs 30 negotiate the protocol to deploy. Once the protocol is agreed upon, the protocol can be downloaded to and installed in all of the appropriate nodes 22. In this case, there I no need for protocol creation. This implies that all of these nodes 22 are programmable, and that it is possible to send active packets to each of them.
To enable seamless access to information in the composed network independently of the registry 24, 25 in which it is stored, an overlay network 50 for information discovery and publication can be created during the network composition process. The overlay network 50 may be based on a peer-to-peer (P2P) overlay mechanism. The use of a P2P overlay mechanism is advantageous because it allows distributed architectures, self reorganization, scalability (P2P overlay mechanisms enable nodes to join and leave “easily”), and provides a very good chance to discover existing information. The general requirements for the overlay network 50 are:
Registries R1-R4 may use different Information Discovery and Publication Interfaces (IDPIs) (i.e., protocol or programmatic interface) for access information. Examples of IDPIs include Structured Query Language (SQL), Universal Description Discovery and Integration (UDDI), and Java Description Object Query Language (JDOQL). In this example, Registry R1 implements a first IDPI (I1), Registries R2 and R3 implement a second IDPI (I2), and Registry R4 implements a third IDPI (I3).
The overlay network 50 logically links the registries R1-R4. One type of node makes up the overlay network: the Virtual Registry (VR) 52. A virtual registry 52 communicates with the other virtual registries 52 using an Overlay Interface 54, and with post-composition registries 24 using a Registry Interface 56. There is one virtual registry 52 in the overlay network 50 for each different IDPI used by the post composition registries R1-R4. In this example, the four post composition registries R1-R4 use three different IDPIs. Thus, there are three virtual registries 52 in the overlay network 50. Each virtual registry 52 supports only one IPDI. The clients (i.e. entities that want to publish or discover information) continue to communicate with pre-composition registries 24 that were part of their network 10 before composition. Each post composition registry R1-R4 communicates with the virtual registry 52 that supports the same IPDI.
A description is associated with each registry R1-R4. The description includes the type of the registry and a description of the information it contains. The main parts of this description are: the registry address, the registry type (e.g. UDDI, SQL, JDOQL. etc.), the type of information maintained by the registry (e.g. web services descriptions), and a brief description of the purpose of this information (e.g. printing, user location, hotel booking). The registry address includes the registry URI and the port number at which clients can communicate with that registry. Each post-composition registry 24 maintains its description. The registry description is intended for machine-to-machine communication between heterogeneous nodes, and therefore, XML may be used as the description language.
The overlay network 50 has a P2P overlay architecture with a fully interconnected topology. It uses a P2P protocol for information discovery and publication The requirements of the overlay protocol are:
Many existing P2P protocols can be used as an overlay protocol, such as Tapestry and Chord. Some existing middleware can also be used for the implementation of the virtual registry, such as JXTA. JXTA is a set of open protocols that allow devices on the network to communicate and collaborate in a P2P manner.
Table 1 below lists messages exchanged between virtual registries 52 in one exemplary embodiment.
The overlay network 50 is created during the registry composition process. One RCE 30 may be selected during the negotiation of the registry composition agreement as the coordinating RCE to coordinate the composition of the registries and the creation of the overlay network 50. The coordinating RCE 30 determines the types, addresses, and IPDIs for post-composition registries 24.
Each virtual registry 52 is mapped to a post-composition registry that supports the same IPDI. For centralized registries, one post-composition registry (R) with the same IDPI is selected to support the virtual registry 52. The post-composition registry to which the virtual registry 52 is mapped can be chosen either randomly, or based on available resources (e.g. processing power and memory, disc space). If the node 22 supporting the virtual registry leaves the network due to network decomposition, the virtual registry 52 is remapped to another post composition registry with the same IDPI. If no other registry uses the same IDPI, the virtual registry is removed. With distributed registries, mapping is done in the same way, except that the virtual registry 52 is mapped to the super-node of the selected post-composition registry. If the network representing the selected registry does not use the super-node concept, one of existing solutions for electing a super-node can be used. If the super-node leaves, the new super-node becomes the virtual registry 52.
The IDP service module 72 includes an application programming interface (IDP API) that enables registries 24 to communicate with the overlay application 52. Exemplary service requests for the IDP API are listed in Table 2 below.
The overlay service module 74 provides an overlay service API (OS API) to enable communication between overlay application modules 62 residing at different virtual registries 52. Exemplary service requests for the OS API are listed in table 3 below.
The IPD service module 72 and the IPD protocol stack 82 provide the “Registry Interface” of the virtual registry 52. The overlay service module 74 and the overlay protocol stack 84 provide the “Overlay Interface”. The “Registry Interface” is used to communicate with post composition registries using the same IPDI supported by the virtual registry 52. To communicate with a post composition registry that supports a different IPDI, the application identifies the virtual registry 52 that supports the same IPDI as the target registry and sends the message to it. The selected virtual registry 52 will then transmit the message to the target registry and send the response, if any, back to the initiating node. The re-director module 28 is added to each post composition registry to enable it to redirect the requests received from clients to the overlay network 50 when needed.
Normally, John's laptop accesses the Internet through an access point on John's home network HN. When John's PAN moves out of range of the HN, WS1 is out of reach. Meanwhile, John gets near a static local area network (LAN) that provides access to a printing web service (WS2), with the same characteristics required by the printing application. WS2 information is stored in a UDDI registry (R4). The static network hosts another registry (R3), which is an object-oriented database. When John's PAN gets close to the LAN, the two networks 10 compose. During network composition, the RCEs 30 of the two networks compose the four registries and create the overlay network 50. The overlay network 50 will be made up of three virtual registries: VR1 uses SQL as its IPDI, VR2 uses UDDI APIs as its IDPI, and VR3 uses Java Data Object Query Language (JDOQL) as its IDPI. JDOQL is an implementation of the Object Query Language, a query language standard for object-oriented databases. If John orders a document to be printed after the creation of the overlay network 50, the overlay network 50 is used and the printing application automatically gets the address of WS2 and prints the document.
The present invention may, of course, be carried out in other specific ways than those herein set forth without departing from the scope and essential characteristics of the invention. The present embodiments are, therefore, to be considered in all respects as illustrative and not restrictive, and all changes coming within the meaning and equivalency range of the appended claims are intended to be embraced therein.
This application claims the benefit of U.S. Provisional Patent Application 60/868,492 filed Dec. 4, 2006, which is incorporated herein by reference.
Number | Date | Country | |
---|---|---|---|
60868492 | Dec 2006 | US |