The invention relates to application layer networking, and more particularly to creation of XML (extensible Markup Language) network topology.
Content-based networks provide distribution of content from providers to subscribers. In content based networks implemented with XML (extensible Markup Language), distribution of said content from the providers to the subscribers occurs through the use of application level XML routers which at the application level ensure that the appropriate content is routed to the appropriate subscribers. As with any network, the procedure used to establish connectivity between routers and the resulting topology have a profound effect upon the effectiveness and efficiency of the network.
In known systems, network topology is typically created in such a manner that each of the subscribers can potentially receive content from each of the providers. As a result most topologies of the prior art content based networks were full mesh topologies or variations thereof. Full mesh topology in a content based application layer network implies a large amount of replication effort which creates delay and overburdens resources.
XML routed communication realizes a many-to-many push communication facility that uses dynamic XML content addresses (the content is an interface group address) and decouples sources (publishers) from receivers (subscribers) with a network of XML routers (directory). The terms “XML routing” and “XML multicast routing” are used interchangeably in the industry. The XML routing engine performs aggregation and distribution of complex semantic routing policies among XML routers connected via an IP network. These semantic routing policies which are maintained by the XML routing control plane are enforced by XML routers at the data plane for streaming XML data at high speed.
XML routing enables the publish/subscribe communication model to distribute real-time events through distributed systems on wide area networks. XML routed networking provides content-based publish-subscribe communication without requiring application specific integration with the network. In an XML routed network, receivers declare their interests using the subscribe process, senders simply publish messages, and the network takes care of delivering the messages from the senders to subscribed receivers. Senders and receivers need not know about each other nor is a connection needed between a sender and a receiver. The network is responsible for intelligently matching new messages to existing subscriptions and delivering the information to relevant subscribers.
XML routers employ XML routing and XML forwarding algorithms for XML traffic handling. Analogous to conventional networking, XML routing amounts to synthesizing XML content distribution paths across the network while XML forwarding involves determining at each XML router the set of next hop XML-aware devices. XML routing enables reliable real-time many-to-many push communications in a flexible manner over a large network.
Subscriptions are the bases of XML publish-subscribe communication since they are used to construct routing information. An XML content subscription is a logical constraint on document structure (path expression) or attribute(s) value(s) requesting XML documents matching these logical constraints to be forwarded to the subscribing node, or on the interface of the subscription. An XML document contains elements, which contain attributes, other elements, and text. XPath provides a standard language for expressing XML document subscriptions and a standard expression syntax for locating XML elements within XML documents. At an XML router, the outgoing interfaces or next hops of a message are determined by matching the content of the message against logical content constraints in a content-routing database. The content-routing database is constructed from the subscriptions, each being a set of attribute-value constraints, of the neighbor nodes indicating messages of interest. The XML-routed communication service consists of delivering a message to all XML nodes whose advertised constraints encompass the message attributes.
An XML routed network is a point-to-point, application level overlay consisting of network hosts and routers. Although point-to-point connections between XML nodes may require that each XML node has a set of unique Layer 3 network addresses to allow the construction of the XML network overlay, the use of Layer 3 network addresses is limited to the Layer 3 network. At the XML routing layer, each node may be assigned a Unique Resource Identifier to assist in message delivery over the Layer 3 network, however messages are not addressed to destination network node(s) explicitly. Instead, each message has a number of attribute-value pairs, such as the topic attribute for routing in a topic-based publish-subscribe system. XML routed networks provide a form of communication whereby the flow of messages from sources to destinations is determined primarily by the message content rather than an explicit addressing.
At the control plane of an XML routed network, XML routing is responsible for distributing and maintaining receiver subscriptions. XML routing involves (1) propagation of topological information to establish the XML overlay network, (2) aggregation of XML constraint subscriptions received from neighbor nodes, and (3) distribution of XML context subscriptions (selection predicates) among XML routers in the XML network overlay.
The rapid adoption of the XML data model and Web Services has triggered the commercialization of a large number of XML-aware networking devices such as XML firewalls, XML routers, and XML transformation accelerators. Up to this date XML routing protocols, which form the control plane of XML routers, remain proprietary to private companies.
Recently, XML has become of interest for publish-subscribe networks due to its widespread adoption in the application world. However, the infancy of XML routing is evident in the lack of standardized XML routing protocols and the lack of experience with XML routed networks. The utility of XML routing in the context of new XML-based network services lies in customized content push distribution, distributed event monitoring networks, publish-subscribe Web services, secure reliable multicast, and application XML VPNs.
Examples of AON/XAN devices that utilize XML routing are Cisco's AON cards, Solace Systems XCR 3200, Sarvega's XML Context Router, and IBM Datapower product family.
Current content based application layer networking systems are not designed to scale well as the size of the network grows especially in the context of the heavy processing demands of distributed XML messaging. Other content based application layer networking solutions, such as IP multicast used for one-to-many broadcast, do not lend themselves to the dynamic real-time demands of a content based publish-subscribe system such as XML messaging.
According to one aspect, the invention provides a method for creating an extensible mark-up language (XML) network. A new XML router is added to a group of existing XML routers by registering the new XML router with a rendezvous point of an XML router discovery group. A hello message is intermittently broadcast from each XML router to all other XML routers in the group. At each XML router, a timer is maintained in association with each of at least one adjacent XML router. If a timer expires at one of the XML routers before receipt of a hello message from the adjacent XML router associated with the timer, the fact that the adjacent XML router is no longer a neighbour of the XML router on which the timer expired is broadcast to all other XML routers.
One of the existing XML routers may be selected by determining which of at least two XML routers best satisfy prioritized metrics. Adjacency between the new XML router and the selected existing XML router may then be established.
According to another aspect the invention provides a method for adding an XML router to an existing XML network having at least one existing XML router. One of the existing XML routers is selected by determining which of at least two XML routers best satisfy prioritized metrics. Adjacency between the new XML router and the selected XML router is then established.
The methods of the invention allow creation of an XML network, or more generally any content based application layer network in which publish-subscriber or advertize-publish-subscribe messaging is used. XML router discovery and monitoring is used to manage network topology. Topology generation utilizes three network metrics to establish network element adjacency, enabling dynamic growth of the XML network. By allowing a network administrator to prioritize the network metrics, the topology of the XML network can be created automatically and still have the characteristics desired by the administrator.
The features and advantages of the invention will become more apparent from the following detailed description of the preferred embodiment(s) with reference to the attached figures, wherein:
It is noted that in the attached figures, like features bear similar labels.
Broadly, an XML network is created using XML router discovery and monitoring to manage network element membership, and using prioritized network metrics to establish network element adjacency when creating the XML network topology. XML router discovery and monitoring is achieved by intermittent broadcasting of hello messages from each XML router, each hello message including an identification of XML routers which are neighbours of the XML router which broadcast the hello message. Each XML router maintains a timer for each of its neighbour XML routers. If a timer expires before receipt of a hello message from the adjacent XML router associated with the timer, then the XML router maintaining the timer broadcasts to all other XML routers that the XML router associated with the timer is no longer a neighbour of the XML router maintaining the timer.
In order to create the XML network topology, adjacency is established between a newly added XML router and an existing XML router. The newly added XML router selects an existing XML router by evaluating at least two XML routers using prioritized metrics. Adjacency is established with the XML router which best satisfies the prioritized metrics.
Referring to
It should be noted that the multicast group of the preferred embodiment is set up over an IP multicast channel over many IP hops as opposed to the traditional one physical hop or multiple Ethernet hops of OSPF.
In
Referring to
In addition to the hello message sent at the time that a new XML router registers with the multicast group, each XML router regularly broadcasts a hello message to all the other XML routers of the XML network based on its internal hello timer. In an exemplary embodiment of the invention, all of the XML routers of the XML network have the same hello timer parameters. Referring to
If the other router is a new router, the XML router adds the new router to the local database at step 124 by adding the URI of the other router to its local database. At step 125 the XML router determines whether the other router is a neighbour. If so, then at step 126 the XML router starts a hello timer associated with the other router, which is the time period after which the XML router will declare the other router as inactive if no subsequent hello messages are received from the other router. If the other router is not a neighbour, then the XML router finishes processing the hello message. If at step 123 the XML router determines that the other router is not a new router, then at step 127 the XML router updates the router list of URIs in its local database with the list of URIs in the received hello message. At step 128 the XML router determines whether the other router is a neighbour, and if so then at step 129 the XML router resets a hello timer associated with the other router in its local database. If at step 128 the XML router determines that the other router is not a neighbour, then the XML router finishes processing the hello message.
Referring to
Once an XML router has been added to a group, the newly added XML router chooses which other XML router to establish adjacency with. Referring to
During the process of building the network, the system takes into account three metrics to decide which of the existing XML routers should be established as adjacent to each new router added to the network. These metrics are a TCP hops metric (or more generally an application layer hop metric), an IP cost metric, and a fanout metric.
The TCP hops metric assigns a TCP hops number to each of the existing routers with which the new XML router may establish adjacency. The TCP hops assigned to a potential neighbour XML router is the minimum number of application layer hops (number of XML routers traversed) needed to reach the farthest perimeter router from that potential neighbour XML router. For example, in the XML network shown in
The IP cost metric assigns an IP cost to each of the existing routers with which the new XML router may establish adjacency. IP cost in general may be measured using any number of possible known IP cost metrics and preferably any IGP metric. In other embodiments of the invention a round trip time for messages to traverse between the new XML router and the existing router measured in milliseconds (msec) is used.
The fanout metric assigns a fanout to each of the existing routers with which the new XML router may establish adjacency. The fanout of a router is the number of adjacencies it has established with other routers of the XML network. For example, the fanout of XML router D in
In association with metrics are a number of parameters which an operator may set. The first set of parameters set by an operator are the prioritization parameters. The prioritization parameters are a prioritization of the three metrics discussed above, and a type of fanout prioritization. Referring to
When determining the connectivity for a newly added XML router, the operator arranges the three metrics into three ordered priorities and defines the fanout prioritization type. In the example prioritization parameters shown in
The fanout prioritization type can be of three types and is chosen by an operator. The way in which the fanout is used while building the network topology will differ depending upon the fanout prioritization type. The operator will typically choose the particular type needed by the network based on, for example, the nature of the XML routers and the desired general type of topology preferred. These three types of fanout priority are: greatest fanout; least fanout; and target fanout. If the fanout parameterization type is target fanout, then a target fanout value is also defined. These are described in more detail below with reference to
A second set of parameters is a maximum fanout parameter defined for each XML router, which specifies the maximum number of application layer connections allowed for the XML router. In other words, the maximum fanout parameter is the maximum number of other routers with which it can establish adjacency. The XML routers need not all have the same maximum fanout parameter. The maximum fanout parameter for each XML router is preferably defined by the operator.
A third set of parameters which can be defined by the operator defines a number of IP cost levels for grouping IP costs measured during building of the network. Referring to
Referring to
For each router in the subset of routers having less than its maximum fanout, an IP cost is calculated at step 144 and the router placed in one of the IP cost levels as defined by the operator as described above. In the preferred embodiment of the invention, the IP cost of each of the routers in the subset 10 is calculated from the round trip time it takes for the hello message sent by the new router N to be answered by a hello message from each of the routers in the subset 10. In the example network of
At step 146 the maximum number of TCP hops to the perimeter of the network is calculated for each of the routers determined as having less than its respective maximum fanout. The TCP hops of each XML router of the network is conveyed to the new XML router N in the TCP hops 119 value in the respective hello message received from that XML router. In the example network of
Finally, before proceeding to the first priority as defined by the operator, the current fanout is calculated at step 148 for each of the routers determined as having less than its respective maximum fanout. The fanout of each XML router is conveyed to the new XML router N in the fanout value 118 in the respective hello message received from that XML router. In the example network of
Once the new XML router has all of the information regarding the IP cost, IP cost level, TCP hops, and fanout of each existing XML router of the XML network, the new XML router proceeds to decide with which of the existing XML routers to establish adjacency. This is determined by evaluating the prioritized metrics of each of the potential neighbour XML routers in the subset 10 of routers having less than their respective maximum fanout. Returning to
If more than one XML router is determined at step 152 as satisfying the first priority, then at step 156 the new XML router evaluates each of those potential neighbour XML routers which satisfy the first priority by using the metric defined as the second priority 31. If only one of those XML routers is determined at step 158 as satisfying the second priority, then the new XML router establishes adjacency with that single XML router at step 154.
If more than one XML router is determined at step 158 as satisfying the second priority (and hence also the first priority), then at step 160 the new XML router evaluates each of those potential neighbour XML routers which satisfy both the first priority and the second priority by using the metric defined as the third priority 32. If only one of those XML routers is determined at step 162 as satisfying the third priority, then the new XML router establishes adjacency with that single XML router at step 154.
If more than one XML router is determined at step 162 as satisfying the third priority (and hence also the first and second priorities), then at step 164 the new XML router evaluates each of those potential neighbour )(ML routers which satisfy all three priorities by using a tie-breaking mechanism. The tie-breaking mechanism determines a single XML router, and the new XML router establishes adjacency with that single XML router at step 154.
Referring to
Referring to
Referring to
Referring to
Referring to
Referring to
Referring to
When choosing the type of fanout priority an operator will take into account the order of metrics for the priorities chosen and the particular goals the topology needs to meet in the context of the particular capabilities of the XML routers and underlying physical network. For example, in a set of priorities where the fanout priority is the first priority the fanout priority type should probably be chosen to be greatest fanout, or target fanout, otherwise a line topology would result if all XML routers were added according to the same set of priorities. In cases where the XML routers do not all have the same order of metrics in the priorities and in cases where the fanout priority is not the first priority, any one of the greatest fanout, least fanout, and target fanout priority type may be chosen for the XML router. In cases where TCP hops are of a more primary priority than fanout, an operator may choose to set the type of fanout priority to greatest fanout priority to further minimize the overall number of TCP hops in the network. Conversely in some cases where fanout is of a more primary priority than TCP hops, an operator may choose to set the type of fanout priority to least fanout priority if minimizing the overall number of TCP hops in the network is less important. Alternatively, an operator may know that a certain target number of adjacencies per router is ideal in the particular operating context of the XML network, in which case the fanout priority type would be set to target fanout priority.
In determining the order of the metrics in the priorities themselves the operator has many considerations to make in the trade off among fanout, TCP hops, and IP cost. Higher fanout throughout the network generally results in lower latency through the network, but more replication effort required from the routers, and a larger routing database due to the lack of route aggregation at intermediate points in the network. If a router has dedicated hardware or otherwise optimized resources for replication, fanout can be set higher than for routers which are not optimized for replication or for routers which use software with scarce resources. Persons skilled in the art however understand that increasing fanout indefinitely would not scale well in large networks. Ensuring there is a maximum fanout for each router is useful in this respect. Lower TCP hops throughout the network generally results in lower latency through the network, and larger routing database sizes due to a lack of aggregation at intermediate points in the network. Reducing IP cost will generally reduce the overall resource and network bandwidth requirements.
Persons skilled in the art will generally be able to determine based upon the context of the particular application layer network they are implementing and the capabilities of the application routers and underlying physical network utilized, which of the types of fanout priorities should be used, and how each of the three metrics, namely, IP cost, TCP hops, and fanout should be prioritized to best meet their needs.
The invention has been described as having the prioritization parameters (the relative priorities of the three metrics and the fanout parameterization type) all set by an operator. Alternatively, the operator need not set all three priorities, and need not define which type of the fanout prioritization is to be used. In embodiments which do not require the operator to set all three priorities or do not require the operator to set the fanout prioritization type, a default priority order and a default fanout prioritization type can be set, which can then be partially or fully overwritten by the operator. Optimization during generation of the topology of the network would then proceed by dealing with the operator parameters first and then by dealing with the defaults parameters to arrive at a final XML router to establish adjacency with the router being added.
The invention has been described with the prioritization of metrics set by an operator when the connectivity of a newly added XML router is to be determined. This allows the greatest flexibility in designing the network, as the prioritization can be set for each XML router as it is added and each new XML router can select its neighbours using priorities specific to itself. In an alternative embodiment, a master router is used to determine the connectivity of each newly added XML router, and applies the same metric prioritization for each newly added XML router. The master router sends the common prioritization to the control plane of each newly added XML router, which determines its connectivity using the common metric prioritizations. Although such an embodiment does not provide as much flexibility in designing the XML network topology, it has the advantage of being faster and simpler.
The invention has been described using three fanout prioritization types and a target fanout value. In one embodiment these are combined into a single value defining both the fanout prioritization type and the target fanout value. For example, a target fanout value of “1” can be used to indicate a fanout prioritization type of “least fanout”, a target fanout value of “99” (or some other high number) can be used to indicate a fanout prioritization type of “greatest fanout”, and any other number used to indicate both a fanout prioritization type of “target fanout” and the target fanout value. In fact, in such an embodiment, only the single method described with reference to
The invention has been described as using the lowest router ID as the final tie-breaker for XML routers which are equivalent by all other measures. Alternatively the XML router having the greatest router ID may be selected. Indeed, any method of categorically selecting a single XML router using a value unique to each XML router may be used by selecting the XML router whose unique value satisfies a predetermined criterion.
Although the preferred embodiment of the invention is exemplary of a content based XML network including XML routers, XML router discovery, and generation of XML network topology, the invention contemplates any kind of content based application layer network, its routers, router discovery and content based application layer network topology generation in general.
The invention has been described as using prioritized metrics to establish adjacency for a newly added XML router, and using timers and the exchange of hello messages identifying neighbours in order to effect network discovery. Alternatively, once prioritized metrics are used to select an existing XML router with which a newly added XML router establishes adjacency, other means may be used to effect network discovery. Similarly, the use of timers and the exchange of hello messages identifying neighbours may be used to effect network discovery in networks that have been created using other adjacency determination methods.
The methods of the invention are preferably executed in a distributed manner by the control logic on the new XML router being added to the XML router, either as software instructions executable by a processor, by hardware logic within the XML router, or a combination of software and hardware. Alternatively, the methods may be executed centrally by an XML control plane server with access to the new XML router and to each existing XML router in the network, in which case the methods are in the form of software instructions executable by a processor. In either case, if the methods are executed partially or wholly as software instructions, then the software instructions may be stored on computer-readable media.
The embodiments presented are exemplary only and persons skilled in the art would appreciate that variations to the embodiments described above may be made without departing from the spirit of the invention. The scope of the invention is solely defined by the appended claims.