Persistent and reliable delivery of event messages
First Claim
1. A method of a system handling an event message, comprising:
- producing at least one event message;
storing said event message in a persistent memory in said system until said event message is handled; and
deleting said event message from said persistent memory after said event message is handled by said system;
wherein when said system is recovering from a system crash or error, said persistent memory is an initialization memory where said message is stored until said system recovers from said system crash or error.
2 Assignments
0 Petitions
Accused Products
Abstract
The invention provides a method and system for persistent and reliable delivery of event messages. Those parts of the system responsible for delivering event messages are able to persistently maintain those event messages until the intended recipient of the event message confirms delivery of those event messages. Those parts of the system responsible for recovering from system crashes and other system errors are able to persistently maintain those event messages until delivery, even after recovery from system crashes or other system errors. The system includes a set of event message producers, and maintains an event-indication queue of those event messages provided by the event producers using a set of pre-allocated resources. An event-distribution engine distributes event messages to intended recipients and, after having received confirmation that the event messages were received, removes them from the event-indication queue. Recipients of event messages receive the event messages, acknowledge their receipt thereof, and might take action in response to the event message. The system includes persistent memory, initialization memory, and recipient persistent memories, and provides upon recovery from system crashes or other system error, an ability to replay event messages recorded in those memories, to re-present them as event messages. A cluster of file servers collectively forming a highly-available system shares persistent memories, so that upon a system crash or other system error, at least one other file server has a record of those event messages.
38 Citations
27 Claims
-
1. A method of a system handling an event message, comprising:
-
producing at least one event message;
storing said event message in a persistent memory in said system until said event message is handled; and
deleting said event message from said persistent memory after said event message is handled by said system;
wherein when said system is recovering from a system crash or error, said persistent memory is an initialization memory where said message is stored until said system recovers from said system crash or error. - View Dependent Claims (2, 3, 4, 5, 6, 7, 8, 9)
-
-
10. A system comprising:
-
an event message producer;
a persistent memory in which at least one event message from said event message producer is stored until said system handles said event message; and
an event message distributor that handles said event message;
wherein said event message is deleted from said persistent memory after said event message is handled by said system; and
wherein when said system is recovering from a system crash or error, said persistent memory is an initialization memory where said message is stored until said system recovers from said system crash or error. - View Dependent Claims (11, 12, 13, 14, 15, 16, 17, 18)
-
-
19. A memory storing instructions executable by a system, said instructions comprising:
-
producing at least one event message;
storing said event message in a persistent memory in said system until said event message is handled; and
deleting said event message from said persistent memory after said event message is handled by said system;
wherein when said system is recovering from a system crash or error, said persistent memory is an initialization memory where said message is stored until said system recovers from said system crash or error. - View Dependent Claims (20, 21, 22, 23, 24, 25, 26, 27)
-
Specification