US20150026277A1 - Method and system for message processing - Google Patents
Method and system for message processing Download PDFInfo
- Publication number
- US20150026277A1 US20150026277A1 US14/452,838 US201414452838A US2015026277A1 US 20150026277 A1 US20150026277 A1 US 20150026277A1 US 201414452838 A US201414452838 A US 201414452838A US 2015026277 A1 US2015026277 A1 US 2015026277A1
- Authority
- US
- United States
- Prior art keywords
- message
- subscriber
- group
- node
- subscriber group
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Abandoned
Links
- 238000012545 processing Methods 0.000 title claims abstract description 47
- 238000000034 method Methods 0.000 title claims description 41
- 230000006870 function Effects 0.000 claims description 16
- 238000004590 computer program Methods 0.000 claims description 4
- 238000010586 diagram Methods 0.000 description 4
- 230000005540 biological transmission Effects 0.000 description 3
- 238000013507 mapping Methods 0.000 description 2
- 238000012986 modification Methods 0.000 description 2
- 230000004048 modification Effects 0.000 description 2
- 238000003672 processing method Methods 0.000 description 2
- 230000002411 adverse Effects 0.000 description 1
- 238000004891 communication Methods 0.000 description 1
- 239000004557 technical material Substances 0.000 description 1
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L51/00—User-to-user messaging in packet-switching networks, transmitted according to store-and-forward or real-time protocols, e.g. e-mail
- H04L51/04—Real-time or near real-time messaging, e.g. instant messaging [IM]
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/50—Network services
- H04L67/55—Push-based network services
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/30—Information retrieval; Database structures therefor; File system structures therefor of unstructured textual data
- G06F16/33—Querying
- G06F16/335—Filtering based on additional data, e.g. user or group profiles
-
- G06F17/30699—
Definitions
- Some existing web services systems use a publish-subscribe model for handling events in a system.
- a typical system includes a message distributor, message subscribers and a middleware.
- Data of messages are transmitted between the message distributor and the message subscribers via the middleware.
- the message distributor may distribute various types of messages relating to a variety of topics.
- the message subscribers may subscribe for the messages of interest.
- the middleware may transmit the messages of a topic distributed by the message distributor to the message subscribers that have subscribed for a particular message topic. Messages of the same topic may be subscribed by multiple different message subscribers. Different message subscribers may process the received messages differently. For example, two message subscribers, Subscriber A and Subscriber B, subscribe to the same topic, e.g. Topic A, each of the two message subscribers may process the received messages of Topic A in its own manner.
- a message distributor such as a transaction handling system may send a notification message notifying the success of the transaction.
- a message subscriber such as a transaction log server may subscribe for the notification message so as to record transaction logs, and another message subscriber such as a seller notification server may also subscribe for the notification message so as to notify the seller that a product has been sold. That is, the two servers may process the same message differently.
- more than one subscriber in the service systems may subscribe for messages of the same topic.
- a middleware is used to transmit the messages of the same topic to the more than one subscriber.
- each message subscriber is formed by a single node, which means that only one device can be used to provide services. As the amount of data to be processed increases, such typical systems often no longer meet the requirements of the large amount of data for several reasons.
- the message subscriber may be unable to receive the subscribed messages from the middleware or may be unable to process the subscribed messages even if the messages are received. In such cases, message processing of the message subscriber is interrupted, thereby adversely affecting the processing of other systems associated with the message subscriber.
- a single node may be incapable of processing large message traffic. Therefore, when the amount of messages is too large for a single node, hardware upgrade may be needed to accommodate a large amount of data.
- FIG. 1 is a block diagram illustrating an embodiment of a message processing system.
- FIG. 2 is a block diagram illustrating another embodiment of a message processing system.
- FIG. 3 is a flow chart illustrating a message subscription procedure of a subscriber according to an embodiment of a message processing system.
- FIG. 4 is a flow chart illustrating an embodiment of a message processing procedure.
- the invention can be implemented in numerous ways, including as a process; an apparatus; a system; a composition of matter; a computer program product embodied on a computer readable storage medium; and/or a processor, such as a processor configured to execute instructions stored on and/or provided by a memory coupled to the processor.
- these implementations, or any other form that the invention may take, may be referred to as techniques.
- the order of the steps of disclosed processes may be altered within the scope of the invention.
- a component such as a processor or a memory described as being configured to perform a task may be implemented as a general component that is temporarily configured to perform the task at a given time or a specific component that is manufactured to perform the task.
- the term ‘processor’ refers to one or more devices, circuits, and/or processing cores configured to process data, such as computer program instructions.
- FIG. 1 is a block diagram illustrating an embodiment of a message processing system.
- the message processing system includes a message distributor U 11 , a middleware U 12 and a number of message subscribers U 13 .
- the message distributor, the middleware, and the message subscribers are implemented using devices such as servers with appropriate software.
- the devices are connected on a wired, wireless, or mixed network such as a local area network (LAN) or a wide area network (WAN).
- LAN local area network
- WAN wide area network
- the message distributor U 11 and the message subscribers U 13 are connected to a server implementing the middleware U 12 .
- Messages generated by the message distributor (for example, messages generated by transaction servers that process user transactions) are sent to the middleware, which re-transmits the message to appropriate subscriber(s).
- message subscribers U 13 are divided into groups, e.g. subscriber groups A, B, etc., as shown in FIG. 1 , according to the functions of the subscribers.
- groups e.g. subscriber groups A, B, etc.
- subscriber group A several log servers that record transaction information
- subscriber group B several seller notification servers
- Each group is assigned a unique group identifier (group ID) which is used to uniquely identify the group.
- group ID group identifier
- Each group of subscribers may include one or more nodes. The nodes in the same group share the same group ID.
- the information includes a connection ID and the group ID of the subscriber node.
- the information includes the IDs and/or addresses of the subscriber node and the middleware server.
- the message distributor U 11 is configured to distribute messages onto a server of the middleware U 12 .
- the middleware U 12 searches, according to the message type of the received message, for the group ID(s) corresponding to the message type. If any group ID that corresponds to the message type is located, the middleware U 12 may select a node among the nodes of the group having the searched group ID, and push the message to the selected node. Since the messages of the same topic may be subscribed by several different groups of subscribers, a message may be transmitted to several groups of subscribers, and only be received by one node in each of the groups.
- a subscriber node in the subscriber group is configured to process received messages.
- the nodes in the same group of subscribers may process the same message in the same way, while the nodes in different groups may process the received message differently.
- one message is processed by only one node within the group.
- each device/node in a subscriber group comprising transaction log servers is configured to use a message announcing the success of transaction to record transaction logs, and each device/node in a subscriber group comprising seller notification servers may use the same message to notify the seller that some product is sold.
- the message processing system further includes a database U 14 .
- database U 14 is connected to middleware U 12 and is adapted to store the message received by the middleware, the corresponding relationships between each message type and identification of each subscriber group, and of the corresponding relationships of nodes and their respective group identifiers and subscriber group.
- the information is stored in the internal storage structure within the server of the middleware U 12 . Other appropriate arrangements can be used in different embodiments.
- the system As described above, in the system a plurality of nodes are configured in each group of message subscribers to share the work load of a message distributor. Therefore, the system thus configured has a good fault-tolerant ability and is capable of processing large amounts of message traffic.
- one or more new nodes may be added to a subscriber group to share the processing load. For example, suppose a subscriber group has 5 nodes and the messages of a certain topic may be generated at a rate of 500 per seconds, all of the 5 nodes may be used to process the 500 messages, and in this case, each node may process 100 messages per second. Even if one of the 5 nodes fails, there remain the other 4 nodes which are capable of processing the 500 messages. In this way, the message processing of the whole system will not be interrupted despite the failure of one node.
- the subscriber nodes obtain the addresses and ports information of the available middleware servers.
- Each node of a subscriber group may be connected to a server of the middleware in a long connection mode.
- the employed communication protocol is the Transmission Control Protocol (TCP)
- TCP Transmission Control Protocol
- the long connection is TCP long connection.
- a “long connection” is distinguished from a “short connection”.
- short connection mode the connection established between two devices is disconnected as soon as processing is finished.
- the long connection mode a list of connections is maintained, which includes information about the identifier of each group and its respective long connection information (such as the name and/or address of each subscriber node within the group and the name/address the respective middleware server in a long connection).
- the established connection is maintained after the processing is finished.
- the server of the middleware may search for the connection(s) to the node(s) of the subscriber group(s) that has subscribed the message among the current connections established to the middleware, and push the message to the node(s) of subscriber(s).
- the long connection has good real-time performance by avoiding the repeated establishment and disconnection of the connections.
- the messages can be transmitted quickly in the long connection mode. In the event that the server is restarted or there is any network connection problem, the subscriber node will attempt to reestablish the TCP long connection.
- the number of nodes in each subscriber group may be adjusted dynamically. That is, one or more nodes may be added into or deleted from a subscriber group as required. When the message traffic becomes heavier and the nodes in a subscriber group are not sufficient to process the messages, one or more new nodes may be added. To add new nodes, the group ID of this subscriber group is used to associate the new nodes with the server of the middleware. If too many nodes are included in a subscriber group, nodes may be removed from the group by stopping the nodes to be removed from processing messages.
- the message distributors may also be divided into groups. Each distributor group may be assigned a unique group ID and may include one or more nodes. The node in the same group shares the same group ID. Each node is connected to a middleware server and the connection is identified using the group ID. When a message is ready to be distributed, a message distributor node within its group is selected to transmit the message. In embodiments where multiple message distributor nodes are available, a node may be selected at random, or a least busy node is selected for message transmission. In this way, the distribution of the message is uninterrupted when a node in the distributor group fails.
- FIG. 2 is a block diagram illustrating another embodiment of a message processing system.
- the message subscribers are divided into a group A and a group B, each of which includes 2 nodes; the message distributors are divided into a group C and a group D, each of which also includes 2 nodes.
- Different arrangements of groups and nodes can be used in other embodiments.
- the message processing system implements a subscription procedure and a message processing procedure. Examples of the two procedures are described below.
- FIG. 3 is a flow chart illustrating a message subscription procedure of a subscriber according to an embodiment of a message processing system.
- Process 300 may be implemented, for example, on a middleware such as U 12 of FIG. 1 .
- subscription information is received from a message subscriber, indicating that the message subscriber is subscribing to a certain topic of interest.
- the message subscriber may subscribe on behalf of a subscriber group.
- the subscription information includes the group ID as well as the message type to be subscribed by the subscriber group.
- subscription information such as the mapping of the group ID and the message type subscribed by the message subscriber is recorded.
- the recorded information is stored, for example in a memory/storage on the middleware or in a database accessible by the middleware.
- an acknowledgement message indicating the success of the subscription to the message subscriber is sent.
- a negative acknowledgement is sent so that the message subscriber may resend the subscription information.
- Process 300 may be repeated for the message subscriber to subscribe to multiple message types.
- the middleware may push messages to the message subscriber, particularly, may push the messages to a node selected within the subscriber group of the message subscriber.
- FIG. 4 is a flow chart illustrating an embodiment of a message processing procedure.
- Process 400 may be implemented on a middleware such as U 12 of FIG. 1 .
- a message sent by a message distributor is received.
- an acknowledgement is sent to the message distributor indicating that the distribution was successful.
- the message is re-sent to the appropriate subscribers as soon as it is received.
- a task queue is maintained to manage the order of messages to be processed. Thus, the message is stored and a message push task is put in a task queue.
- the message push task is taken from the task queue, and the group ID(s) of one or more corresponding subscriber groups is located according to the message type. For example, in embodiments where subscription information is stored in a mapping table that maps message types to appropriate group IDs, the message type of the message received is used as an index into the table for looking up the corresponding subscriber group ID(s).
- each of the corresponding subscriber groups found to be subscribing to the received message type is processed.
- a node with a connection to the middleware is located for each subscriber group subscribing to the message type.
- connections of subscriber groups subscribing to the present message type are located. If only one connection is found, it is used directly. If multiple connections are found, a connection may be selected randomly from these connections. In some embodiments, rather than randomly choosing a node/connection, each node in the subscriber group with an active connection is polled to determine whether it is idle. The idle node is selected for message transmission.
- the message is transmitted to the selected node(s) via respective connection(s).
- the node Upon receipt of the message, the node processes the message and takes appropriate actions. For example, where a transaction success message is received by a log server and a seller notification server, the former updates log information and the latter sends out email notification to the seller.
- each node of the subscriber groups is connected to the server of the middleware in a long connection mode where the connection remains open once it is established. This way, when the server of the middleware receives a message, it may search for the connection(s) to the node(s) of the subscriber(s) which subscribes for the message among the current connections, and push the message to the node(s) via the searched connection(s).
- each distributor group may include one or more nodes.
- Each distributor group selects one node to distribute a message to the middleware. In this way, the distribution of the message can not be interrupted even if a node in the distributor group fails.
- a plurality of nodes in the group may be used, so as to share the processing load of the distributor.
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Computational Linguistics (AREA)
- Databases & Information Systems (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Data Mining & Analysis (AREA)
- Information Transfer Between Computers (AREA)
- Mobile Radio Communication Systems (AREA)
- Data Exchanges In Wide-Area Networks (AREA)
Abstract
Processing a message includes receiving at a message processing system the message that is distributed by a message distributor, the message having a message type, based at least in part on the message type, locating among a plurality of subscriber groups a subscriber group that subscribes to the message type, each of the plurality of subscriber groups having a unique identifier and comprising one or more message subscriber nodes, at least some of the one or more message subscriber nodes in each of the plurality of subscriber groups being connected to the message processing system, and transmitting the message to a message subscriber node that belongs to the subscriber group that is located.
Description
- This application is a continuation of co-pending U.S. patent application Ser. No. 12/456,223, entitled METHOD AND SYSTEM FOR MESSAGE PROCESSING filed Jun. 12, 2009 which is incorporated herein by reference for all purposes, which claims priority to People's Republic of China Patent Application No. 200810214332.4 entitled MESSAGE PROCESSING METHOD AND SYSTEM filed Sep. 2, 2008 which is incorporated herein by reference for all purposes.
- Some existing web services systems use a publish-subscribe model for handling events in a system. A typical system includes a message distributor, message subscribers and a middleware.
- Data of messages are transmitted between the message distributor and the message subscribers via the middleware. The message distributor may distribute various types of messages relating to a variety of topics. The message subscribers may subscribe for the messages of interest. The middleware may transmit the messages of a topic distributed by the message distributor to the message subscribers that have subscribed for a particular message topic. Messages of the same topic may be subscribed by multiple different message subscribers. Different message subscribers may process the received messages differently. For example, two message subscribers, Subscriber A and Subscriber B, subscribe to the same topic, e.g. Topic A, each of the two message subscribers may process the received messages of Topic A in its own manner.
- For example, during an electronic transaction, when the transaction is created successfully, a message distributor such as a transaction handling system may send a notification message notifying the success of the transaction. A message subscriber such as a transaction log server may subscribe for the notification message so as to record transaction logs, and another message subscriber such as a seller notification server may also subscribe for the notification message so as to notify the seller that a product has been sold. That is, the two servers may process the same message differently.
- In some application scenarios, more than one subscriber in the service systems may subscribe for messages of the same topic. In such cases, a middleware is used to transmit the messages of the same topic to the more than one subscriber. In a typical system, each message subscriber is formed by a single node, which means that only one device can be used to provide services. As the amount of data to be processed increases, such typical systems often no longer meet the requirements of the large amount of data for several reasons.
- First, when a message subscriber node fails, the message subscriber may be unable to receive the subscribed messages from the middleware or may be unable to process the subscribed messages even if the messages are received. In such cases, message processing of the message subscriber is interrupted, thereby adversely affecting the processing of other systems associated with the message subscriber.
- Second, a single node may be incapable of processing large message traffic. Therefore, when the amount of messages is too large for a single node, hardware upgrade may be needed to accommodate a large amount of data.
- Various embodiments of the invention are disclosed in the following detailed description and the accompanying drawings.
-
FIG. 1 is a block diagram illustrating an embodiment of a message processing system. -
FIG. 2 is a block diagram illustrating another embodiment of a message processing system. -
FIG. 3 is a flow chart illustrating a message subscription procedure of a subscriber according to an embodiment of a message processing system. -
FIG. 4 is a flow chart illustrating an embodiment of a message processing procedure. - The invention can be implemented in numerous ways, including as a process; an apparatus; a system; a composition of matter; a computer program product embodied on a computer readable storage medium; and/or a processor, such as a processor configured to execute instructions stored on and/or provided by a memory coupled to the processor. In this specification, these implementations, or any other form that the invention may take, may be referred to as techniques. In general, the order of the steps of disclosed processes may be altered within the scope of the invention. Unless stated otherwise, a component such as a processor or a memory described as being configured to perform a task may be implemented as a general component that is temporarily configured to perform the task at a given time or a specific component that is manufactured to perform the task. As used herein, the term ‘processor’ refers to one or more devices, circuits, and/or processing cores configured to process data, such as computer program instructions.
- A detailed description of one or more embodiments of the invention is provided below along with accompanying figures that illustrate the principles of the invention. The invention is described in connection with such embodiments, but the invention is not limited to any embodiment. The scope of the invention is limited only by the claims and the invention encompasses numerous alternatives, modifications and equivalents. Numerous specific details are set forth in the following description in order to provide a thorough understanding of the invention. These details are provided for the purpose of example and the invention may be practiced according to the claims without some or all of these specific details. For the purpose of clarity, technical material that is known in the technical fields related to the invention has not been described in detail so that the invention is not unnecessarily obscured.
-
FIG. 1 is a block diagram illustrating an embodiment of a message processing system. As shown inFIG. 1 , the message processing system includes a message distributor U11, a middleware U12 and a number of message subscribers U13. In some embodiments, the message distributor, the middleware, and the message subscribers are implemented using devices such as servers with appropriate software. The devices are connected on a wired, wireless, or mixed network such as a local area network (LAN) or a wide area network (WAN). In this example, the message distributor U11 and the message subscribers U13 are connected to a server implementing the middleware U12. Messages generated by the message distributor (for example, messages generated by transaction servers that process user transactions) are sent to the middleware, which re-transmits the message to appropriate subscriber(s). - In this example, message subscribers U13 are divided into groups, e.g. subscriber groups A, B, etc., as shown in
FIG. 1 , according to the functions of the subscribers. For example, several log servers that record transaction information are grouped as subscriber group A, and several seller notification servers are grouped as subscriber group B. Each group is assigned a unique group identifier (group ID) which is used to uniquely identify the group. Each group of subscribers may include one or more nodes. The nodes in the same group share the same group ID. Whenever a connection is made between a subscriber node and the middleware, information about the connection is added to a list. In some embodiments, the information includes a connection ID and the group ID of the subscriber node. In some embodiments, the information includes the IDs and/or addresses of the subscriber node and the middleware server. - The message distributor U11 is configured to distribute messages onto a server of the middleware U12. The middleware U12 searches, according to the message type of the received message, for the group ID(s) corresponding to the message type. If any group ID that corresponds to the message type is located, the middleware U12 may select a node among the nodes of the group having the searched group ID, and push the message to the selected node. Since the messages of the same topic may be subscribed by several different groups of subscribers, a message may be transmitted to several groups of subscribers, and only be received by one node in each of the groups.
- A subscriber node in the subscriber group is configured to process received messages. The nodes in the same group of subscribers may process the same message in the same way, while the nodes in different groups may process the received message differently. In a given group, one message is processed by only one node within the group. For example, during an electronic transaction, each device/node in a subscriber group comprising transaction log servers is configured to use a message announcing the success of transaction to record transaction logs, and each device/node in a subscriber group comprising seller notification servers may use the same message to notify the seller that some product is sold.
- In some embodiments, the message processing system further includes a database U14. In this example, database U14 is connected to middleware U12 and is adapted to store the message received by the middleware, the corresponding relationships between each message type and identification of each subscriber group, and of the corresponding relationships of nodes and their respective group identifiers and subscriber group. In some embodiments, the information is stored in the internal storage structure within the server of the middleware U12. Other appropriate arrangements can be used in different embodiments.
- As described above, in the system a plurality of nodes are configured in each group of message subscribers to share the work load of a message distributor. Therefore, the system thus configured has a good fault-tolerant ability and is capable of processing large amounts of message traffic.
- When one node in a subscriber group fails, the other nodes in the same subscriber group continue to process the received message(s). In this way, messages are processed without interruption, giving the overall system good fault-tolerance.
- In some embodiments, when a large amount of traffic is received, one or more new nodes may be added to a subscriber group to share the processing load. For example, suppose a subscriber group has 5 nodes and the messages of a certain topic may be generated at a rate of 500 per seconds, all of the 5 nodes may be used to process the 500 messages, and in this case, each node may process 100 messages per second. Even if one of the 5 nodes fails, there remain the other 4 nodes which are capable of processing the 500 messages. In this way, the message processing of the whole system will not be interrupted despite the failure of one node.
- In some embodiments, the subscriber nodes obtain the addresses and ports information of the available middleware servers. Each node of a subscriber group may be connected to a server of the middleware in a long connection mode. For example, if the employed communication protocol is the Transmission Control Protocol (TCP), the long connection is TCP long connection. As used herein, a “long connection” is distinguished from a “short connection”. In the short connection mode, the connection established between two devices is disconnected as soon as processing is finished. In the long connection mode, a list of connections is maintained, which includes information about the identifier of each group and its respective long connection information (such as the name and/or address of each subscriber node within the group and the name/address the respective middleware server in a long connection). The established connection is maintained after the processing is finished. With the long connection, when there is a message to be transmitted, the server of the middleware may search for the connection(s) to the node(s) of the subscriber group(s) that has subscribed the message among the current connections established to the middleware, and push the message to the node(s) of subscriber(s). The long connection has good real-time performance by avoiding the repeated establishment and disconnection of the connections. The messages can be transmitted quickly in the long connection mode. In the event that the server is restarted or there is any network connection problem, the subscriber node will attempt to reestablish the TCP long connection.
- In a system such as the one shown in
FIG. 1 , the number of nodes in each subscriber group may be adjusted dynamically. That is, one or more nodes may be added into or deleted from a subscriber group as required. When the message traffic becomes heavier and the nodes in a subscriber group are not sufficient to process the messages, one or more new nodes may be added. To add new nodes, the group ID of this subscriber group is used to associate the new nodes with the server of the middleware. If too many nodes are included in a subscriber group, nodes may be removed from the group by stopping the nodes to be removed from processing messages. - In some embodiments, there are multiple message distributors to provide better redundancy. The message distributors may also be divided into groups. Each distributor group may be assigned a unique group ID and may include one or more nodes. The node in the same group shares the same group ID. Each node is connected to a middleware server and the connection is identified using the group ID. When a message is ready to be distributed, a message distributor node within its group is selected to transmit the message. In embodiments where multiple message distributor nodes are available, a node may be selected at random, or a least busy node is selected for message transmission. In this way, the distribution of the message is uninterrupted when a node in the distributor group fails. In addition, when the message traffic to be distributed is heavy, a plurality of nodes in the group may be used, so as to share the processing load of the distributor.
FIG. 2 is a block diagram illustrating another embodiment of a message processing system. In this example, the message subscribers are divided into a group A and a group B, each of which includes 2 nodes; the message distributors are divided into a group C and a group D, each of which also includes 2 nodes. Different arrangements of groups and nodes can be used in other embodiments. - In some embodiments, the message processing system implements a subscription procedure and a message processing procedure. Examples of the two procedures are described below.
-
FIG. 3 is a flow chart illustrating a message subscription procedure of a subscriber according to an embodiment of a message processing system. -
Process 300 may be implemented, for example, on a middleware such as U12 ofFIG. 1 . At 301, subscription information is received from a message subscriber, indicating that the message subscriber is subscribing to a certain topic of interest. The message subscriber may subscribe on behalf of a subscriber group. The subscription information includes the group ID as well as the message type to be subscribed by the subscriber group. - at 302, subscription information such as the mapping of the group ID and the message type subscribed by the message subscriber is recorded. The recorded information is stored, for example in a memory/storage on the middleware or in a database accessible by the middleware.
- At 303, an acknowledgement message indicating the success of the subscription to the message subscriber is sent. In the event that the reception or recordation of the subscription information fails, a negative acknowledgement is sent so that the message subscriber may resend the subscription information.
Process 300 may be repeated for the message subscriber to subscribe to multiple message types. - After the message subscriber subscribes to messages according to the above procedure, the middleware may push messages to the message subscriber, particularly, may push the messages to a node selected within the subscriber group of the message subscriber.
-
FIG. 4 is a flow chart illustrating an embodiment of a message processing procedure.Process 400 may be implemented on a middleware such as U12 ofFIG. 1 . - At 401, a message sent by a message distributor is received.
- At 402, an acknowledgement is sent to the message distributor indicating that the distribution was successful. In some embodiments, the message is re-sent to the appropriate subscribers as soon as it is received. In some embodiments, a task queue is maintained to manage the order of messages to be processed. Thus, the message is stored and a message push task is put in a task queue.
- At 403, the message push task is taken from the task queue, and the group ID(s) of one or more corresponding subscriber groups is located according to the message type. For example, in embodiments where subscription information is stored in a mapping table that maps message types to appropriate group IDs, the message type of the message received is used as an index into the table for looking up the corresponding subscriber group ID(s).
- At 404, each of the corresponding subscriber groups found to be subscribing to the received message type is processed. In particular, a node with a connection to the middleware is located for each subscriber group subscribing to the message type. In embodiments where a list of active connections between the middleware and respective nodes in subscriber groups is maintained, connections of subscriber groups subscribing to the present message type are located. If only one connection is found, it is used directly. If multiple connections are found, a connection may be selected randomly from these connections. In some embodiments, rather than randomly choosing a node/connection, each node in the subscriber group with an active connection is polled to determine whether it is idle. The idle node is selected for message transmission.
- At 405, the message is transmitted to the selected node(s) via respective connection(s).
- Upon receipt of the message, the node processes the message and takes appropriate actions. For example, where a transaction success message is received by a log server and a seller notification server, the former updates log information and the latter sends out email notification to the seller.
- In some embodiments, each node of the subscriber groups is connected to the server of the middleware in a long connection mode where the connection remains open once it is established. This way, when the server of the middleware receives a message, it may search for the connection(s) to the node(s) of the subscriber(s) which subscribes for the message among the current connections, and push the message to the node(s) via the searched connection(s).
- In an embodiment, there may be one or more message distributors divided into one or more distributor groups. Each distributor group may include one or more nodes. Each distributor group selects one node to distribute a message to the middleware. In this way, the distribution of the message can not be interrupted even if a node in the distributor group fails. In addition, when the message traffic to be distributed is heavy, a plurality of nodes in the group may be used, so as to share the processing load of the distributor.
- The message processing methods and systems are described above according to some embodiments of the invention. The above particular embodiments are described as examples to illustrate the principle of the invention, so as to enable a better understanding of the idea and solutions of the invention. In addition, it will be appreciated that a person of ordinary skill in the art can recognize many variations or modifications to the embodiments and applications of the invention without departing from the disclosure of the invention. In summary, the invention is not limited to the above description.
- Although the foregoing embodiments have been described in some detail for purposes of clarity of understanding, the invention is not limited to the details provided. There are many alternative ways of implementing the invention. The disclosed embodiments are illustrative and not restrictive.
Claims (18)
1. (canceled)
2. A system, comprising:
a message distributor to send a message to a middleware server, the message having a message type, wherein the middleware server is connected to a first plurality of message subscriber nodes associated with a first subscriber group and to a second plurality of message subscriber nodes associated with a second subscriber group, wherein a message subscriber node of the first plurality of message subscriber nodes associated with the first subscriber group is configured to perform a first processing function and a message subscriber node of the second plurality of message subscriber nodes associated with the second subscriber group is configured to perform a second processing function, wherein the first processing function is different from the second processing function;
the middleware server to:
receive the message from the message distributor;
determine that the first subscriber group subscribes to the message type; and
transmit the message to a selected message subscriber node that belongs to the first subscriber group, wherein the selected message subscriber node is configured to process the message based at least in part on the first processing function associated with the first subscriber group; and
a memory coupled to the processor and configured to provide the processor with instructions.
3. The system of claim 2 , wherein the selected message subscriber node is randomly selected among the first plurality of message subscriber nodes associated with the first subscriber group.
4. The system of claim 2 , wherein the selected message subscriber node is selected to correspond to an idle message subscriber node in the first plurality of message subscriber nodes associated with the first subscriber group.
5. The system of claim 2 , wherein the middleware server is connected to the first plurality of message subscriber nodes associated with the first subscriber group and the second plurality of message subscriber nodes associated with the second subscriber group in a long connection mode.
6. The system of claim 5 , wherein the middleware server is further to connect to a newly added message subscriber node in the first subscriber group, the newly added message subscriber node being associated with the first subscriber group based on a unique identifier of the first subscriber group.
7. The system of claim 2 , wherein the system further includes a database to store a corresponding relationship of the message type and a unique identifier of the first subscriber group based at least in part on subscription information from a message subscriber.
8. The system of claim 2 , wherein in the event that a message subscriber node in the first plurality of message subscriber nodes fails, message subscriber nodes other than the failed message subscriber node in the first plurality of message subscriber nodes are to continue processing received messages.
9. The system of claim 2 , wherein a number of message subscriber nodes included in the first plurality of message subscriber nodes is configured to be dynamically adjusted based on message traffic volume.
10. A method, comprising:
sending a message to a middleware server, the message having a message type, wherein the middleware server is connected to a first plurality of message subscriber nodes associated with a first subscriber group and to a second plurality of message subscriber nodes associated with a second subscriber group, wherein a message subscriber node of the first plurality of message subscriber nodes associated with the first subscriber group is configured to perform a first processing function and a message subscriber node of the second plurality of message subscriber nodes associated with the second subscriber group is configured to perform a second processing function, wherein the first processing function is different from the second processing function;
receiving the message from the message distributor;
determining that the first subscriber group subscribes to the message type; and
transmitting the message to a selected message subscriber node that belongs to the first subscriber group, wherein the selected message subscriber node is configured to process the message based at least in part on the first processing function associated with the first subscriber group.
11. The method of claim 10 , wherein the selected message subscriber node is randomly selected among the first plurality of message subscriber nodes associated with the first subscriber group.
12. The method of claim 10 , wherein the selected message subscriber node is selected to correspond to an idle message subscriber node in the first plurality of message subscriber nodes associated with the first subscriber group.
13. The method of claim 10 , wherein the middleware server is connected to the first plurality of message subscriber nodes associated with the first subscriber group and to the second plurality of message subscriber nodes associated with the second subscriber group in a long connection mode.
14. The method of claim 13 , wherein the middleware server is further connected to a newly added message subscriber node in the first subscriber group, the newly added message subscriber node being associated with the first subscriber group based on a unique identifier of the first subscriber group.
15. The method of claim 10 further comprising storing a corresponding relationship of the message type and a unique identifier of the first subscriber group based at least in part on subscription information from a message subscriber.
16. The method of claim 10 , wherein in the event that a message subscriber node in the first plurality of message subscriber nodes fails, message subscriber nodes other than the failed message subscriber node in the first plurality of message subscriber nodes are configured to continue processing received messages.
17. The method of claim 10 , wherein a number of message subscriber nodes included in the first plurality of message subscriber nodes is configured to be dynamically adjusted based on message traffic volume.
18. A computer program product, the computer program product being embodied in a non-transitory computer readable storage medium and comprising instructions for:
sending a message to a middleware server, the message having a message type, wherein the middleware server is connected to a first plurality of message subscriber nodes associated with a first subscriber group and to a second plurality of message subscriber nodes associated with a second subscriber group, wherein a message subscriber node of the first plurality of message subscriber nodes associated with the first subscriber group is configured to perform a first processing function and a message subscriber node of the second plurality of message subscriber nodes associated with the second subscriber group is configured to perform a second processing function, wherein the first processing function is different from the second processing function;
receiving the message from the message distributor;
determining that the first subscriber group subscribes to the message type; and
transmitting the message to a selected message subscriber node that belongs to the first subscriber group, wherein the selected message subscriber node is configured to process the message based at least in part on the first processing function associated with the first subscriber group.
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US14/452,838 US20150026277A1 (en) | 2008-09-02 | 2014-08-06 | Method and system for message processing |
Applications Claiming Priority (4)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN200810214332.4 | 2008-09-02 | ||
CN2008102143324A CN101668031B (en) | 2008-09-02 | 2008-09-02 | Message processing method and message processing system |
US12/456,223 US8838703B2 (en) | 2008-09-02 | 2009-06-12 | Method and system for message processing |
US14/452,838 US20150026277A1 (en) | 2008-09-02 | 2014-08-06 | Method and system for message processing |
Related Parent Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US12/456,223 Continuation US8838703B2 (en) | 2008-09-02 | 2009-06-12 | Method and system for message processing |
Publications (1)
Publication Number | Publication Date |
---|---|
US20150026277A1 true US20150026277A1 (en) | 2015-01-22 |
Family
ID=41726920
Family Applications (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US12/456,223 Active 2029-09-19 US8838703B2 (en) | 2008-09-02 | 2009-06-12 | Method and system for message processing |
US14/452,838 Abandoned US20150026277A1 (en) | 2008-09-02 | 2014-08-06 | Method and system for message processing |
Family Applications Before (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US12/456,223 Active 2029-09-19 US8838703B2 (en) | 2008-09-02 | 2009-06-12 | Method and system for message processing |
Country Status (6)
Country | Link |
---|---|
US (2) | US8838703B2 (en) |
EP (1) | EP2321908B1 (en) |
JP (1) | JP5398836B2 (en) |
CN (1) | CN101668031B (en) |
HK (1) | HK1141171A1 (en) |
WO (1) | WO2010027394A1 (en) |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN107483327A (en) * | 2017-09-05 | 2017-12-15 | 江苏电力信息技术有限公司 | An Instant Messaging Method Based on Long Connection Service Independence |
CN110309002A (en) * | 2019-05-29 | 2019-10-08 | 北京达佳互联信息技术有限公司 | Message treatment method, device, electronic equipment and storage medium |
Families Citing this family (33)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102377686B (en) * | 2010-08-10 | 2015-07-01 | 阿里巴巴集团控股有限公司 | Message subscription system, method and device |
CN102469033B (en) * | 2010-11-01 | 2014-08-06 | 阿里巴巴集团控股有限公司 | Message subscription system and message sending method |
CN102469116B (en) * | 2010-11-05 | 2013-12-11 | 北京闪联云视信息技术有限公司 | Remote collaborative method and system thereof |
US20120131083A1 (en) * | 2010-11-24 | 2012-05-24 | Edward Wayne Goddard | Systems and methods for asynchronous notification using http |
US9251481B2 (en) * | 2011-06-13 | 2016-02-02 | Accenture Global Services Limited | Distributed metering and monitoring system |
CN102508722B (en) * | 2011-12-02 | 2015-04-08 | 中科方德软件有限公司 | Inter-process communication method under embedded environment |
EP3094116B1 (en) * | 2012-05-14 | 2018-04-18 | Huawei Technologies Co., Ltd. | Method and system for group communication, group server, and group member device |
CN105493444B (en) * | 2013-12-31 | 2019-08-27 | 华为技术有限公司 | A kind of network function virtualization NFV fault management device, device and method |
WO2015100611A1 (en) * | 2013-12-31 | 2015-07-09 | 华为技术有限公司 | Network function virtualisation nfv fault management apparatus, device, and method |
CN105591877A (en) * | 2014-10-23 | 2016-05-18 | 阿里巴巴集团控股有限公司 | Method, device and system for service message transmission |
CN105791082B (en) * | 2014-12-23 | 2019-08-02 | 阿里巴巴集团控股有限公司 | Method for message transmission and its device between computer cluster based on message-oriented middleware |
CN105072016B (en) * | 2015-07-03 | 2019-07-02 | 北京京东尚科信息技术有限公司 | For carrying out the method and apparatus for sorting out processing to message |
CN105187555B (en) * | 2015-09-29 | 2019-02-22 | 北京奇艺世纪科技有限公司 | A kind of message treatment method, apparatus and system |
CN106572146B (en) * | 2015-10-13 | 2020-03-17 | 腾讯科技(深圳)有限公司 | Message sending method and message sending device |
CN106603598B (en) * | 2015-10-15 | 2020-12-25 | 阿里巴巴集团控股有限公司 | Method and device for processing service request |
CN105677774B (en) * | 2015-12-30 | 2019-11-22 | 百度在线网络技术(北京)有限公司 | A kind of data event method for pushing and device |
US10419401B2 (en) | 2016-01-08 | 2019-09-17 | Capital One Services, Llc | Methods and systems for securing data in the public cloud |
CN106230922A (en) * | 2016-07-28 | 2016-12-14 | 上海斐讯数据通信技术有限公司 | A kind of news subscribing method, message production unit and message reception units |
CN106713328A (en) * | 2016-12-29 | 2017-05-24 | 北京奇虎科技有限公司 | Information processing method and apparatus based on long connection |
CN108282500A (en) * | 2017-01-05 | 2018-07-13 | 阿里巴巴集团控股有限公司 | Message issuance method, device and electronic equipment |
CN106953901B (en) * | 2017-03-10 | 2020-04-07 | 重庆邮电大学 | Cluster communication system and method for improving message transmission performance |
CN106878446A (en) * | 2017-03-10 | 2017-06-20 | 大盛微电科技股份有限公司 | The means of communication |
CN107026917A (en) * | 2017-06-16 | 2017-08-08 | 智者四海(北京)技术有限公司 | The method and system pushed for message |
CN107835203B (en) * | 2017-08-09 | 2020-07-10 | 平安壹钱包电子商务有限公司 | Message packet delivery method, device, storage medium and terminal |
CN110048927B (en) * | 2018-01-16 | 2020-12-15 | 华为技术有限公司 | Communication method and communication device |
CN109995873A (en) * | 2019-04-10 | 2019-07-09 | 阿里巴巴集团控股有限公司 | A kind of management client, equipment monitoring system and method |
US11108890B2 (en) | 2019-04-10 | 2021-08-31 | Advanced New Technologies Co., Ltd. | Management client and device monitoring |
CN110708312A (en) * | 2019-09-30 | 2020-01-17 | 交控科技股份有限公司 | Method and system for message transmission in ATS and ATS |
CN110718084B (en) * | 2019-10-10 | 2021-06-08 | 腾讯科技(深圳)有限公司 | Driving information transmission method, device, system, equipment and storage medium |
CN114168368A (en) * | 2021-12-13 | 2022-03-11 | 平安养老保险股份有限公司 | Method and device for processing message, computer equipment and storage medium |
CN114422569A (en) * | 2021-12-30 | 2022-04-29 | 天翼云科技有限公司 | Message pushing method and device of cloud desktop |
CN114513699B (en) * | 2022-04-19 | 2022-07-12 | 深圳市华曦达科技股份有限公司 | Method and device for preventing screen recording outside OTT television |
DE102023110890A1 (en) | 2023-04-27 | 2024-10-31 | Franken Systems Gmbh | 2-component adhesion primer for combination with liquid plastics |
Citations (10)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20020188761A1 (en) * | 2000-09-28 | 2002-12-12 | Chikirivao Bill S. | Data-type definition driven dynamic business component instantiation and execution framework |
US20030167326A1 (en) * | 2002-01-18 | 2003-09-04 | De Bonet Jeremy S. | Highly redundant, high-reliability and high-performance platform logging/billing generation and collection subsystem |
US20040240462A1 (en) * | 2003-05-27 | 2004-12-02 | Sun Microsystems, Inc. | Hashing based messaging approach to a cluster |
US20040258027A1 (en) * | 2003-06-23 | 2004-12-23 | Boris Tsybakov | Code channel management in a wireless communications system |
US20050076106A1 (en) * | 2003-09-23 | 2005-04-07 | Jesse Hummer | Asynchronous information retrieval |
US20050210109A1 (en) * | 2004-03-22 | 2005-09-22 | International Business Machines Corporation | Load balancing mechanism for publish/subscribe broker messaging system |
US20050262205A1 (en) * | 2004-04-30 | 2005-11-24 | Nikolov Radoslav I | Delivering messages in an enterprise messaging system using message selector hierarchy |
US20090064185A1 (en) * | 2007-09-03 | 2009-03-05 | International Business Machines Corporation | High-Performance XML Processing in a Common Event Infrastructure |
US7559065B1 (en) * | 2003-12-31 | 2009-07-07 | Emc Corporation | Methods and apparatus providing an event service infrastructure |
US20090276771A1 (en) * | 2005-09-15 | 2009-11-05 | 3Tera, Inc. | Globally Distributed Utility Computing Cloud |
Family Cites Families (30)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7028187B1 (en) * | 1991-11-15 | 2006-04-11 | Citibank, N.A. | Electronic transaction apparatus for electronic commerce |
GB2345157B (en) * | 1998-12-23 | 2003-06-18 | Ibm | Publish and subscribe data processing apparatus, method and computer program product with declaration of a unique publisher broker |
US6205205B1 (en) * | 1998-02-09 | 2001-03-20 | At&T Corp | Method and system for affinity group telephone service |
US6175743B1 (en) * | 1998-05-01 | 2001-01-16 | Ericsson Inc. | System and method for delivery of short message service messages to a restricted group of subscribers |
US6182143B1 (en) * | 1998-06-25 | 2001-01-30 | International Business Machines Corporation | Publish and subscribe data processing apparatus, method and computer program product with use of a stream to distribute local information between neighbors in a broker structure |
GB2345158A (en) * | 1998-12-23 | 2000-06-28 | Ibm | Publish and subscribe data processing with ability to specify a local publication/subscription |
GB2345164A (en) * | 1998-12-24 | 2000-06-28 | Ibm | Publish and subscribe data processing with subscriber option to request subscription propagation prior to acknowledgment |
US6298455B1 (en) * | 1998-12-29 | 2001-10-02 | International Business Machines Corporation | Publish and subscribe data processing with failover using cascaded sequence numbers |
GB2354847A (en) * | 1999-09-28 | 2001-04-04 | Ibm | Publish/subscribe data processing with subscription points for customised message processing |
US7020697B1 (en) * | 1999-10-01 | 2006-03-28 | Accenture Llp | Architectures for netcentric computing systems |
US7039164B1 (en) * | 1999-10-14 | 2006-05-02 | Gte Wireless Service Corporation | Method and system for reporting events in telecommunication networks |
US6772216B1 (en) * | 2000-05-19 | 2004-08-03 | Sun Microsystems, Inc. | Interaction protocol for managing cross company processes among network-distributed applications |
US6442250B1 (en) * | 2000-08-22 | 2002-08-27 | Bbnt Solutions Llc | Systems and methods for transmitting messages to predefined groups |
ATE244423T1 (en) * | 2001-02-28 | 2003-07-15 | Sap Ag | COMPUTER SYSTEM FOR BUSINESS APPLICATIONS WITH ALARM NOTIFICATION AND CONDITIONAL ACTIVATION |
EP1257086A2 (en) * | 2001-05-07 | 2002-11-13 | Siemens Aktiengesellschaft | Device and method for information transmission |
US6877107B2 (en) * | 2001-07-05 | 2005-04-05 | Softwired Ag | Method for ensuring operation during node failures and network partitions in a clustered message passing server |
EP1419661B1 (en) * | 2001-08-24 | 2011-04-13 | TELEFONAKTIEBOLAGET LM ERICSSON (publ) | Method and means for redistribution of subscriber information in umts networks where the nodes are arranged in pools |
GB0124014D0 (en) * | 2001-10-05 | 2001-11-28 | Abb Ab | Communication of messages in a system |
CN100458767C (en) | 2002-03-28 | 2009-02-04 | 普里凯许公司 | Method and apparatus for reliable and efficient content-based routing and query and response in a publish-subscribe network |
US7623848B2 (en) * | 2003-03-20 | 2009-11-24 | Dell Marketing Usa L.P. | Method and system for providing backup messages to wireless devices during outages |
ATE398376T1 (en) * | 2003-12-05 | 2008-07-15 | Ericsson Telefon Ab L M | METHOD AND DEVICE FOR ESTABLISHING A COMMUNICATION SESSION BETWEEN TWO TERMINAL DEVICES |
US8095598B2 (en) * | 2004-04-30 | 2012-01-10 | Sap Ag | Methods and apparatus for subscribing/publishing messages in an enterprising computing environment |
US7526444B2 (en) * | 2004-06-03 | 2009-04-28 | Globalprivatequity.Com, Inc. | Integrated trading information processing and transmission system for exempt securities |
US7552476B2 (en) * | 2004-06-25 | 2009-06-23 | Canon Kabushiki Kaisha | Security against replay attacks of messages |
US20060106840A1 (en) * | 2004-11-04 | 2006-05-18 | International Business Machines Corporation | System and method for tracking notifications in a publish subscribe system |
AU2005322970A1 (en) * | 2005-01-06 | 2006-07-13 | Tervela, Inc. | Hardware-based messaging appliance |
EP1920393A2 (en) * | 2005-07-22 | 2008-05-14 | Yogesh Chunilal Rathod | Universal knowledge management and desktop search system |
GB0521355D0 (en) * | 2005-10-19 | 2005-11-30 | Ibm | Publish/subscribe system and method for managing subscriptions |
US20070245018A1 (en) * | 2006-04-12 | 2007-10-18 | International Business Machines Corporation | Dynamic access control in a content-based publish/subscribe system with delivery guarantees |
US20090144385A1 (en) * | 2008-03-03 | 2009-06-04 | Harry Gold | Sequential Message Transmission System |
-
2008
- 2008-09-02 CN CN2008102143324A patent/CN101668031B/en active Active
-
2009
- 2009-06-12 US US12/456,223 patent/US8838703B2/en active Active
- 2009-06-16 EP EP09811794.8A patent/EP2321908B1/en active Active
- 2009-06-16 JP JP2011524959A patent/JP5398836B2/en active Active
- 2009-06-16 WO PCT/US2009/003622 patent/WO2010027394A1/en active Application Filing
-
2010
- 2010-08-03 HK HK10107406.1A patent/HK1141171A1/en not_active IP Right Cessation
-
2014
- 2014-08-06 US US14/452,838 patent/US20150026277A1/en not_active Abandoned
Patent Citations (10)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20020188761A1 (en) * | 2000-09-28 | 2002-12-12 | Chikirivao Bill S. | Data-type definition driven dynamic business component instantiation and execution framework |
US20030167326A1 (en) * | 2002-01-18 | 2003-09-04 | De Bonet Jeremy S. | Highly redundant, high-reliability and high-performance platform logging/billing generation and collection subsystem |
US20040240462A1 (en) * | 2003-05-27 | 2004-12-02 | Sun Microsystems, Inc. | Hashing based messaging approach to a cluster |
US20040258027A1 (en) * | 2003-06-23 | 2004-12-23 | Boris Tsybakov | Code channel management in a wireless communications system |
US20050076106A1 (en) * | 2003-09-23 | 2005-04-07 | Jesse Hummer | Asynchronous information retrieval |
US7559065B1 (en) * | 2003-12-31 | 2009-07-07 | Emc Corporation | Methods and apparatus providing an event service infrastructure |
US20050210109A1 (en) * | 2004-03-22 | 2005-09-22 | International Business Machines Corporation | Load balancing mechanism for publish/subscribe broker messaging system |
US20050262205A1 (en) * | 2004-04-30 | 2005-11-24 | Nikolov Radoslav I | Delivering messages in an enterprise messaging system using message selector hierarchy |
US20090276771A1 (en) * | 2005-09-15 | 2009-11-05 | 3Tera, Inc. | Globally Distributed Utility Computing Cloud |
US20090064185A1 (en) * | 2007-09-03 | 2009-03-05 | International Business Machines Corporation | High-Performance XML Processing in a Common Event Infrastructure |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN107483327A (en) * | 2017-09-05 | 2017-12-15 | 江苏电力信息技术有限公司 | An Instant Messaging Method Based on Long Connection Service Independence |
CN110309002A (en) * | 2019-05-29 | 2019-10-08 | 北京达佳互联信息技术有限公司 | Message treatment method, device, electronic equipment and storage medium |
Also Published As
Publication number | Publication date |
---|---|
EP2321908A4 (en) | 2013-01-23 |
CN101668031B (en) | 2013-10-16 |
HK1141171A1 (en) | 2010-10-29 |
JP5398836B2 (en) | 2014-01-29 |
EP2321908A1 (en) | 2011-05-18 |
WO2010027394A1 (en) | 2010-03-11 |
US20100057867A1 (en) | 2010-03-04 |
JP2012511190A (en) | 2012-05-17 |
CN101668031A (en) | 2010-03-10 |
US8838703B2 (en) | 2014-09-16 |
EP2321908B1 (en) | 2017-12-06 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US8838703B2 (en) | Method and system for message processing | |
EP3734913A1 (en) | Communication method and communication apparatus | |
US9237077B2 (en) | Monitoring persistent client connection status in a distributed server environment | |
US9608831B2 (en) | Migrating a chat message service provided by a chat server to a new chat server | |
CN106993043B (en) | Data communication system and method based on agency | |
CN111901705B (en) | OMCI function virtualization system of OLT equipment | |
CN102177690A (en) | Methods, systems, and computer readable media for providing sedation service in a telecommunications network | |
US20130139178A1 (en) | Cluster management system and method | |
CN102208988B (en) | Message processing method, system and equipment thereof | |
CN103312593B (en) | A kind of message distributing system and method | |
CN112214377B (en) | Equipment management method and system | |
CN110661836B (en) | Message routing method, device and system, and storage medium | |
CN114338063B (en) | Message queue system, business processing method and computer-readable storage medium | |
EP2071764B1 (en) | A method, device and communication system thereof of electing local master | |
CN116095180B (en) | A routing method, device and storage medium for log backhaul | |
JP4459999B2 (en) | Non-stop service system using voting and information updating and providing method in the system | |
TWI477113B (en) | Information processing methods and systems | |
CN112437146B (en) | A device state synchronization method, device and system | |
CN113542319B (en) | Method, device and system for notifying service provider entity change in Dubbo framework | |
US8077699B2 (en) | Independent message stores and message transport agents | |
CN110620673B (en) | Data processing method and system for chat room process | |
JP5379800B2 (en) | Method and system for managing user information within an instant messaging system | |
CN104301240B (en) | Data transmission method and system | |
US20200341968A1 (en) | Differential Update of Local Cache from Central Database | |
CN110716827A (en) | Hot backup method suitable for distributed system and distributed system |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
STCB | Information on status: application discontinuation |
Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION |