Publish and subscribe (publish/subscribe) systems are asynchronous messaging systems. Messages are categorized in classes and a subscriber expresses interest in one or more classes of messages to a server. The publisher of a message (publisher) does not send the message to a specific receiver (subscriber), but publishes the message to the server, without knowledge of what (if any) subscribers will receive the message. When a message is received for publication, the server transmits the message to subscribers who have expressed interest in the class associated with the message. Thus, the publishers and subscribers are decoupled in a publish and subscribe system, operating independently of each other.
The first publish and subscribe system was the “news” subsystem in the Isis Toolkit, which was described in a paper “Exploiting Virtual Synchrony in Distributed Systems” at the 1987 ACM Symposium on Operating Systems Principles conference (p. 123-138).
As each user subscribes to various classes of messages, subscribers typically receive only a sub-set of the total messages published. As an example, a subscriber may subscribe to messages based on the topic of the message. Subscribers in a topic-based system will receive all messages published to the topics to which they subscribe. All subscribers to a topic receive the same messages. As another example, a subscriber may subscribe to messages based on the content of the message. In a content-based system, a message is only delivered to a subscriber if the attributes or contents of the message matches constraints defined by the subscriber. Some publish and subscribe system combine topics and contents in a hybrid manner.
In a typical publish and subscribe system, a server receives subscription requests from clients wishing to receive messages based on topic or content. When a user wants to publish a message, the message is sent to the server, which then forwards the message to the various users who have submitted subscription requests matching the message properties. In this way, the server performs a filtering function, only transmitting the message to interested subscribers. Some servers may perform a store-and-forward function during the process of routing messages from publishers to subscribers, decoupling the publishers and subscribers temporally. An example of this temporal decoupling is temporarily taking down a publisher in order to allow the subscriber to work through the backlog, producing a form of bandwidth throttling.
For relatively small installations, publish/subscribe systems, through parallel operation, message caching, and the like, can provide better scalability than a traditional client-server system. However, as a publish/subscribe system is scaled up, benefits provided by the publish/subscribe system are often lost. Thus, despite the functionality provided by conventional publish/subscribe systems, there is a need in the art for improved publish/subscribe systems as well as methods for using such systems.
The present invention relates generally to computer networks. More specifically, the present invention relates to methods of operating a publish/subscribe system. Merely by way of example, the invention has been applied to a publish/subscribe system in which remote relays communicating with multiple sets of central relays receive a subscription request from a client and subscribe to all of the central relays in one set of central relays. Publication messages from clients are published to only one central relay in each set of central relays. Thus, embodiments of the present invention implement an architecture in which publication message load balancing is provided at the application level. The methods and techniques can be applied to a variety of computer networks and communications systems.
According to an embodiment of the present invention, a method of publishing a message is provided. The method includes receiving a subscription request at a first remote relay from a first client and transmitting a subscription message from the remote relay to each of a first set of central relays. The subscription request and the subscription message include a target. The method also includes receiving a publication request at a second remote relay from a second client and transmitting a publication message from the second remote relay to a first central relay of the first set of central relays and a second central relay of a second set of central relays. The publication request includes a message string characterized by a pattern and the publication message includes the message string. The method further includes determining, at the first central relay, that the target matches at least a portion of the pattern, transmitting the message string from the first central relay to the first remote relay, determining, at the first remote relay, that the target matches at least a portion of the pattern, and transmitting the message string to the first client.
According to another embodiment of the present invention, a publish/subscribe message architecture is provided. The publish/subscribe message architecture includes a first set of central relays, a second set of central relays, and a first remote relay in communication with the first set of central relays. The publish/subscribe message architecture also includes a first client in communication with the first remote relay. The first remote relay is operable to transmit a subscription request to each of the central relays in the first set of central relays. The publish/subscribe message architecture further includes a second remote relay in communication with the second set of central relays and a second client in communication with the second remote relay. The second remote relay is operable to transmit a publication message to one of the central relays in the first set of central relays and one of the central relays in the second set of central relays.
According to a specific embodiment of the present invention, a method of operating remote relays is provided. The method includes receiving, at a first remote relay, a subscription request from a first remote client and recording, in a computer readable medium of the first remote relay, identify information associated with the first remote client. The subscription request includes a target and information associated with the target is also recorded, in the computer readable medium of the first remote relay. The method also includes transmitting a subscription message to each of a first set of central relays. The subscription message includes the target. The method further includes receiving, at a second remote relay, a publication request from a second remote client and transmitting a publication message from the second remote relay to a first central relay of a first set of central relays and a second central relay of a second set of central relays. The publication request includes a message string characterized by a pattern and the publication message includes the message string. Moreover, the method includes receiving, at the first remote relay, the message string from the first central relay, determining, at the first remote relay, that the target matches at least a portion of the pattern, and transmitting the message string from the first remote relay to the first client. Numerous benefits are achieved by way of the present invention over conventional techniques. For example, by utilizing the publish/subscribe architecture described herein, load balancing is provided at the application level. Utilizing a hierarchical structure, the number of connections from remote sites to central sites is greatly reduced. A reduction in the number of connections results in decreased system complexity in relation to configuring, maintaining, and running the IP network, enhanced security, and improved system performance. Additionally, embodiments of the present invention enhance system performance by reducing the number of duplicate publications.
Moreover, embodiments of the present invention enable system scalability by increasing the performance of the system as a whole in terms of messages per second that can be handled. As an example, if the traffic is being balanced across three application load balancing servers that are all performing about the same amount of work, each server is handling one third of the traffic for that site. Adding a fourth sever will increase the capacity since each server would then handle one fourth of the current traffic at the site. Due to the spare capacity on each server resulting from the addition of the fourth server, the overall capacity can be increased as the traffic rate increases. Embodiments of the present invention enable practically arbitrary increases in system scalability.
Furthermore, embodiments of the present invention provide systems that are characterized by both high availability and reliability. For example, when a client or server sends a message to a set of load balanced servers, it has the responsibility to send it to a server to which it has valid connection. Having more servers as elements of the system enables messages to still be transmitted through the system, even with more of the servers being in a failed state. For instance, if there are two servers in a set and both are in a failed state, the sender is not able to send the message using either server. However, if there are, for example, five servers in a set and two are in a failed state, three servers are still available to transmit the message through the system.
These and other embodiments of the invention along with many of its advantages and features are described in more detail in conjunction with the text below and attached figures.
As discussed above, typical publish and subscribe systems are one-level implementations in which a server interacts with subscribers and publishers. Each subscriber submits subscription requests to the server and each publication request is also submitted to the server. A drawback of using a conventional one-level system is that each client (either publisher or subscriber) is connected to the server, which results in a large number of connections between the clients and the server. The large number of connections, in turns, results in complexity in configuring, maintaining, and running the network on account of firewall rules, configuration of multiple logical paths, and the like.
Embodiments of the present invention utilize a hierarchical structure that reduces the number of connections from clients to central sites, for example, by an order of magnitude. Reducing the number of connections reduces the complexity of the network and associated configuration and maintenance tasks. Additionally, reducing the number of connections between clients and central sites enhances security since fewer connections are established and the reduced number of connections can be more carefully tracked and controlled. Moreover, reducing the number of connections improves performance on both the servers and clients since the load on these systems associated with handling connection processing is reduced. The hierarchical publish and subscribe system with load balancing described herein provides benefits not available using conventional techniques including redundancy, security, and performance.
VeriSign's HMS (Hydra Messaging Service) system is a publish/subscribe implementation for message passing. This is also referred to as a message bus. The system provides the functionality of sending messages between edge sites (represented by remote clients) and central data centers including central relays, in order to transmit and receive monitoring data and monitoring commands. This includes statistics on the functioning of SDNS, Whois, TGV, CRL, and the like. These statistics are displayed in real time by the Java HUD and Argus HUD, which subscribe to HMS, and also used for historical reporting involving the Hydra database, Hydra Plots, and other users.
Embodiments of the present invention provide improvements in relation to the existing HMS system, introducing a hierarchical architecture with load balancing. In one implementation, there are two levels of hierarchy—remote relays and central relays. Typically, the central relays are located in data centers. However, the invention can be extended to an arbitrary number of levels of the hierarchy.
The network connections 120, 130, and 140 are illustrated in
A second data center 152 includes a number of central relays (Central Relay 1 (152a) through Central Relay n (152n)). The central relays in the second data center 152 are in communication with remote clients 114 and 116 through a hierarchical structure of remote relays 136 and 126 disposed in Remote Relay Level1 and Remote Relay Level2, respectively. As described more fully throughout the present specification, a subscription request originating at remote client 110 can be transmitted to the first data center 150 and the second data center 152 through remote relays 124 and 134/136. A publication request from remote client 114 can be transmitted to the first and second data centers through remote relays 126 and 134/136. Accordingly, if the message content published by remote client 114 matches the subscription request submitted by remote client 110, such content can be provided to remote client 110 using the publish/subscribe system described herein.
In order to provide load balancing for traffic through the data centers, subscription and publication messages are transmitted to predetermined central relays as described more fully throughout the present specification and more particularly below. For subscription requests, remote relays record the subscription request when received from a remote client and then forward the subscription request to each central relay in one of the data centers. The central relays receiving the subscription request will record the subscription request. The central relays in the other data center do not receive the subscription request. When a remote client transmits a publication request to a remote relay, the remote relay forwards the publication request to one of the central relays in each of the data centers. In an embodiment, the particular central relay in each of the data centers that receives the publication request is defined in configuration data for the remote relay, enabling different remote relays to send their publication messages to different central relays.
After receiving the publication request, a central relay that has recorded the corresponding subscription request will then transmit the desired message to the remote relay from which the subscription request was received. In turn, the remote relay will transmit the desired message to the remote client that has submitted a subscription request.
Embodiments of the present invention utilizing the hierarchical architecture described herein are suitable for applications including systems that monitor network traffic, including DNS resolution systems (e.g., SDNS, TGV, Whois, and the like). The present invention is also suitable for use in other publish/subscribe systems, providing load balancing at the application level that will increase system performance and security. It should be noted that in contrast with conventional techniques that provide load balancing at the network level (e.g., packet load balancers), embodiments of the present invention provide load balancing at the application level.
As an example, a DNS service running on a server may track the number of DNS translations in a given time period. This DNS translation rate can be published as a statistic that other clients may be interested in receiving. This DNS translation statistic could begin with a predetermined character or string, for example, “DNST.” Subscription requests for this DNS translation statistic will therefore, include a condition that a string in the publication message will satisfy. For this example, the condition would be strings that start with “DNST.” This condition can also be referred to as a target and the string in the publication message can be referred to as a pattern. For this example, the pattern could be DNST100, indicating 100 DNS translations in a second. When a relay receives this pattern or string in a list of statistics being distributed to the system, the target DNST will be compared against the pattern DNST100, and patterns that start with the target DNST will satisfy the defined condition. Accordingly, the relay will deliver this statistic to the clients that have subscribed to these DNS translation statistics.
As another example, it may be desirable to send a command to a particular machine. In order to send this command, the machine could subscribe, providing it's machine name to the remote relay. Another machine can then send a publication message including the machine name of interest. During the publication process, the desired machine will receive the message based on the machine name of interest. Another variation on this command mode is that a publication message could be sent to all machines using a wildcard. One of ordinary skill in the art would recognize many variations, modifications, and alternatives.
Thus, the subscription message has a condition, also referred to as a target, and the published message is examined by the central relays and the remote relays to determine if the strings included in the published message have a pattern that satisfies the condition defined by the subscription message. As an example, the target could be a string of a first length (e.g., 4 characters) and the pattern could be a string of a second length (e.g., 10 characters) greater than the first length. The published messages are examined to determine if portions of the patterns in the message match the targets of interest. If there is a match between the target and a portion or all of the pattern, then the relay will direct the published message or some portion or variant thereof, to the other relays and clients that have subscribed using the target. The published message may be changed to another message as long as the clients that have subscribed using the target receive information related to their subscription.
Referring once again to
The subscription message is transmitted to all of the central relays in the first set of central relays (Data Center #1). In the illustrated example, there are three central relays illustrated, but fewer central relays or a greater number of central relays are included within the scope of the present invention. The subscription message is not sent to the central relays in the second set of central relays (Data Center #2). In an alternative embodiment, a variant of the subscription message including the target is transmitted to each of the central relays in the first set of central relays. Typically, the remote relays will store configuration data defining the set of central relays to which a particular remote relay will transmit subscription messages. As will be described more fully below, transmission of the subscription message to only one set of central relays will eliminate duplicate message delivery and provide for load balancing of publication messages. The central relays that receive the subscription message will record information related to the subscription message if it is a new subscription. If the subscription message is now new, then the central relay will perform a condensing function as discussed in relation to receipt of subscription messages by remote relays. As an example, if the target in the subscription message has already been processed by the central relay, then the identity of the remote relay will be added to the listing including the target and the identities of other remote relays that have already subscribed in relation to the target.
Although it is not required by the present invention, Central Relays 150a through 150n are co-located in a first data center 150 and Central Relays 152a through 152n are co-located in a second data center 152, with the dashed lines 150 and 152 representing a geographical boundary, that is, the geographical area associated with the data centers. It is also possible to have multiple levels of hierarchy without having multiple geographies. In the embodiment illustrated in
Since the subscription message was received by all of the central relays in the first set (Data Center #1), the central relay that receives the publication message (Central Relay 230a) is able to determine a match between the pattern in the publication message and the target in the subscription message. As an example, if the target was “DNST” and the pattern was “DNST100,” then central relay 230a would determine that the target matched a portion of the pattern, indicating that the central relay had received a subscription message from a remote relay interested in this type of message. Thus, a determination is made of whether the pattern satisfies a condition associated with the target.
Since the subscription message was not received at the second set of central relays (Data Center #2), the receipt of the publication message by Central Relay 240b does not result in a match between the target and at least a portion of the pattern. Embodiments of the present invention provide for application level load balancing since the publication message load is distributed between the various central relays in the data centers. Preferably, when subsequent publication messages are received at the data centers from other remote relays, the messages will be distributed, on average, approximately uniformly between the various central relays in the data centers. Thus, rather than having a single central relay perform most of the publication tasks, the workload is distributed between the various central relays. Although each central relay in a data center receives the subscription message and records the target, the publication message is only received by one central relay in the data center, resulting in only a single central relay processing the publication message to determine a match between the pattern and the target.
Once Central Relay 230a has determined a match, the message string is transmitted to remote relay 220 (Process 6), which is included in a list maintained by the central relay indicating an interest in this particular message type. In addition to the message string, additional information may be included along with the message string. Remote relay 220, in turn, determines that the target matches at least a portion of the pattern and transmits the message string to remote client 210 (Process 7). If remote client 212 had submitted a similar subscription request (Optional Process 2), then the message string would be transmitted to remote client 212 as well.
In implementations in which there is only one set of central relays, embodiments of the present invention will still provide for application level load balancing. In these implementations, subscription messages will be delivered to each central relay in the set, i.e., all the central relays in the system. The publication message will then be transmitted to and received by one of the central relays. The central relay receiving the publication message will then communicate the publication message to the subscribing remote relay(s). Therefore, even in implementations with a single set of central relays, the model of “subscribe to all and publish to one” will result in application level load balancing. It will be noted that in this single set implementation, the publication message will be sent to one central relay in the set of central relays rather than to one central relay in each of the multiple sets of central relays.
A subscription message is transmitted from the first remote relay to each of a first set of central relays (312). The subscription message includes the target, providing the central relays with an indication that the first remote relay is interested in the particular type of publication message indicated by the first remote client. As illustrated in
The publication portion of the publish/subscribe system is initiated when a publication request is transmitted from a second remote client to a second remote relay (314). The publication request includes a message string characterized by a pattern. The second remote relay is one of a number of remote relays that are in communication with the central relays illustrated in
All of the central relays in the first set of central relays (including the first central relay) received the subscription message. However, none of the central relays in the second set of central relays (including the second central relay) received the subscription message. Thus, when the publication message is received by the first central relay, it is able to determine that the target matches at least a portion of the pattern (318). On the other hand, since the central relays in the second set of central relays did not receive the publication message, no match is found between the pattern and the targets stored in the central relays of the second set of central relays. Of course, if at some previous time, another remote relay had submitted a subscription message including the target to the second set of central relays, the second central relay would determine a match in a manner similar to the first central relay. However, in the method illustrated in
After determining a match, the first central relay transmits the message string to the first remote relay in response to determining that the first remote relay is interested in the message type associated with the publication message (320). Although in this particular example, the publication message is sent only to the first remote relay, one of skill in the art will appreciate that the publication message can be sent to multiple remote relays by the first central relay. For example, if the first central relay had received subscription messages with the same target from 15 of 90 remote relays, then when a publication message having a pattern partially or wholly matching the target is received, the first central relay would then transmit the publication message or a variant thereof to the 15 remote relays that had subscribed for this particular message type. One of ordinary skill in the art would recognize many variations, modifications, and alternatives.
At the first remote relay, a determination is made that the target matches at least a portion of the pattern (322). Based on the match, the first remote relay transmits the message string to the first client (324). Thus, the first client is able to receive the desired information in response to the initial subscription request.
It should be noted that although a single subscription request and a single publication request are used in the method illustrated in
It should be appreciated that the specific steps illustrated in
Alternatively, multiple requests can be bundled by the remote relay before transmission in a batch mode of operation. After recording the subscription, if the remote relay is in a layer of the hierarchy below a remote relay (e.g., Remote Relay Level 2), the subscription message will be forwarded to a remote relay in a layer of the hierarchy closer to the central relays. If the remote relay is in a layer of the hierarchy adjacent to the central relays (e.g., Remote Relay Level 1), the remote relay will transmit a subscription message to each central relay in one set of central relays.
Continuing in the first row of the chart, if a subscription request is received by a central relay, the subscription will be recorded. Thus, when publication messages are received, the publication message, some portions thereof, or a variant thereof, can be transmitted to remote relays based on the information recorded by the central relay. Typically, the identity of the remote relay and the target are included in the subscription request.
The second row of the chart relates to receipt of a publication request from a remote client. The remote relay will forward a publication message related to the publication request to one central relay in each set of central relays. The publication message can be the publication request received from a remote client, a portion of the publication request, a variant of the publication request, or the like. As an example, the message string from the publication request could be forwarded to the central relays. The right column of the second row is blank because in one implementation, no remote clients are directly connected to central relays. In this implementation, all remote clients connect to central relays through a remote relay and publication requests are thus not received at a central relay from a remote client. In other implementations, remote clients can be directly connected to central relays without connection through a remote relay.
The third row of the chart relates to receipt of a publication message from a remote relay. If the publication message is received at a remote relay in the hierarchy adjacent to a central relay (i.e., from a remote relay at a lower level of the hierarchy), the publication message will be forwarded to one central relay in each set of central relays. This process is illustrated by Process 5 in
The fourth row of the chart relates to receipt of a publication message from a central relay. When a remote relay adjacent to remote clients in the hierarchy receives such a publication message, it will transmit the publication message to remote clients that have subscribed to the particular message type. As discussed in relation to
The processor 512 is coupled to the memory 516 in order to store and access stored information for use during operation of the hierarchical publish/subscribe system. The memory (also referred to as a database or a computer readable medium) 516 can be local or distributed as appropriate to the particular application. An example of memory is a hard drive, flash memory, or the like. An optional input/output interface 518 is provided to facilitate control of the remote relay by a system operator. The optional I/O interface 518 also provides a mechanism for delivering performance reports to a system operator, other suitable personnel, or suitable computer systems. More typically, the remote relay is controlled through the communication module 514, through which a system operator can interact with the remote relay.
The communications module 514 also provides for communication between the remote relay and remote clients 520, other remote relays 522, and/or central relays 524.
It is also understood that the examples and embodiments described herein are for illustrative purposes only and that various modifications or changes in light thereof will be suggested to persons skilled in the art and are to be included within the spirit and purview of this application and scope of the appended claims.
This application is a continuation of U.S. Patent Application having Ser. No. 12/615,205, filed on Nov. 9, 2009 the entirety of which is incorporated by reference herein.
Number | Name | Date | Kind |
---|---|---|---|
6202093 | Bolam et al. | Mar 2001 | B1 |
6334151 | Bolam et al. | Dec 2001 | B1 |
6336119 | Banavar et al. | Jan 2002 | B1 |
6519629 | Harvey et al. | Feb 2003 | B2 |
6578066 | Logan et al. | Jun 2003 | B1 |
6829230 | Tiuri | Dec 2004 | B1 |
7133869 | Bryan et al. | Nov 2006 | B2 |
7280999 | Chung et al. | Oct 2007 | B2 |
7310686 | Uysal | Dec 2007 | B2 |
7406537 | Cullen | Jul 2008 | B2 |
7546368 | Drees et al. | Jun 2009 | B2 |
7631101 | Sullivan et al. | Dec 2009 | B2 |
7685270 | Vermeulen et al. | Mar 2010 | B1 |
7694016 | Halley | Apr 2010 | B2 |
7725602 | Liu et al. | May 2010 | B2 |
7734815 | Leighton et al. | Jun 2010 | B2 |
7761570 | Halley | Jul 2010 | B1 |
7769826 | Gustafsson | Aug 2010 | B2 |
7814202 | Drees et al. | Oct 2010 | B2 |
7925747 | Kirwan et al. | Apr 2011 | B2 |
7925782 | Sivasubramanian et al. | Apr 2011 | B2 |
7930393 | Baumback et al. | Apr 2011 | B1 |
7933951 | Sullivan et al. | Apr 2011 | B2 |
8982882 | Gallant et al. | Mar 2015 | B2 |
20020129354 | Bryan et al. | Sep 2002 | A1 |
20030012215 | Novaes | Jan 2003 | A1 |
20030084057 | Balogh | May 2003 | A1 |
20030084074 | Balogh et al. | May 2003 | A1 |
20030084075 | Balogh et al. | May 2003 | A1 |
20030208539 | Gildenblat et al. | Nov 2003 | A1 |
20040039798 | Hotz et al. | Feb 2004 | A1 |
20040076155 | Yajnik et al. | Apr 2004 | A1 |
20040181588 | Wang et al. | Sep 2004 | A1 |
20040194102 | Neerdaels | Sep 2004 | A1 |
20040254926 | Balogh | Dec 2004 | A1 |
20050027882 | Sullivan et al. | Feb 2005 | A1 |
20050105513 | Sullivan et al. | May 2005 | A1 |
20050108257 | Ishii et al. | May 2005 | A1 |
20060031432 | Patrick et al. | Feb 2006 | A1 |
20060059253 | Goodman et al. | Mar 2006 | A1 |
20060085507 | Zhao et al. | Apr 2006 | A1 |
20060167968 | Reynolds et al. | Jul 2006 | A1 |
20060235885 | Steele et al. | Oct 2006 | A1 |
20070061282 | Ganguly et al. | Mar 2007 | A1 |
20070070820 | Gallant | Mar 2007 | A1 |
20070088711 | Craggs et al. | Apr 2007 | A1 |
20070100808 | Balogh | May 2007 | A1 |
20070150596 | Miller et al. | Jun 2007 | A1 |
20070294419 | Ulevitch | Dec 2007 | A1 |
20080059152 | Fridman et al. | Mar 2008 | A1 |
20080071909 | Young et al. | Mar 2008 | A1 |
20080133646 | Azulai | Jun 2008 | A1 |
20080133729 | Fridman et al. | Jun 2008 | A1 |
20080155254 | Stradling | Jun 2008 | A1 |
20080201413 | Sullivan et al. | Aug 2008 | A1 |
20080256166 | Branson et al. | Oct 2008 | A1 |
20080256553 | Cullen | Oct 2008 | A1 |
20080260119 | Marathe et al. | Oct 2008 | A1 |
20080307436 | Hamilton | Dec 2008 | A1 |
20090044246 | Sheehan et al. | Feb 2009 | A1 |
20090063664 | Tiberio, Jr. | Mar 2009 | A1 |
20090106211 | Balogh | Apr 2009 | A1 |
20090106390 | Kirwan, Jr. et al. | Apr 2009 | A1 |
20090138572 | Banks et al. | May 2009 | A1 |
20090157889 | Treuhaft | Jun 2009 | A1 |
20090235359 | Abdulhayoglu et al. | Sep 2009 | A1 |
20090282027 | Subotin et al. | Nov 2009 | A1 |
20090282028 | Subotin et al. | Nov 2009 | A1 |
20090282038 | Subotin et al. | Nov 2009 | A1 |
20100030897 | Strading | Feb 2010 | A1 |
20100077462 | Joffe et al. | Mar 2010 | A1 |
20100082748 | Banks et al. | Apr 2010 | A1 |
20100138559 | Sullivan et al. | Jun 2010 | A1 |
20100218040 | Bodmer et al. | Aug 2010 | A1 |
20100257266 | Holmes et al. | Oct 2010 | A1 |
20100274836 | Orentas et al. | Oct 2010 | A1 |
20100274970 | Treuhaft et al. | Oct 2010 | A1 |
20100287532 | Smith et al. | Nov 2010 | A1 |
20100291950 | Lin et al. | Nov 2010 | A1 |
20100318858 | Essawi et al. | Dec 2010 | A1 |
20100333111 | Kothamasu et al. | Dec 2010 | A1 |
20110022678 | Smith et al. | Jan 2011 | A1 |
20110029662 | Drees et al. | Feb 2011 | A1 |
20110035469 | Smith et al. | Feb 2011 | A1 |
20110035497 | Daly et al. | Feb 2011 | A1 |
20110047292 | Gould et al. | Feb 2011 | A1 |
20110051728 | Bhogavilli et al. | Mar 2011 | A1 |
20110099232 | Gupta et al. | Apr 2011 | A1 |
20110106891 | Gallant et al. | May 2011 | A1 |
20110110267 | Gallant | May 2011 | A1 |
20110161289 | Pei et al. | Jun 2011 | A1 |
20130024527 | Miller et al. | Jan 2013 | A1 |
20130024528 | Gallant et al. | Jan 2013 | A1 |
20130024529 | Gallant et al. | Jan 2013 | A1 |
Number | Date | Country |
---|---|---|
2007078283 | Jul 2007 | WO |
2011053847 | May 2011 | WO |
Entry |
---|
Notice of Allowance dated Nov. 7, 2014, U.S. Appl. No. 12/615,205, filed Nov. 9, 2009, pp. 1-9. |
Non-Final Office Action dated Aug. 27, 2014, U.S. Appl. No. 13/534,634, filed Jun. 27, 2012, pp. 1-41. |
Non-Final Office Action dated Aug. 27, 2014, U.S. Appl. No. 13/534,732, filed Jun. 27, 2012, pp. 1-38. |
Extended European Search Report dated Jan. 23, 2014, European Application No. 13173188.7, pp. 1-11. |
Non-Final Office Action dated Jan. 15, 2014, U.S. Appl. No. 13/534,732, filed Jun. 27, 2012, pp. 1-50. |
Non-Final Office Action dated Jan. 3, 3014, U.S. Appl. No. 13/534,634, filed Jun. 27, 2012, pp. 1-46. |
European Search Report dated Oct. 14, 2013, European Application No. 13173260.4, filed Jun. 21, 2013, pp. 1-4. |
European Search Report dated Oct. 17, 2013, European Application No. 13173251.3, filed Jun. 21, 2013, pp. 1-6. |
Birman et al., “Exploiting Virtual Synchrony in Distributed Systems”, ACM SIFOPS Operating Systems Review, Nov. 1987, 21(5), pp. 123-138. |
International Search Report and Written Opinion dated Dec. 23, 2010, International Application No. PCT/US2010/054833, filed Oct. 29, 2010, pp. 1-7. |
Supplemental European Search Report dated May 6, 2013, European Application No. 10828717.8, filed Sep. 22, 2010, pp. 1-7. |
Final Office Action dated Sep. 24, 2012, U.S. Appl. No. 12/615,205, filed Nov. 9, 2009, pp. 1-18. |
Non-Final Office Action dated May 11, 2012, U.S. Appl. No. 12/615,205, filed Nov. 9, 2009, pp. 1-21. |
Author Unknown, International Search Report and Written Opinion dated Nov. 23, 2010, International Application No. PCT/US2010/049872, filed Sep. 22, 2010, pp. 1-9. |
Author Unknown, Wikipedia entry on Publish/Subscribe, entry first appeared Dec. 28, 2007, retrieved from the Internet: <<http://en.widipedia.org/wiki/Publish/subscribe>>, pp. 1-3. |
Non-Final Office Action dated Mar. 18, 2015, U.S. Appl. No. 13/534,786, filed Jun. 27, 2012, pp. 1-27. |
Notice of Allowance dated Jun. 5, 2015, U.S. Appl. No. 13/534,732, filed Jun. 27, 2012, pp. 1-40. |
Non-Final Office Action dated May 28, 2015, U.S. Appl. No. 13/534,634, filed Jun. 27, 2012, pp. 1-29. |
Number | Date | Country | |
---|---|---|---|
20150195350 A1 | Jul 2015 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 12615205 | Nov 2009 | US |
Child | 14659119 | US |