Data storage systems and methods using a real-time messaging system

US10447623B2 · US · B2

Patent metadata
FieldValue
Publication numberUS-10447623-B2
Application numberUS-201715442286-A
CountryUS
Kind codeB2
Filing dateFeb 24, 2017
Priority dateFeb 24, 2017
Publication dateOct 15, 2019
Grant dateOct 15, 2019

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 encoded on a computer storage medium, for implementing key-value store functionality within a real-time messaging system. An example method includes: providing a plurality of channels, wherein each channel comprises an ordered plurality of messages, wherein each channel represents a unique key, and wherein each message comprises one or more key-value pairs; receiving a function comprising a key for identifying one of the plurality of channels and processing instructions to be applied to a subset of the key-value pairs; and applying the processing instructions based at least in part on the unique key.

First claim

Opening claim text (preview).

What is claimed is: 1. A method of data management using a key-value structure, comprising: providing a plurality of channels, wherein each channel comprises a plurality of messages published to the channel according to an order, wherein the plurality of messages are provided to one or more subscribers of the channel according to the order, wherein each channel is associated with a respective key, wherein at least one key is associated with a respective time-to-live, wherein the at least one key becomes unavailable when the respective time-to-live expires, and wherein each message comprises one or more key-value pairs; receiving, by one or more computer processors, a function comprising a key for identifying one of the plurality of channels and processing instructions to be applied to a subset of the key-value pairs; and applying the processing instructions based at least in part on the key. 2. The method of claim 1 , wherein the function is received and stored at a first processing node based at least in part on the processing instructions, and wherein the processing instructions are applied as the key-value pairs are received at the first processing node. 3. The method of claim 1 , wherein the processing instructions comprise instructions to read values from key-value pairs assigned to the one of the plurality of channels based on the key, and wherein the key is unique. 4. The method of claim 1 , wherein the function is received at a first processing node and, based at least in part on the processing instructions, forwarded to a second processing node at which the processing instructions are applied. 5. The method of claim 1 , wherein the processing instructions comprise instructions to write values as key-value pairs to the one of the plurality of channels based on the key. 6. The method of claim 1 , wherein the processing instructions comprise instructions to delete values from the one of the plurality of channels based on the key. 7. The method of claim 1 , wherein the processing instructions comprise modifications to values within the key-value pairs from a channel based on the key. 8. The method of claim 1 , wherein the subset of key-value pairs comprise a historical series of key-value pairs. 9. The method of claim 8 , wherein the historical series of key-value pairs comprises a state log for each of the plurality of channels. 10. The method of claim 9 , wherein application of the processing instructions to the historical series of key-value pairs restores the channel to a prior state. 11. A messaging system, comprising: a memory; and one or more computer processors to: provide a plurality of channels of a publish-subscribe system, wherein each channel comprises a plurality of messages published to the channel according to an order, wherein the plurality of messages are provided to one or more subscribers of the channel according to the order, wherein each channel is associated with a respective key, wherein at least one key is associated with a respective time-to-live, wherein the at least one key becomes unavailable when the respective time-to-live expires, and wherein each message comprises one or more key-value pairs; receive a function comprising a key for identifying one of the plurality of channels and processing instructions to be applied to a subset of the key-value pairs; and apply the processing instructions based at least in part on the key. 12. The messaging system of claim 11 , wherein the function is received and stored at a first processing node based at least in part on the processing instructions, and wherein the processing instructions are applied as the key-value pairs are received at the first processing node. 13. The messaging system of claim 11 , wherein the processing instructions comprise instructions to read values from key-value pairs assigned to the one of the plurality of channels based on the key, and wherein the key is unique. 14. The messaging system of claim 11 , wherein the function is received at a first processing node and, based at least in part on the processing instructions, forwarded to a second processing node at which the processing instructions are applied. 15. The messaging system of claim 11 , wherein the processing instructions comprise instructions to write values as key-value pairs to the one of the plurality of channels based on the key. 16. The messaging system of claim 11 , wherein the processing instructions comprise instructions to delete values from the one of the plurality of channels based on the key. 17. The messaging system of claim 11 , wherein the processing instructions comprise modifications to values within the key-value pairs from a channel based on the key. 18. The messaging system of claim 11 , wherein the subset of key-value pairs comprise a historical series of key-value pairs. 19. The messaging system of claim 18 , wherein the historical series of key-value pairs comprises a state log for each of the plurality of channels, and wherein application of the processing instructions to the historical series of key-value pairs restores the channel to a prior state. 20. A non-transitory computer-readable medium having instructions stored thereon that when executed by one or more computer processors, cause the one or more computer processors to: provide a plurality of channels of a publish-subscribe system, wherein each channel comprises a plurality of messages published to the channel according to an order, wherein the plurality of messages are provided to one or more subscribers of the channel according to the order, wherein each channel is associated with a respective key, wherein at least one key is associated with a respective time-to-live, wherein the at least one key becomes unavailable when the respective time-to-live expires, and wherein each message comprises one or more key-value pairs; receive, by the one or more computer processors, a function comprising a key for identifying one of the plurality of channels and processing instructions to be applied to a subset of the key-value pairs; and apply the processing instructions based at least in part on the key.

Assignees

Inventors

Classifications

  • Sequence data queries, e.g. querying versioned data · CPC title

  • Updating · CPC title

  • H04L51/04Primary

    Real-time or near real-time messaging, e.g. instant messaging [IM] · CPC title

  • Markers for unambiguous identification of a particular session, e.g. session cookie or URL-encoding · CPC title

  • Electricity · mapped topic

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 US10447623B2 cover?
Methods, systems, and apparatus, including computer programs encoded on a computer storage medium, for implementing key-value store functionality within a real-time messaging system. An example method includes: providing a plurality of channels, wherein each channel comprises an ordered plurality of messages, wherein each channel represents a unique key, and wherein each message comprises one o…
Who is the assignee on this patent?
Machine Zone Inc, Satori Worldwide Llc
What technology area does this patent fall under?
Primary CPC classification H04L51/04. Mapped technology areas include Electricity.
When was this patent published?
Publication date Tue Oct 15 2019 00:00:00 GMT+0000 (Coordinated Universal Time) (B2). Legal status and post-grant events are not shown on this page.
What related patents are in patentsdb?
We list 12 related publications on this page (citations in our corpus or others sharing the same primary CPC).