Maintaining persistence of a messaging system

US9602450B1 · US · B1

Patent metadata
FieldValue
Publication numberUS-9602450-B1
Application numberUS-201615155384-A
CountryUS
Kind codeB1
Filing dateMay 16, 2016
Priority dateMay 16, 2016
Publication dateMar 21, 2017
Grant dateMar 21, 2017

How to read this patent

A practical reading order for non-experts. Skip the full description unless you need deep technical detail.

  1. Title

    What the patent document calls the invention.

  2. Abstract

    A short plain-language summary of the technical disclosure.

  3. Assignees and inventors

    Who owns or filed the patent and who is credited as inventor.

  4. Key dates

    Filing, priority, publication, and grant dates set the timeline.

  5. First independent claim

    The legal scope of protection — read this for what is actually claimed.

  6. CPC / IPC classifications

    Technology tags used to group this patent with similar filings.

  7. Citations and related patents

    Prior art links and similar publications in this corpus.

Abstract

Official abstract text for this publication.

Methods, systems, and apparatus, including computer programs for receiving, from a first client device, a request for messages of a first channel of a plurality of channels starting at a position in the first channel, wherein each channel comprises a respective ordered plurality of messages stored in one or more respective buffers according to the order, each buffer having a respective time-to-live; receiving, from one of the second client devices, a response message comprising one or more messages of the first channel that are at or after the position in the order; and sending the messages to the first client device.

First claim

Opening claim text (preview).

What is claimed is: 1. A method comprising: performing by one or more computers: receiving, from a first client device, a request for messages of a first channel of a plurality of channels starting at a position in the first channel, wherein each channel comprises a respective ordered plurality of messages stored in one or more respective buffers according to the order, each buffer having a respective time-to-live; identifying a first message in the first channel corresponding to the position in the order, wherein the first message is stored in a buffer having a time-to-live that has expired; sending to one or more second client devices that subscribe to the first channel a request for messages beginning at the position in the order; receiving, from one of the second client devices, a response message comprising one or more messages of the first channel that are at or after the position in the order; retrieving messages for the first channel from one or more buffers of the first channel having time-to-lives that have not expired and according to the order; combining the retrieved messages and the messages from the response message according to the order; and sending the combined messages to the first client device. 2. The method of claim 1 , further comprising: determining, for one or more of the second client devices subscribing to the first channel, respective connection latency to the first channel; and identifying one of the second client devices that has a shortest connection latency. 3. The method of claim 1 , further comprising: determining, for one or more second client devices subscribing to the first channel, time durations of respective current connection sessions to the first channel; and identifying one of the second client devices having the longest current connection session among the one or more second client devices. 4. The method of claim 1 , wherein combining the retrieved message and the messages from the response message according to the order further comprises: removing from the combined messages one or more duplicate messages. 5. A system comprising: one or more computers programmed to perform operations comprising: receiving, from a first client device, a request for messages of a first channel of a plurality of channels starting at a position in the first channel, wherein each channel comprises a respective ordered plurality of messages stored in one or more respective buffers according to the order, each buffer having a respective time-to-live; identifying a first message in the first channel corresponding to the position in the order, wherein the first message is stored in a buffer having a time-to-live that has expired; sending to one or more second client devices that subscribe to the first channel a request for messages beginning at the position in the order; receiving, from one of the second client devices, a response message comprising one or more messages of the first channel that are at or after the position in the order; retrieving messages for the first channel from one or more buffers of the first channel having time-to-lives that have not expired and according to the order; combining the retrieved messages and the messages from the response message according to the order; and sending the combined messages to the first client device. 6. The system of claim 5 wherein the operations further comprise: determining, for one or more of the second client devices subscribing to the first channel, respective connection latency to the first channel; and identifying one of the second client devices that has a shortest connection latency. 7. The system of claim 5 wherein the operations further comprise: determining, for one or more second client devices subscribing to the first channel, time durations of respective current connection sessions to the first channel; and identifying one of the second client devices having the longest current connection session among the one or more second client devices. 8. The system of claim 5 , wherein combining the retrieved message and the messages from the response message according to the order further comprises: removing from the combined messages one or more duplicate messages. 9. A manufacture comprising a non-transitory computer-readable medium having instructions stored thereon that when executed by one or more computers causes the computers to perform operations comprising: receiving, from a first client device, a request for messages of a first channel of a plurality of channels starting at a position in the first channel, wherein each channel comprises a respective ordered plurality of messages stored in one or more respective buffers according to the order, each buffer having a respective time-to-live; identifying a first message in the first channel corresponding to the position in the order, wherein the first message is stored in a buffer having a time-to-live that has expired; sending to one or more second client devices that subscribe to the first channel a request for messages beginning at the position in the order; receiving, from one of the second client devices, a response message comprising one or more messages of the first channel that are at or after the position in the order; retrieving messages for the first channel from one or more buffers of the first channel having time-to-lives that have not expired and according to the order; combining the retrieved messages and the messages from the response message according to the order; and sending the combined messages to the first client device. 10. The manufacture of claim 9 wherein the operations further comprise: determining, for one or more of the second client devices subscribing to the first channel, respective connection latency to the first channel; and identifying one of the second client devices that has a shortest connection latency. 11. The manufacture of claim 9 wherein the operations further comprise: determining, for one or more second client devices subscribing to the first channel, time durations of respective current connection sessions to the first channel; and identifying one of the second client devices having the longest current connection session among the one or more second client devices. 12. The manufacture of claim 9 , wherein combining the retrieved message and the messages from the response message according to the order further comprises: removing from the combined messages one or more duplicate messages.

Assignees

Inventors

Classifications

  • Multimedia information · CPC title

  • H04L51/046Primary

    Interoperability with other network applications or services · CPC title

  • Computer-aided management of electronic mailing [e-mailing] · CPC title

  • Electricity · mapped topic

  • H04L51/216Primary

    Handling conversation history, e.g. grouping of messages in sessions or threads · CPC title

Patent family

Related publications grouped by family.

External sources

Frequently asked questions

Answers are generated from the same data shown on this page.

What does patent US9602450B1 cover?
Methods, systems, and apparatus, including computer programs for receiving, from a first client device, a request for messages of a first channel of a plurality of channels starting at a position in the first channel, wherein each channel comprises a respective ordered plurality of messages stored in one or more respective buffers according to the order, each buffer having a respective time-to-…
Who is the assignee on this patent?
Machine Zone Inc
What technology area does this patent fall under?
Primary CPC classification H04L51/046. Mapped technology areas include Electricity.
When was this patent published?
Publication date Tue Mar 21 2017 00:00:00 GMT+0000 (Coordinated Universal Time) (B1). Legal status and post-grant events are not shown on this page.
What related patents are in patentsdb?
We list 10 related publications on this page (citations in our corpus or others sharing the same primary CPC).