JP2014528126A - 複数のターゲットへのマルチソースプッシュ通知の分配 - Google Patents

複数のターゲットへのマルチソースプッシュ通知の分配 Download PDF

Info

Publication number
JP2014528126A
JP2014528126A JP2014529930A JP2014529930A JP2014528126A JP 2014528126 A JP2014528126 A JP 2014528126A JP 2014529930 A JP2014529930 A JP 2014529930A JP 2014529930 A JP2014529930 A JP 2014529930A JP 2014528126 A JP2014528126 A JP 2014528126A
Authority
JP
Japan
Prior art keywords
event
data
distribution
target
source
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.)
Pending
Application number
JP2014529930A
Other languages
English (en)
Inventor
ヴァスターズ,クレメンス・フリードリッチ
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Microsoft Corp
Original Assignee
Microsoft Corp
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by Microsoft Corp filed Critical Microsoft Corp
Publication of JP2014528126A publication Critical patent/JP2014528126A/ja
Pending legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/54Interprogram communication
    • G06F9/542Event management; Broadcasting; Multicasting; Notifications
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
    • G06Q10/00Administration; Management
    • G06Q10/10Office automation; Time management
    • G06Q10/107Computer-aided management of electronic mailing [e-mailing]
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
    • G06Q30/00Commerce
    • G06Q30/02Marketing; Price estimation or determination; Fundraising

Landscapes

  • Engineering & Computer Science (AREA)
  • Business, Economics & Management (AREA)
  • Strategic Management (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • Entrepreneurship & Innovation (AREA)
  • Human Resources & Organizations (AREA)
  • General Physics & Mathematics (AREA)
  • Software Systems (AREA)
  • Finance (AREA)
  • Economics (AREA)
  • Marketing (AREA)
  • Development Economics (AREA)
  • Accounting & Taxation (AREA)
  • General Business, Economics & Management (AREA)
  • Quality & Reliability (AREA)
  • Multimedia (AREA)
  • Computer Hardware Design (AREA)
  • General Engineering & Computer Science (AREA)
  • Tourism & Hospitality (AREA)
  • Operations Research (AREA)
  • Data Mining & Analysis (AREA)
  • Game Theory and Decision Science (AREA)
  • Information Transfer Between Computers (AREA)
  • Computer And Data Communications (AREA)

Abstract

イベントを消費者に配信すること。方法は、所有権データにアクセスするステップを含む。この方法はさらに、所有権データを正規化して正規化イベントを作り出すステップを含む。加入に基づいて、イベントを受信するべきである複数の末端消費者が判断される。正規化イベントからのデータは、判断された末端消費者全てに適当な複数の異なるフォーマットに形式化される。正規化イベントからのデータは、末端消費者に適当なフォーマットで、複数の末端消費者それぞれに配信される。

Description

本願発明の一実施例は、例えば、複数のターゲットへのマルチソースプッシュ通知の分配に関する。
[0001]コンピュータおよび計算システムは、現代の生活のほぼ全ての面に影響を与えてきた。コンピュータは一般に、仕事、娯楽、ヘルスケア、輸送、エンターテインメント、家庭管理などに関連している。
[0002]さらに、計算システム機能は、ネットワーク接続を介して他の計算システムに相互接続される計算システム能力によって向上させることができる。ネットワーク接続としては、これに限らないが、有線または無線イーサネット(登録商標)、モバイル接続、または直列、並列、USB、または他の接続によるコンピュータ接続へのコンピュータを介した接続を挙げることができる。接続により、計算システムが、他の計算システムでのサービスにアクセスし、他の計算システムからアプリケーションデータを迅速かつ効率的に受信することが可能になる。
[0003]開発者は、最新の状態にするために、世界のイベントに関する、またはサッカー、フットボール、ホッケー、または野球リーグもしくはチームのスポーツファンに対する一般大衆ニュース、情報および事実に注目した、iOS、アンドロイド、ウィンドウズ(登録商標)フォン、ウィンドウズ(登録商標)などにおけるモバイルアプリケーションを構築することができる。これらのアプリケーション(および、幅広い他のアプリケーション)のいずれかにおいて、世界中のファンの好きなチームのスコアとして警告または祝杯、または特定の種類のニュースイベントの中止をポップする通知は、大きな差別化要因である。この差別化要因は、これらのイベントを、オペレーティングシステムプラットフォーム、またはデバイスベンダー供給通知チャネルにプッシュするために、サーバインフラを構築および運用し、これは最適化されたユーザの経験に注目した多くのモバイルアプリケーション開発者の技術の組合せを超えている。また、このアプリケーションが極めて成功を収めた場合には、何万、数十万、または数百万のデバイスにイベントをタイムリーな方法で配布することは極めて困難であるので、単純なサーバベースの解決法は直ぐに、スケーラビリティの壁にぶち当たる。
[0004]加えて、多数の現代のモバイルアプリケーションが、既存のインターネット資源における単純な経験として記載されている。例えば、ユーザがウェブサイトにナビゲートする必要なくアプリケーションを開くことができるので、ニュースアプリケーションは、重要なニュースプロバイダのRSSフィードから最新のヘッドラインを即時に表示することができる。個人のソフトウェア開発者および小さな個別のソフトウェアベンダーは、多数のこのようなアプリケーションを構築し、極めて低い価格で販売している。また、これらのアプリケーションでは、プッシュ通知から大きな利益も得るが、イベントの配布だけでなく、イベントデータの取得でも困難を示す。というのは、取得も同様に、重要なサーバインフラを構築および運用する必要があるからである。
[0005]本明細書で特許請求される主題は、あらゆる欠点を解決する、または上に記載したような環境だけで動作する実施形態に限定されるものではない。むしろ、この背景は、本明細書に記載された、いくつかの実施形態を実施することができる1つの例示的技術分野を例示するためにだけに提供されている。
本願発明の一実施例は、例えば、複数のターゲットへのマルチソースプッシュ通知の分配に関する。
[0006]本明細書に例示された一実施形態は、イベントを消費者に配信する方法を含む。この方法は、所有権データにアクセスするステップを含む。この方法はさらに、所有権データを正規化して、正規化イベントを作り出すステップを含む。複数の末端消費者が、加入に基づいて、イベントを受信するべきであると判断される。正規化イベントからのデータは、判断された各末端消費者に個別に適当な複数の異なるフォーマットに形式化される。正規化イベントからのデータは、それぞれの末端消費者に適当、および消費者がこれを介して到達するターゲットインフラによって規定されるプロトコル規則に整合するフォーマットで、複数の末端消費者それぞれに運ばれる。
[0007]この要約は、詳細な説明で以下にさらに記載された単純な形で、概念の選択を紹介するために提供される。この要約は、請求する主題の重要な特性または本質的な特性を特定することを意図したものではなく、請求する主題の範囲を判断する助けとして使用されることを意図したものでもない。
[0008]追加の特性および利点は、以下の説明に記載され、部分的には説明から自明である、または本明細書の教示の実施によって習得することができる。本発明の特性および利点は、添付の特許請求の範囲で特に指摘された機器または組合せにより、実現することができ、得ることができる。本発明の特性は、以下の説明および添付の特許請求の範囲からより十分明らかになる、またはこれ以下に記載されるような発明の実施によって習得することができる。
[0009]上で言及した、および他の利点および特性を得ることができる方法を説明するため、上で簡単に説明した主題のより特定な記載は、添付の図面で例示された特定の実施形態を参照して示される。これらの図面が、典型的な実施形態を示すだけであり、したがって範囲を限定するものと考えるものではないことを理解して、実施形態は、添付の図面の使用により、追加の特性および詳細で記載および説明される。
[0010]イベントデータを収集し、イベントデータを全体的なイベントにマッピングし、イベントデータを様々なターゲット消費者に分配するシステムの概略を示す図である。 [0011]イベントデータ取得および分配システムを示す図である。 [0012]イベントデータ取得システムの一例を示す図である。 [0013]イベントデータ分配システムの一例を示す図である。 [0014]イベントデータ取得および分配システムを示す図である。 [0015]バッジカウンタ機能の実施を示す図である。 [0016]イベントを消費者に配信する方法を示す図である。
[0017]実施形態は、イベント取得システムを、通知分配システム、およびイベントを通知にマッピングするマッピングモデルに組み合わせることができる。実施形態はまた、加入供給基準に基づいて通知をフィルタリングすることが可能である。さらに、実施形態は、効率的な方法で個別のターゲットに対する配信カウントを追跡することなどの深度能力を有することができる。
[0018]このような一例が、図1に示されている。図1は、多数の異なるソース116からの情報が、多数の異なるターゲット102に運ばれる一例を示す。いくつかの例では、単一のソースからの情報、または多数のソース116から集約される情報を使用して、多数のターゲット102に運ばれる単一のイベントを作り出すことができる。指示子102は、集合的に全てのターゲット、または一般的に個別のターゲットのことを言うために使用することができることに留意されたい。特定の個別のターゲットは、別の差別子によって指定される。
[0019]図1はソース116を示す。指示子116は、集合的に全てのソース、または一般的に個別のソースのことを言うために使用することができることに留意されたい。特定の個別のソースは、別の差別子によって指定される。ソース116としては、例えば、RSS、Atom、およびODataフィードを含む幅広いパブリックおよびプライベートネットワークサービスと、これに限らないが、IMAPおよびPOP3プロトコルをこのようにサポートすることを含むEメールメールボックスと、ツイッタータイムラインまたはフェイスブックウォールなどのソーシャルネットワーク情報ソース116と、ウィンドウズアジュール(商標)サービスバスまたはアマゾンのシンプルキューサービスなどの外部公共/加入インフラに関する加入とを含むことができる。
[0020]ソース116を使用して、イベントデータを取得することができる。以下により詳細に説明されるように、ソース116を、取得トピック140−1などの取得トピックに編成することができる。イベントデータは、全体的に104で示した正規化イベントにマッピングさせることができる。正規化イベント104は、1つまたは複数のマッピングモジュール130によって、特定のターゲット102に対する通知にマッピングさせることができる。通知132は、特定のターゲット102に対する通知を代表する。単一のイベント104は、多くの異なる通知にマッピングさせることができ、ここで、異なる通知は、多くの異種ターゲット102への分配に適当な異なるフォーマットであることが分かるものとする。例えば、図1はターゲット102を示す。ターゲット102は、ターゲット特徴に依存する多くの異なるメッセージフォーマットをサポートする。例えば、いくつかのターゲット102は、リレーフォーマットで通知をサポートすることができ、他のターゲット102は、ウィンドウズ(登録商標)7フォン用のMPNS(マイクロソフト(登録商標)プッシュ通知サービス)フォーマットで通知をサポートすることができ、他のターゲット102は、iOSデバイス用のAPN(アップルプッシュ通知)フォーマットで通知をサポートすることができ、他のターゲット102は、アンドロイドデバイス用のC2DM(クラウドツーデバイスメッセージング)フォーマットで通知をサポートすることができ、他のターゲット102は、デバイス上のブラウザ用のJSON(ジャバスクリプトオブジェクトノーテーション)フォーマットで通知をサポートすることができ、他のターゲット102は、HTTP(ハイパーテキスト転送プロトコル)などで通知をサポートすることができる。
[0021]したがって、マッピングモジュール130によるマッピングは、1つまたは複数のデータソース116からの情報から作り出された単一のイベント104を、異なるターゲット102用の多くの異なる通知にマッピングすることができる。異なる通知132は、その後、様々なターゲット102に運ぶことができる。
[0022]これは、いくつかの実施形態では、図2に示されたようなファンアウトトポロジーを使用して達成することができる。図2は、ソース116を示す。本明細書に以下に論じるように、実施形態は取得パーティション140を利用することができる。各取得パーティション140は、多くのソース116を含むことができる。潜在的に、多数および多様なソース116がある可能性がある。ソース116は情報を提供する。このような情報としては、例えば、これに限らないが、Eメール、テキストメッセージ、リアルタイム株価、リアルタイムスポーツスコア、ニュース更新などを挙げることができる。
[0023]図2は、各パーティションが例示的な取得エンジン118などの、取得エンジンを含んでいることを示す。取得エンジン118は、ソース116から情報を収集し、情報に基づき、イベントを生成する。図2に示す例では、多くのイベントが、様々なソースを使用して、取得エンジンによって生成されると示される。イベント104−1は、例示として使用される。いくつかの実施形態では、イベント104−1は、本明細書にさらに説明するように正規化させることができる。取得エンジン118は、ネットワーク上でソース116から情報を収集する、インターネットなどのネットワーク上のサービスであってもよい。
[0024]図2は、イベント104−1が分配トピック144に送信されることを示す。分配トピック144は、イベントを多くの分配パーティションにファンアウトさせる。分配パーティション120−1は、分配パーティションの全てに対してアナログとして使用される。分配パーティションはそれぞれ、加入によって示される多くのエンドユーザまたはデバイスにサービスを提供する。分配パーティションによってサービス提供される加入数は、他の分配パーティションの数とは異なる可能性がある。いくつかの実施形態では、パーティションによってサービス提供される加入数は、分配パーティションの容量に左右される可能性がある。別の方法では、または加えて、分配パーティションを選択して、エンドユーザへの論理的または地理的近接に基づき、ユーザにサービスを提供することができる。これにより、警告をよりタイムリーな方法でエンドユーザに運ぶことが可能になる。
[0025]示した例では、分配パーティション120−1は、分配エンジン122−1を含む。分配エンジン122−1は、データベース124−1を参照する。データベース124−1は、関連する配信ターゲット102に関する詳細を有する加入に関する情報を含む。特に、データベースは、ターゲット102用プラットフォーム、ターゲット102によって使用されるアプリケーション、ターゲット102用ネットワークアドレス、ターゲット102を使用するエンドユーザのユーザ好みなどを記載する情報などの情報を含むことができる。データベース124−1内の情報を使用して、分配エンジン122−1はバンドル126−1を構築し、ここでバンドル126−1は、イベント104(または、少なくともイベント104からの情報)、およびイベント104−1からの情報が通知として送信されるターゲット102の中から複数のターゲット102を識別するルーティングスリップ128−1を含む。バンドル126−1はその後、キュー130−1内に配置される。
[0026]分配パーティション120−1は、多くの配信エンジンを含むことができる。配信エンジンは、バンドルをキュー103−1から取り除き、通知をターゲット102に運ぶ。例えば、配信エンジン108−1は、バンドル126−1をキュー13−1から取り出し、イベント104情報をルーティングスリップ128−1内で識別されたターゲット102に送信することができる。したがって、イベント104−1情報を含む通知134は、異なるターゲット102に適当な、また個別のターゲット102に特有のいくつかの異なるフォーマットで、ターゲット102に様々な分配パーティションから送信させることができる。これにより、多数の個別化通知を配信システムを通して運ぶのではなく、個別のターゲット102に個別化された個別化通知134を、配信システムのエッジで共通イベント104−1から作り出すことが可能になる。
[0027]以下に、いくつかの実施形態で使用することができる情報収集およびイベント分配システムの代替的記載を例示する。
[0028]基礎として、一実施形態のシステムは、ワシントン州レッドモンドのマイクロソフトコーポレーションから市販されるウィンドウズ(登録商標)アジュールサービスバスによって提供されるような公共/加入インフラを使用しており、また様々な他のメッセージングシステムで同様の形で存在する。インフラは、示した方法の記載した実施を容易にする2つの能力、トピックおよびキューを提供する。
[0029]キューは、メッセージを逐次的な順序で追加する(キューに加える)ことを可能にする、また追加されたのと同じ順序で取り除く(キューから取り除く)ことを可能にするメッセージ用の記憶構造である。メッセージを、あらゆる数の並列クライアントによって追加し、取り除くことができ、キューに加える側の負荷のレベリング、およびキューから取り除く側の受信機にわたる処理負荷の並列化を可能にする。キューはまた、エンティティが、キューから取り除かれたときにメッセージ上のロックを得るのを可能にして、いつメッセージが実際にキューから削除されるか、または取り出されたメッセージの処理が失敗した場合にキュー内で回復させることができるかどうかに関する消費クライアントの明示的制御を可能にする。
[0030]トピックは、キューの全ての特徴を有するが、それぞれキューに加えられたメッセージのシーケンス上の隔離およびフィルタリングされたビューを可能にする、複数の同時に存在する「加入」を可能にする記憶構造である。トピック上の各加入は、(1つまたは複数の)加入の関連フィルタ状態がメッセージに確実に一致するという条件で、キューに加えられた各メッセージのコピーを作り出す。その結果、それぞれが全てのメッセージに一致する単純な「パススルー」状態を有する10の加入を有するトピック内でキューに加えられたメッセージは、それぞれ各加入用の合計10のメッセージを作り出す。加入は、キューと同様に、受信機にわたる処理負荷の並列化を行なう複数の並列消費者を有することができる。
[0031]別の基礎的概念は、「イベント」のものであり、これは根本的な公共/加入インフラの意味において、単にメッセージである。一実施形態の内容で、イベントは、メッセージ本体およびメッセージ特性の使用を管理する1式の単純な制約の影響を受ける。イベントのメッセージ本体は一般的に、不透明なデータブロックとして流れ、一実施形態によって検討されるあらゆるイベントデータは一般的に、イベントを示すメッセージの一部である1式のキー/値対であるメッセージ特性内に流れる。
[0032]次に図3を参照すると、一実施形態のアーキテクチャの目標は、大きな規模で幅広い異なるソース116からイベントデータを取得し、次の処理のために公共/加入インフラ内にこれらのイベントを転送することである。処理は、引くまたは押す通知機構を通して興味のある加入者へのイベントの分析、リアルタイム調査、または再分配のいくつかの形を含むことができる。
[0033]一実施形態のアーキテクチャは、取得エンジン118、取得アダプタおよびイベント正規化用モデル、取得ソース116に関するメタデータを保持する分割されたストア138、共通の分割およびスケジューリングモデル、およびさらなるデータベース検索を必要とすることなく、取得ソース116の状態のユーザ起動の変化をシステム内にランタイムでどのように流すかについてのモデルを定義する。
[0034]具体的な実施では、取得は、RSS、Atom、およびODataフィードを含む幅広いパブリックおよびプライベートネットワークサービス、これに限らないが、IMAPおよびPOP3プロトコルをこのようにサポートすることを含むEメールメールボックス、ツイッタータイムラインまたはフェイスブックウォールなどのソーシャルネットワーク情報ソース116、およびウィンドウズアジュール(商標)サービスバスまたはアマゾンのシンプルキューサービスなどの外部公共/加入インフラに関する加入からのソースイベントへの具体的な取得アダプタをサポートすることができる。
[0035]
イベント正規化
イベントデータは正規化されて、イベントを手渡されている公共/加入インフラ上の加入者によって実際に消費可能にする。正規化は、この内容では、イベントを様々な内容で広範の加入者に興味のある可能性がある情報アイテムの一貫性のある表示を備えた共通のイベントモデルの上にマッピングされることを意味する。選択されたモデルはここでは、システムによってさらに解釈されない、単一の不透明なバイナリ量のデータに伴うことができるキー/値対の均一のリストの形のイベントの単純な表示である。イベントのこのような表示は、多くの公共/加入インフラ上で容易に表示可能であり、また、HTTPなどの共通のインターネットプロトコルに対して極めてみごとにマッピングする。
[0036]イベント正規化を示すために、イベント104内へのRSSまたはAtomフィードエントリのマッピングを検討する(図1および2を参照)。RSSおよびAtomは、しばしば時系列で、ニュースおよび他の現在の情報を発表するために極めて幅広く使用され、その情報を構造的な方法でコンピュータプログラム内の処理に利用可能にするのを助ける、2つのインターネット標準である。RSSおよびAtomは、極めて同様な構造、および異なる名前であるが、意味的に同一なデータ要素の集合を共有する。したがって、第1の正規化ステップは、名称または概要などの、両方の標準で定義されたこのような意味的に同一な要素に対するキーとして共通な名前を定義する。第2に、1つの、しかし他の標準で起こるだけであるデータは普通、それぞれの「ネイティブ」名でマッピングされる。その上、これらの種類のフィードはしばしば、コア標準で定義されないが、追加のデータを加えるために、それぞれの標準で拡張性を使用しているデータアイテムである、「拡張子」を運ぶ。
[0037]これに限らないが、地理位置情報用のGeoRSS、または構造化データをAtomフィード内に埋め込むためのODataを含む、これらの拡張子のいくつかは、異なるイベントソース116にわたって共有される共通の方法でマッピングされ、それによって、イベントが発せられる公共/加入インフラ上の加入者は、データがRSSまたはAtom、またはツイッタータイムラインから取得されたかどうかに関わらず、均一の方法で地理的位置情報を解釈することができる。GeoRSSの例に続けて、地理「ポイント」を示す単純なGeoRSS式はしたがって、WGS84座標を示す1対の数値の「緯度」/「経度」性にマッピングさせることができる。
[0038]ODataなどの複雑構造化データを運ぶ拡張子は、基礎的イベントモデルを複雑化することなく、複合タイプ構造およびデータを保存するマッピングモデルを実施することができる。いくつかの実施形態は、JSONなどの正準およびコンパクト複合データ表示に正規化し、例えば、複合データタイプ「人」のODataプロパティ「テナント」をキー/値対にマッピングし、キーはプロパティ名「テナント」であり、値はJSON直列化された形で示された名前、経歴情報、および住所情報を有する人を説明する複合データである。データソースがXMLドキュメントである場合、RSSまたはAtomの場合と同様に、値は、XMLデータをXMLによって提供された構造を保存するJSONに転写するが、属性および要素などのXML特殊性を平坦化することによって作り出すことができ、同じXML要素ノードのXML属性および要素の下位概念であるXML属性および要素は両方とも、別の区別がない「きょうだい(siblings)」としてJSONプロパティにマッピングされる。
[0039]
ソースおよび分割化
一実施形態のアーキテクチャは、ソースデータベース138内に記憶させることができる、「ソース記述」記録内のデータソース116に関するメタデータを保存する。「ソース記述」は、共通要素の集合、およびデータソースに特有な要素の集合を有することができる。共通の要素は、ソースの名前、ソース116が有効であると考えられる期間インターバル、人間が読み取れる記述、および差別化用タイプのソース116を含むことができる。ソース特有要素は、ソース116のタイプに左右され、ネットワークアドレスと、認証情報と、またはアドレスによって示されたリソース、およびRSSフィードをチェックするための時間インターバルを提供するなどの、特定の方法でデータ取得を行なう、または構築されるエンド間経験である場合に、通知受信者が制約されたスクリーン表面上の各ニュース速報アイテムを見る機会を得るように、少なくとも60秒離して現在のイベントニュースフィードから取得されたイベントに間隔をあけることなどの、特定の方法のイベントの転送を行なういずれかを、ソース取得アダプタに命令するメタデータへのアクセスを得るための他のセキュリティキー材料とを含むことができる。
[0040]ソース記述は、ソースデータベース138などの1つまたは複数のストア内に保持される。ソース記述は、2つの異なる軸に沿って、これらのストアにわたって、これらの中で分割化させることができる。
[0041]第1の軸は、システムテナントによる区別である。システムテナント、または「ネームスペース」は、システム内にエンティティ用の隔離された範囲を作り出すための機構である。「フレッド」が一実施形態を実施しているシステムのユーザである具体的な場合を示し、フレッドは、システム内の他のソース116とは完全に独立したソース記述および構成および状態を保持することができる、隔離された仮想環境をフレッドに提供するテナント範囲を作り出すことが可能である。この軸は、また特に、テナントが(パスワードなどのセキュリティ感度が高いデータを含むことができる)記憶されたメタデータの隔離を必要とする場合、または技術的、規制的または事業的理由で、ストアにわたってソース記述を広げるための差別化要因として働くことができる。システムテナントはまた、ソース記述データが中に保持され、そこからデータ取得が行なわれる特定のデータセンタへのアフィニティを示すことができる。
[0042]第2の軸は、規定の識別子範囲から選択された数値パーティション識別子による区別であることができる。パーティション識別子は、例えば、ソース名およびテナント識別子などの、ソース記述内に含まれる不変条件から導き出すことができる。パーティション識別子は、ハッシュ機能(多くの候補のうちの1つは、ジェンキンスハッシュである。http://www.burtleburtle.net/bob/hash/doobs.htmlを参照のこと。)を使用してこれらの不変条件から導き出すことができ、得られるハッシュ値は、おそらくハッシュ値上のモジュロ機能を使用して、パーティション識別子範囲に算出される。識別子範囲は、システム内にいつも保持される全てのソース記述を記憶するのに必要であると予測される最も多くの記憶パーティションより大きいように選択される(実質的に大きい可能性がある)。
[0043]記憶パーティションを導入することは、根本的なデータストアに関する記憶容量割当に直ぐに関連する、または所与のデータセンタまたはデータセンタ部に対する帯域幅制約などの取得エンジン118に影響を与える容量制限に関連するいずれかの、容量制限によって普通は動機付けされ、その結果、侵入帯域幅要求を満たすために、異なるデータセンタまたはデータセンタセグメントにわたって容量を利用している取得パーティション140を作り出す実施形態につながる可能性がある。記憶パーティションは、全体的識別子範囲のサブセットを所有し、記憶パーティション(および、これにアクセスするのに必要なリソース)を備えたソース記述記録の関連性はしたがって、そのパーティション識別子から直接推論することができる。
[0044]記憶パーティション軸を提供することを越えて、パーティション識別子はまた、スケジューリングまたは取得ジョブに使用され、(記憶パーティションへの関係とは潜在的に異なる)所与のソース記述への取得パーティション140の所有関係を明らかに規定している。
[0045]
所有および取得パーティション
システム内の各ソース技術は、特定の取得パーティション140によって所有させることができる。重複したイベントを発する可能性がある場合に、システムは複数の場所で並列して全く同じソース116からイベントを取得しないので、明確および独自の所有権が使用される。これをより具体的にするために、テナントの範囲内で規定された1つのRSSフィードは、システム内で正確に1つの取得パーティション140によって所有され、パーティション内には、時間内にあらゆる所与のポイントで特定のフィード上の1つのスケジューリングされた取得実行がある。
[0046]取得パーティション140は、パーティション識別子範囲の所有権を得る方法で、ソース記述の所有権を得る。識別子範囲は、フェイルオーバー能力を有することができ、マスタ/バックアップオーナーを割り当てることができる外部の専用分割システムを使用して、またはパーティション識別子範囲が、取得エンジン役割を仮定する多くの個別算出例にわたって均一に広がるより単純な機構を使用して、取得パーティション140に割り当てることができる。外部の分割システムでのより洗練された実施では、パーティションの選ばれたマスタオーナーは、システムが「冷却」状態から開始した場合に、ジョブのスケジューリングをシーディングする責任があり、これは、パーティションは前のオーナーを有していなかったということを意味する。より単純なシナリオでは、パーティションを所有する算出例は、スケジューリングをシーディングすることを所有している。
[0047]
スケジューリング
取得ジョブに対するスケジューリング需要は、具体的なソースの性質に左右されるが、一般的に、いくつかの記載された実施形態で実現される2種類の取得モデルがある。
[0048]第1のモデルでは、オーナーは、ソースのネットワークサービス上で接続または長期間のネットワーク要求のいくつかの形を開始し、データグラムまたはストリームの形で接続上でデータが返されるのを待つ。一般的には長期ポーリングとも呼ばれる長期間要求の場合、ソースネットワークサービスは、タイムアウトが起こるまで、またはデータが利用可能になるまで、要求を保ち、その後、取得アダプタは、ペイロード結果があってもなくても要求が完了するのを待ち、その後、要求を再発行する。その結果、この取得スケジューリングモデルは、ソース116のオーナーがソースに関して学習するときに、また新しい要求または接続が現在の接続または要求が完了するまたは一時的に中断されると直ぐに開始される場合に、開始される「タイト」ループの形をしている。オーナーがタイトループの即時制御にあるときに、ループはオーナーが実行している間に確実にアライブに保持させることができる。オーナーが停止および再開すると、ループも再開する。所有権が変わると、ループは停止し、新しいオーナーがループを開始させる。
[0049]第2のモデルでは、ソースのネットワークサービスは、利用可能になったときに、長期間要求または接続生成データをサポートしていないが、問い合わせされると直ぐに返る通常の要求/応答サービスである。このようなサービスでは、これは多くのウェブリソースに当てはまり、連続タイトループ内でデータを要求することにより、膨大な量のロードをソース116上に生じさせ、また、ソース116が変化しなかったことを単に示す、または最悪の場合、何度も繰り返し同じデータを運んでいるいずれかの重大なネットワークトラフィックを生じさせる。タイムリーなイベント取得の需要を並列化し、無益なクエリートラフィックでソース116をオーバーロードさせないために、取得エンジン118はしたがって、「タイミング」ループ内で要求を実行し、ソース116上の要求は、これらの検討事項を並列化し、またソース116からのヒントを考慮するインターバルに基づいて周期的に実行される。「タイミング」ループは、ソース116のオーナーがソースに関して学習するときに開始される。
[0050]タイミングループに対する2つの注目に値する実施バリアント型がある。第1のバリアント型は、低い規模の最良の努力のシナリオであり、スケジューリングにローカルのインメモリタイマオブジェクトを使用し、これにより、規模、制御および再開特徴が、タイトループのものと同様にされる。ループが開始され、直ぐにタイマコールバックがスケジューリングされて、取得ジョブの第1の反復が実行される。そのジョブが(エラーがあったとしても)完了し、ループが実行し続けるものであると判断されると、別のタイマコールバックが、ジョブが次に実行される瞬間にスケジューリングされる。
[0051]第2のバリアント型は、ウィンドウズアジュール(商標)サービスバスを含む、いくつかの公共/加入システムの特性である、「スケジューリングメッセージ」を使用する。バリアント型は、いくらかより高い複雑性の犠牲に、かなりより高い取得スケールを提供する。スケジューリングループは、オーナーによって開始され、メッセージは取得パーティションのスケジューリングキュー内に置かれる。メッセージは、ソース記述を含む。取得ジョブを行ない、その後、得られたイベントをターゲット公共/加入システム内でクエリーに加える労働者によってのちに取り上げられる。最後にまた、新しい「スケジューリング」メッセージをスケジューリングキューに加える。そのメッセージは、「スケジューリングされた」と呼ばれる。というのは、スケジューリングキュー上であらゆる消費者によって検索に利用可能になる瞬間でマーキングされているからである。
[0052]このモデルでは、取得パーティション140は、スケジューリングを一次的にシーディングする、また実際の取得ジョブを行なうあらゆる数の「労働者」の役割と対にすることができる、1つの「オーナー」の役割を有することによってスケールアウトすることができる。
[0053]
ソース更新
システムが運転しているときに、取得パーティション140は、観察すべき新しいソース116に関して、およびどのソース116をもはや観察すべきではないかに関して学習することができる必要がある。これに関する決定は典型的には、検出された回復不能のまたは一時的なエラーによりソース116を(以下に説明するように)ブラックリスト化する場合を除いて、ユーザにかかっており、管理サービス142との相互作用の結果である。このような変化を通信するため、取得システムは、根本的な公共/加入インフラ内に「ソース更新」トピックを維持する。各取得パーティション140は、加入が取得パーティションの所有された範囲内でパーティション識別子を運ぶものに適格なメッセージを制約するフィルタ条件を有した状態で、トピックに関する専用加入を有する。これにより、管理サービス142が、新しいまたは退いたリソース116に関する更新を設定し、パーティション保有権分配の知識を必要とすることなくこれらを正しいパーティション140に送信することが可能になる。
[0054]管理サービス142は、ソース記述、(上記フィルタリング目的の)パーティション識別子、およびソース116を加えるべきか、またはソース116をシステムから取り除くべきかを示す動作識別子を含むトピック内に更新コマンドを提示する。
[0055]取得パーティション140のオーナーがコマンドメッセージを検索すると、新しいソース116に対して新しい取得ループをスケジューリングする、または既存の取得ループを中断、またはさらには退かせる。
[0056]
ブラックリスト化
データ取得が失敗したソース116は、一時的にまたは永久的にブラックリスト化させることができる。一時的ブラックリスト化は、ソース116ネットワークリソースが利用可能ではない、または再発行された取得要求に直ぐには関連しないエラーを返す場合に行なわれる。一時的ブラックリスト化の期間は、エラーの性質に左右される。一時的ブラックリスト化は、通常のスケジューリングループ(タイトまたはタイミング)を中断し、エラー状態が他者によって解決されることが予測される瞬間に対して、(コールバックまたはスケジューリングメッセージにより)ループの次の反復をスケジューリングすることによって行なわれる。
[0057]永久的ブラックリスト化は、エラーが取得要求の直ぐの結果であると判断された場合に行なわれ、要求は認証または許可エラーを起こしている、または遠隔ソース116がいくつかの他の要求エラーを示しているということを意味する。リソースが永久的にブラックリスト化されると、ソース116はパーティションストア内でブラックリスト化されたとマーキングされ、取得ループは直ぐに中止される。永久的にブラックリスト化されたソース116を元に戻すには、推定上、要求に対する挙動変化を起こす構成変化と共に、ストア内のブラックリストマーカを取り除き、ソース更新トピックを介して取得ループを再開させる必要がある。
[0058]
通知分配
特定の範囲に関連する多数の「ターゲット102」それぞれに所与の入力イベントからの情報のコピーを分配し、各ターゲット102に対して最小の時間でそのようにするように、実施形態を構成することができる。ターゲット102は、いくつかの第三者通知システム、またはいくつかのネットワークアクセス可能外部インフラへのアダプタの識別子に結合されたデバイスまたはアプリケーションのアドレスと、その通知システムまたはインフラにアクセスするための補助データとを含むことができる。
[0059]いくつかの実施形態は、以下に詳細に記載され、図4を参照して理解することができる、3つの個別の処理役割に分割されるアーキテクチャを含むことができる。図4に「1」で記されているように、それぞれ処理役割の楕円、および「n」は、処理役割の1つまたは複数の例を有することができる。各場合において「n」の使用は、処理役割に適用されるような各他の場合とは区別して考えられるべきであり、各処理役割は同じ数の例を有する必要はないということを意味することに留意されたい。「分配エンジン」112の役割は、イベントを許可し、これらをターゲット102のグループを含むルーティングスリップ(例えば、図2のルーティングスリップ128−1を参照のこと)を束ねる。「配信エンジン」108は、これらのバンドルを許可し、ターゲット102によって示されたネットワーク位置への配信のためにルーティングスリップを処理する。管理サービス142によって示された「管理役割」は、ターゲット102を管理するために外部APIを提供し、また、配信エンジン108からの統計およびエラーデータを受け入れ、そのデータを処理/記憶する責任がある。
[0060]データフローは、イベントが分配のためにその中に提示される「分配トピック114」上にアンカリングされる。提示されたイベントは、メッセージプロパティを使用して、イベントおよび生メッセージを区別する上記制約の1つである可能性がある、関連する範囲でラベル付される。
[0061]分配トピック144は、示した例では、「分配パーティション120」毎の1つのパススルー(フィルタリングされていない)加入を有する。「分配パーティション」は、所与の範囲でターゲット102のサブセットに通知を分配および配信する責任がある隔離されたセットのリソースである。分配トピック内に送信された各イベントのコピーは、これらの関連する加入を通して効果的に同時に、全て同時に構成された分配パーティションに利用可能であり、分配作業の並列化が可能になる。
[0062]分割による並列化は、タイムリーな分配を達成するのを助ける。これを理解するため、1000万個のターゲット102での範囲を検討する。ターゲットのデータが分割されていないストア内に保持された場合、システムは、単一の大きなデータベース結果セットを順に詳しく検討しなければならない、または結果セットが同じストア上のパーティショニングクエリーを使用して取得された場合、ターゲットデータを取得するためのスループットは少なくとも、所与のストアの前置ネットワークゲートウェイインフラのスループットシーリングによって調整されなければならず、その結果、その記述記録が所与の結果セット内で極めて遅く生じるターゲット102への通知の配信の配信待ち時間は満足いかない可能性がある。
[0063]その代り、1000万個のターゲット102がそれぞれ10,000個のターゲット記録を保持する1,000のストアにわたって分配され、これらのストアがクエリーを実行し、ここに記載するようにパーティションの形で結果を処理する専用計算インフラ(本明細書に記載された「分配エンジン122」および「配信エンジン108」)と対にされた場合、ターゲット記述の取得は、幅広いセットの計算およびネットワークリソースにわたって並列化させることができ、分配された最初のイベントから最後のイベントまで測定された全てのイベントの分配に対する時間差をかなり小さくすることができる。
[0064]分配パーティションの実際の数は、技術的には制限されない。単一のパーティションから、1より大きいあらゆる数のパーティションの範囲にわたる可能性がある。
[0065]示した例では、分配パーティション120用の「分配エンジン122」がイベント104を取得すると、最初にイベントデータのサイズを計算し、その後、ルーティングスリップ128のサイズを計算し、これは、イベントサイズと、根本的なメッセージングシステムの許容最大メッセージサイズおよび絶対サイズシーリングのうちのより小さい方の間の差分に基づいて計算することができる。イベントは、「ルーティングスリップ」データ用のいくつかの最小のヘッドルームがあるような寸法で限定される。
[0066]ルーティングスリップ128は、ターゲット102の記述を含むリストである。ルーティングスリップは、イベントの範囲をパーティションのストア124内に保持されたターゲット102に対して一致させる検索クエリーを行ない、イベントの範囲、およびイベントデータに関するフィルタリング条件に基づく選択を狭める別の条件の集合に一致する全てのターゲット102を返すことによって、分配エンジン122により作り出される。実施形態は、これらのフィルタ条件の中で、現在の瞬間に有効であると考えられるこれらのターゲット102に結果を制限する時間ウィンドウ条件を含むことができる、これは、現在のUTC時間はターゲット記述記録に含まれた開始/終了有効性時間ウィンドウ内にあるということを意味する。この能力は、本文書でのちに記載するブラックリスト化に使用される。検索結果が詳しく検討されると、エンジンはイベント104のコピーを作り出し、ルーティングスリップ128を最大のサイズまで、ストア124から取り出したターゲット記述で満たし、その後、イベントおよびルーティングスリップの得られたバンドルをパーティションの「配信キュー130」に加える。
[0067]ルーティングスリップ技術は、分配エンジン122から(1つまたは複数の)配信エンジン108までのイベントのイベント流速が、根本的なインフラ上の実際のメッセージ流量より高いことを保証し、これは例えば、30個のターゲット記述をイベントデータのそばでルーティングスリップ128内に詰めることができる場合に、イベント/ターゲット対の流速は、イベント/ターゲット対が直ぐにメッセージにグループ化された場合よりも30倍高いということを意味する。
[0068]配信エンジン108は、配信キュー130からのイベント/ルーティングスリップバンドル126の消費者である。配信エンジン108の役割は、これらのバンドルをキューから取り除き、イベント104をルーティングスリップ128内に挙げられた全ての宛先に配信することである。配信は普通、イベントメッセージをそれぞれのターゲットインフラによって理解される通知メッセージに形式化するアダプタを通して起こる。例えば、通知メッセージは、ウィンドウズ(登録商標)7フォン用のMPNSフォーマット、iOSデバイス用のAPN(アップルプッシュ通知)フォーマット、アンドロイドデバイス用のC2DM(クラウドツーデバイスメッセージング)フォーマット、デバイス上のブラウザ用のJSON(ジャバスクリプトオブジェクトノーテーション)フォーマット、HTTP(ハイパーテキスト転送プロトコル)などで配信することができる。
[0069]配信エンジン108は普通、独立したターゲット102にわたる配信を並列化し、ターゲットインフラによって実施される範囲を共有するターゲット102への配信を直列化する。後者の例は、配信エンジン内の特定のアダプタが、単一のネットワーク接続を通して特定の通知プラットフォーム上の特定のターゲットアプリケーションでターゲット化された全てのイベントを送信することを選択することができるということである。
[0070]分配および配信エンジン122および108は、配信キュー130を使用して切り離されて、配信エンジン108の独自のスケーリングが可能になり、配信が減速されるのを防ぎ、分配クエリー/パッキングステージをブロックする。
[0071]各分配パーティション120は、配信キュー130を同時に観察するあらゆる数の配信エンジン例を有することができる。配信キュー130の長さを使用して、いくつの配信エンジンが同時にアクティブであるかを判断することができる。キューの長さが特定の閾値と交差する場合、新しい配信エンジン例がパーティション120に加えられて、送信スループットを大きくすることができる。
[0072]分配パーティション120、および関連する分配および配信エンジン例を、高いスケールでの最適な並列化を達成するために、実質的に無制限の方法でスケールアップさせることができる。ターゲットインフラが、並列の方法でデバイスに100万のイベント要求を受信および転送することが可能である場合、記載されたシステムは、その配信インフラにわたってイベントを分配することが可能である、潜在的には、ターゲットインフラに負荷がかけられ、あらゆる許可された配信割当が与えられるのを可能にするのと同じだけタイムリーに、全ての所望のターゲット102への配信のためのイベント提示でターゲットインフラを飽和させることができる方法で、データセンタにわたってネットワークインフラおよび帯域幅を利用することが可能である。
[0073]メッセージがそれぞれのインフラアダプタを介してターゲット102に配信されると、いくつかの実施形態では、システムは統計情報アイテムの範囲に注意する。これらの中で、配信バンドルの受け取りと、あらゆる個別のメッセージの配信の間の継続時間、および実際の送信動作の継続時間に対する期間が測定される。また、統計情報の一部は、配信が成功したか失敗したかに関する指標である。この情報は、配信エンジン108内で収集され、範囲毎およびターゲットアプリケーション毎に、平均値に丸められる。「ターゲットアプリケーション」は、統計ロールアップの特定の目的で導入されたグループ化識別子である。計算された平均値は、規定のインターバルで配信統計キュー146に送信される。このキューは、ある範囲の目的でデータ倉庫にイベントデータを提示する、管理サービス142内の労働者(の集合)によって流出される。これらの目的は、操作監視に加えて、イベントが配信されるテナントの請求、および/または第三者の独自の請求に対するテナントへの統計の開示を含むことができる。
[0074]配信エラーが検出されると、これらのエラーは一時的および永久的エラー状態に分類される。一時的エラー状態としては、例えば、システムがターゲットインフラの配信ポイントに到達することができないネットワーク故障、または配信割当に一時的に到達したことを報告するターゲットインフラを挙げることができる。永久的エラー状態としては、例えば、ターゲットインフラ上の認証/許可エラー、またはターゲットがもはや利用可能ではないまたは永久的にメッセージを受けたくないということをターゲットインフラが報告する人的介入およびエラー状態なしで直すことができない他のエラーを挙げることができる。いったん分類されると、エラーレポートが配信失敗キュー148に提示される。一時的エラー状態では、エラーはまた、エラー状態が解決されることが予測されるまで、絶対UTCタイムスタンプを含むことができる。同時に、ターゲットは、この配信エンジン例によってあらゆるさらなるローカル配信に対するターゲットアダプタにより局所的にブラックリスト化される。ブラックリストはまた、タイムスタンプを含むことができる。
[0075]配信失敗キュー148は、管理役割で労働者(の集合)によって流出される。永久的エラーは、それぞれのターゲットを、管理役割がアクセスを有するそれぞれの分配パーティションストア124から直ぐに削除させる可能性がある。「削除」とは、記録が実際に取り除かれる、または別の方法では、規則がその有効期間の「終了」タイムスタンプをエラーのタイムスタンプに設定することによって、検索クエリーから見えないように単に移動されることを意味することがある。一時的エラー状態は、エラーによって示された期間だけターゲットを停止させる可能性がある。停止は、エラー状態が直ると予測される、エラーに示されたタイムスタンプまでターゲットの有効性期間を移動させることによって行なうことができる。
[0076]図5は、取得パーティション140が分配トピック144を通して分配パーティション120に結合されるシステムの概略図を示す。
[0077]前に記したように、いくつかの実施形態では、全体的なイベント104をソース116からの情報から作り出すことができる。全体的なイベントは、後に、データを識別し、プラットフォーム特定フォーマットに置くことができるような、全体的なフォーマットである可能性がある。次に、特定のプラットフォーム通知へ、一実施形態で実施された全体的なイベントプロパティをマッピングすることができる、式の多くの例を以下に示す。
[0078]$(name)or.(name)or>(name)所与の名前を有するイベントプロパティへの参照。プロパティ名は大文字と小文字を区別しない。プロパティ名は、参照されたプロパティの値がJSONストリング文字列式の形で複合タイプデータを含む場合に、「ドット」式(例えば、プロパティアイテム)である可能性がある。この式は、プロパティのテキスト値、またはプロパティが存在しない場合には空の文字列に分解する。値は、ターゲットフィールドに対するターゲットのサイズ制約によってクリッピングされる可能性がある。
[0079]$(name,n)、上記のとおりであるが、テキストはn文字で明確にクリッピングされる。例えば、$(title,20)は、20文字でタイトルプロパティの内容をクリッピングする。
[0080].(name,n)、上記のとおりであるが、テキストはクリッピングされているので3ドットで接尾辞が付けられる。クリッピングされた文字列および接尾辞の合計サイズは、n文字を超えない。「これはタイトル行です」の入力プロパティを有する.(title,20)は、「これは、・・・タイトルである」という結果になる。
[0081]%(name)、$(name)と同様であるが、出力が符号化されたURIであることを除く。
[0082]$bodyは、イベントのエンティティ本体のことを言う。エンティティ本体は、バイナリデータを含む任意のデータを含むことができ、現状のままでシステムを通過させることができるので、クリッピング可能ではない。$bodyがターゲット上のテキストプロパティにマッピングされると、いくつかの実施形態では、本体がテキストの内容を含んでいる場合に、マッピングが成功するだけである。エンティティ本体が空である場合、式は空の文字列に分解される。
[0083]$countは、所与のソースから配信されたイベントのターゲット毎のカウントのことを言う。この式は、このカウンタのリセットを最後に要求してから、このソース116からいくつのメッセージをそれぞれのターゲットが受信したかを示すシステムによって計算された数に分解する。いくつかの例示的な実施形態では、この数は0から99の範囲を有する。カウンタが99に到達すると、さらには値が増えない。この値は普通、バッジおよびタイルカウンタに使用される。
[0084]‘[..text...]’または“[..text...]”は、リテラルである。リテラルは、一重または二重引用符内に囲まれた任意のテキストを含む。テキストは、JavaScriptエスケープ規則にしたがってエスケープの形で特殊な文字を含むことができる(ECMA−262、7.8.4を参照のこと)。expr1+expr2は、単一文字列へ2つの式を結合させる連結演算子である。式は、上記のいずれかである可能性がある。
[0085]expr1??expr2は、ゼロまたはゼロ長さ文字列でない場合に、expr1の値を求め、それ以外の場合にexpr2の値を求める条件演算子である。??演算子は、+演算子より高い優先順位を有する、すなわち、式‘p’+$(a)??$(b)は、リテラル‘p’の接頭辞を付けたaまたはbの値を生じる。
[0086]実施形態は、イベント104からプロパティを取るためにマッピング言語を使用し、これらをターゲット102上での通知のために正しい位置にマッピングすることができる。
Figure 2014528126
[0087]ウィンドウズフォン用のタイル通知はまた、カウントを自動的に記録する$countプロパティを利用することができる。
Figure 2014528126
[0088]iPadアプリでは、実施形態は以下に示すようにこれを警告にマッピングすることができる。
Figure 2014528126
[0089]または、単にアプリアイコン上のバッジ(カウンタ)だけである。
Figure 2014528126
[0090]いくつかの実施形態では、これらのマッピングに対するデフォルトは、各ターゲットプロパティが同じ名前を有する入力プロパティにマッピングされるということである。実施形態はしたがって、これと同じだけ簡潔にウィンドウズ(登録商標)フォンに対するターゲットを特定することができる。
Figure 2014528126
また、Text1、Text2およびParamは、入力イベント上で同じ名前を有するメッセージプロパティから自動的にマッピングされ、このようなプロパティがない場合には空になる(送信されない)。これにより、ウィンドウズアジュール(商標)サービスバスキューおよびトピック加入が普通そうであるのと同様に、ソース116が開発制御下にある場合のプロパティの完全なソースサイド制御が可能になる。
[0091]グーグルアンドロイドでは、C2DMサービスは通知用の固定フォーマットを定義せず、アンドロイドユーザインターフェイスシェル内への直近の関係がないので、マッピングはいくらか異なり、それによってマッピングは、ターゲットプロパティをキーとして、式を値として有する自由形式のプロパティバッグの形をとる。プロパティマップが省略された場合、全ての入力プロパティは、C2DMエンドポイントに真っ直ぐにマッピングされる。
Figure 2014528126
[0092]
選択通知分配
本明細書に記載された実施形態は、放送システム内の通知ターゲット102が、地理的、人口統計的、または他の基準に基づいて、ターゲットへのイベントストリームからのイベントの選択分配を可能にする基準を提供するイベントストリームに加入することを可能にする機能を実施することができる。
[0093]特に、イベントデータは、様々なカテゴリー化データを有することができる。例えば、イベントにジオタグを付けることができる。別の方法では、イベントは、イベント用のカテゴリー文字列を含めることなどによって、ソースによりカテゴリー化することができる。
[0094]再び図1を参照すると、様々な図を参照して上に記載したように、イベント104は、様々なタイプのカテゴリー化データを含むことができる。例えば、イベントは、地理的座標が警告内に含まれたジオタグを含むことができる。分配エンジン122−1は、ジオタグ付けされたデータを見つけるためにイベントを調べることができる。分配エンジン122−1はまた、ジオタグを有するデータに興味があるターゲット102を判断するために、データベース124−1を調べることができる。例えば、ユーザは、その位置、または全体的な位置を特定することができる。ユーザは、その位置に関連する、またはその位置から8.045キロ(5マイル)以内のあらゆる警告をユーザに運ぶべきであることを特定することができる。分配エンジン122−1は、データ内のジオタグがこの仕様内に含まれるかどうかを判断することができる。そうである場合には、その後、分配エンジン122−1は、イベント104に対してルーティングスリップ128−1内のその特定のユーザを含むことができる。そうでなければ、ユーザをルーティングスリップから除外することができ、警告104を有する通知を受信しない。
[0095]ジオタグ付けされたイベントでは、ユーザ(または、ユーザへの他のエンティティ制御通知およびイベント配信)は、多くの異なる境界のいずれかを特定することができる。例えば、所与の位置の8.045キロ(5マイル)以内のあらゆる位置を特定することにより、基本的に、ポイント、およびそのポイントの周りの円を特定する。しかし、他の実施形態は、市、州、国、または大陸などの地政学的境界の仕様、建物または複合施設の形などを含むことができる。ワシントン州レッドモンドのマイクロソフトコーポレーションからのSQLサーバ(登録商標)は、イベントを配信するためにターゲット102を判断するように、分配パーティション120−1の一部として使用することができる地理空間的機能を有する。
[0096]一般的に、イベントデータは、カテゴリー化情報を含むことができる。例えば、イベントに含まれる文字列は、イベントデータをカテゴリー化することができる。ルーティングスリップ128−1内にターゲットを含むことは、カテゴリー内を選ぶ、またはカテゴリーから選ばないユーザに基づくことがある。例えば、ターゲット102−1は、カテゴリーを選択することができ、カテゴリー化文字列をイベント104−1上で比較することができる。イベント104−1が選択されたカテゴリーを示す文字列を含む場合、その後、ターゲット102−1は、イベント104−1からのデータを有する通知がターゲット102−1に運ばれるように、バンドル126−1のルーティングスリップ128−1内に含められる。
[0097]
バッジカウンタ
記載したいくつかの実施形態により、個別のカウンタを、各エンドユーザに対するカウンタの個別の追跡を必要とすることなく、イベント放送システム内で追跡することが可能になる。これは、一連のイベントを受信するサーバによって達成することができ、一連の中の各イベントはタイムスタンプのリストに関連している。各イベント用のタイムスタンプのリストは、イベント用のタイムスタンプ、および一連の中の全ての前のイベント用のタイムスタンプを含む。
[0098]ユーザは、タイムスタンプをサーバに送信する。タイムスタンプは、ユーザがユーザデバイスでいくつかのユーザ相互作用をいつ行ったかの指標である。例えば、タイムスタンプは、ユーザがユーザデバイス上のアプリケーションをいつ開いたかの指標である可能性もある。サーバは、ユーザによって送信されるタイムスタンプを、ユーザに送信されようとしているイベント用のタイムスタンプのリストと比較する。サーバは、ユーザがタイムスタンプを送信した後に起こるユーザに送信されようとしているイベント用のタイムスタンプのリスト内のタイムスタンプの数をカウントし、このカウントをバッジカウンタとして送信する。
[0099]一例が、ここに添付された図6に示される。図6は、ターゲット102−1を示す。ターゲット102−1は、配信エンジン108−1からイベント104およびバッジカウンタ106を受信する。ターゲット102−1は、タイムスタンプ110を配信エンジン108−1に送信する。ターゲット102−1によって配信エンジン108−1に送信されたタイムスタンプ110は、ターゲット102−1でのいくつかのアクションに基づくことができる。例えば、ユーザは、配信エンジン108−1によってターゲット102−1に送信されるイベント104およびバッジカウンタ106に関連するアプリケーションを開くことができる。アプリケーションを開くことにより、タイムスタンプ110を、アプリケーションが開かれたときを示す配信エンジン108−1に対してターゲット102−1から放出させることができる。
[00100]配信エンジン108−1は、一連のイベント112(104−1、104−2、104−3、および104−nとして示される)を受信する。一連のイベント112内の各イベントは、タイムスタンプのリスト114−1、114−2、114−3、または114−nそれぞれに関連している。タイムスタンプの各リストは、現在のイベント用のタイムスタンプ、および現在のイベントの前の一連の中の各イベント用のタイムスタンプを含む。示した例では、イベント104−1は、ターゲット102への配信のための配信エンジン108−1に送信される第1のイベントである。したがって、イベント104−1に関連するリスト114−1は、イベント104−1が配信エンジン108−1に送信された時間に対応する単一エントリT1を含む。イベント104−2は、イベント104−1の後に配信エンジン108−1に送信され、したがって、イベント104−1および104−2がそれぞれ配信エンジン108−1に送信されたときに対応する時間スタンプT1およびT2を含むリスト114−2に関連している。イベント104−3は、イベント104−2の後に配信エンジン108−1に送信され、したがって、イベント104−1、104−2および104−3がそれぞれ配信エンジン108−1に送信されるときに対応するタイムスタンプT1、T2およびT3を含むリスト114−3に関連している。イベント104−nは、イベント104−3(および、推定上リスト114−n内の楕円によって示されるような多くの他のイベント)の後に配信エンジン108−1に送信され、したがって、イベント104−1、104−2、104−3から104−nまでがそれぞれ配信エンジン108−1に送信されたときに対応する時間スタンプT1、T2、T3からTnまでを含むリスト114−nに関連している。
[00101]ターゲット102−1が、配信エンジン108−1にいかなるタイムスタンプ110も送信していないと仮定する。配信エンジンがイベント104−1を送信する場合、また、T1に対応する、1の値を有するバッジカウンタを送信する。配信エンジンがイベント104−2を送信する場合、また、タイムスタンプT1およびT2のカウントに対応する、2の値を有するバッジカウンタを送信する。配信エンジンがイベント104−3を送信する場合、また、タイムスタンプT1、T2およびT3に対応する、3の値を有するバッジカウンタを送信する。配信エンジンがイベント104−nを送信する場合、また、nのタイムスタンプT1からTnまでに対応する、nの値を有するバッジカウンタを送信する。
[00102]次に、ターゲットがタイムT2とT3の間に起こる絶対的時間を有するタイムスタンプ110を送信すると仮定する。推定上このポイントでは、イベント104−1および104−2は既に、ターゲット102−1に運ばれている。イベント104−3がターゲットに送信されると、配信エンジン108−1は、バッジカウンタの値を判断する場合に、タイムスタンプ110の後に起こるタイムスタンプをカウントするだけである。したがって、このシナリオでは、配信エンジン108−1は、イベント104−3と共に、(タイムスタンプ110の前にイベントT1およびT2が起こったときに)T3に対応する、1のバッジカウンタを送信する。このプロセスは、バッジカウンタ値を判断するために使用されているターゲット102−1から受信された最新のタイムスタンプ110で繰り返すことができる。
[00103]以下の議論は次に、行なうことができるいくつかの方法および方法活動のことに言及する。方法活動を、特定の順序で議論する、または特定の順序で起こるようなフローチャートで図示することができるが、特に記されていない限り特定の順序は必要ない、または活動は行なわれている活動の前に完了している別の活動に左右されるので必要ない。
[00104]次に図7を参照すると、方法700が図示されている。この方法は、イベントを消費者に配信する活動を含む。方法700は、所有権データにアクセスするステップ(活動702)を含む。例えば、各ソース116は、異なるソース116に特定である所有権フォーマットでデータを提供することができる。
[00105]方法700はさらに、所有権データを正規化して正規化イベントを作り出すステップ(活動704)を含む。例えば、上に例示したように、イベント104は、異なるソース116からの所有権データを正規化することによって正規化させることができる。
[00106]方法700はさらに、加入に基づいて、イベントを受信するべきである複数の末端消費者を判断するステップ(活動706)を含む。例えば、図2に示すように、分配エンジン122−1は、ターゲット102でのどのようユーザが加入したのかを判断するためにデータベース124−1を調べることができる。
[00107]方法700はさらに、判断された末端消費者全てに適当な複数の異なるフォーマットに正規化イベントからのデータを形式化するステップ(活動708)を含む。例えば、図1に示すように、正規化イベントを、様々なターゲット102に適当なフォーマットに特に形式化させることができる。
[00108]方法700はさらに、末端消費者に適当なフォーマットで、複数の末端消費者それぞれに正規化イベントからのデータを配信するステップ(活動710)を含む。
[00109]さらに、方法は、1つまたは複数のプロセッサ、およびコンピュータメモリなどのコンピュータ読取可能媒体を含むコンピュータシステムによって実施させることができる。特に、コンピュータメモリは、実施形態で言及した活動などの、1つまたは複数のプロセッサによって実行される場合に様々な機能を行なわせるコンピュータ実行可能指示を記憶することができる。
[00110]本発明の実施形態は、以下により詳細に論じるように、コンピュータハードウェアを含む専用または汎用コンピュータを備える、または利用することができる。本発明の範囲内の実施形態はまた、コンピュータ実行可能指示および/またはデータ構造を担持または記憶するための物理的または他のコンピュータ読取可能媒体を含む。このようなコンピュータ読取可能媒体は、汎用または専用コンピュータシステムによってアクセスすることができるあらゆる市販の媒体であってもよい。コンピュータ実行可能指示を記憶するコンピュータ読取可能媒体は、物理的記憶媒体である。コンピュータ実行可能指示を担持するコンピュータ読取可能媒体は、伝達媒体である。したがって、限定ではなく例として、本発明の実施形態は、少なくとも2つの個別の異なる種類のコンピュータ読取可能媒体、物理的コンピュータ読取可能記憶媒体および伝達コンピュータ読取可能媒体を備えることができる。
[00111]物理的コンピュータ読取可能記憶媒体としては、RAM、ROM、EEPROM、CD−ROMまたは他の光学ディスク記憶装置(CD、DVDなど)、磁気ディスク記憶装置または他の磁気記憶デバイス、またはコンピュータ実行可能指示またはデータ構造の形の所望のプログラムコード手段を記憶するのに使用することができ、汎用または専用コンピュータによってアクセスすることが可能なあらゆる他の媒体が挙げられる。
[00112]「ネットワーク」は、コンピュータシステム、および/またはモジュール、および/または他の電子デバイス間の電子データの移送を可能にする1つまたは複数のデータリンクとして定義される。情報がコンピュータにネットワークまたは別の通信接続(有線、無線、または有線または無線の組合せのいずれか)上で伝達または提供される場合、コンピュータは接続を伝達媒体として適切に見る。伝達媒体は、コンピュータ実行可能指示またはデータ構造の形で所望のプログラムコード手段を担持するために使用することができ、汎用または専用コンピュータによってアクセスすることができる、ネットワークおよび/またはデータリンクを含むことができる。上記の組合せはまた、コンピュータ読取可能媒体の範囲内に含まれる。
[00113]さらに、様々なコンピュータシステム構成部品に到達する際に、コンピュータ実行可能指示またはデータ構造の形のプログラムコード手段は、伝達コンピュータ読取可能媒体から物理的コンピュータ読取可能記憶媒体に伝達させることができる(または、逆も同様である)。例えば、ネットワークまたはデータリンク上で受信されたコンピュータ実行可能指示またはデータ構造は、ネットワークインターフェイスモジュール(例えば、「NIC」)内でRAMにバッファリングさせ、その後、コンピュータシステムでコンピュータシステムRAMおよび/または揮発性が低いコンピュータ読取可能物理的記憶媒体に次第に伝達させることができる。したがって、コンピュータ読取可能物理的記憶媒体は、また(または、一次的にでさえも)伝達媒体を利用するコンピュータシステム構成部品内に含めることができる。
[00114]コンピュータ実行可能指示は、例えば、汎用コンピュータ、専用コンピュータ、または専用処理デバイスに特定の機能または機能のグループを行なわせる指示およびデータを含む。コンピュータ実行可能指示は例えば、アセンブリ言語、またはさらにはソースコードなどのバイナリ、中間フォーマット指示であってもよい。主体を構造的特性および/または方法的活動に特有の言語で記載したが、添付の特許請求の範囲で定義された主題は、上に記載した特性または活動に必ずしも限定されるものではないことを理解されたい。むしろ、記載した特性および活動は、特許請求の範囲を実施する例示的形として開示されている。
[00115]当業者は、本発明を、パソコン、デスクトップコンピュータ、ノートパソコン、メッセージプロセッサ、手持ち式デバイス、マルチプロセッサシステム、マイクロプロセッサベースまたはプログラム可能な家庭用電化製品、ネットワークPC、ミニコンピュータ、メインフレームコンピュータ、携帯電話、PDA、ページャ、ルータ、スイッチなどを含む、多くのタイプのコンピュータシステム構成でのネットワーク演算環境で実施することができることが分かるだろう。本発明はまた、ネットワークを通して(有線データリンク、無線データリンク、または有線および無線データリンクの組合せのいずれかによって)リンクされた、ローカルおよび遠隔コンピュータシステムが両方ともタスクを行なう分配されたシステム環境で実施することができる。分配されたシステム環境では、プログラムモジュールは、ローカルおよび遠隔メモリ記憶デバイスの両方に配置させることができる。
[00116]本発明は、その精神および特徴から逸脱することなく、他の特定の形で具体化させることができる。記載した実施形態は、全ての態様において、単に例示的なものであり、限定するものではないと考えられるものとする。本発明の範囲はしたがって、前述の説明よりむしろ、添付の特許請求の範囲によって示される。特許請求の範囲の均等の意味および範囲内にある全ての変更は、その範囲内に含まれるものである。

Claims (7)

  1. イベントを消費者に配信する方法であって、
    所有権データにアクセスするステップと、
    前記所有権データを正規化(normalizing)して正規化(normalized)イベントを作り出すステップと、
    加入(subscription)に基づいて、前記イベントを受信するべきである複数の末端消費者(end consumers)を判断する(determining)ステップと、
    前記判断された末端消費者全てに適当な(appropriate)、複数の異なるフォーマットに、前記正規化イベントからのデータを形式化する(formatting)ステップと、
    前記末端消費者に適当なフォーマットで、前記複数の末端消費者それぞれに前記正規化イベントからの前記データを配信するステップと、
    を含む方法。
  2. 所有権データにアクセスするステップは、複数のソースからのデータにアクセスするステップを含む、請求項1に記載の方法。
  3. 前記末端消費者に適当なフォーマットで、前記複数の末端消費者それぞれに前記正規化イベントからの前記データを配信するステップは、最初に前記正規化フォーマットで前記イベントからの前記データをファンアウトする(fanning out)ステップを含む、請求項1に記載の方法。
  4. 前記末端消費者に適当なフォーマットで、前記複数の末端消費者それぞれに前記正規化イベントからの前記データを配信するステップは、前記イベントを複数のバンドル(bundles)にパッケージングする(packaging)ステップを含み、前記バンドルはそれぞれ前記正規化フォーマットの前記イベントおよびルーティングスリップ(routing slip)を含み、前記ルーティングスリップは、複数の末端消費者を識別し(identifying)、前記識別は、前記ルーティングスリップ内で識別された前記末端消費者用のフォーマットを識別することを含む、請求項1に記載の方法。
  5. 前記イベントを複数のバンドルにパッケージングするステップは、データベース内の末端消費者の好み(preferences)を参照することによって、どの末端消費者が前記ルーティングスリップに含まれるのかを判断するためにデータベースを調べるステップを含む、請求項4に記載の方法。
  6. 前記所有権(proprietary)データを正規化して正規化イベントを作り出すステップは、イベント正規化システムによってさらに解釈されない、単一の(single)不透明な(opaque)バイナリ量(binary chunk)のデータに伴うキー値対(key value pairs)として前記データを示すステップを含む、請求項1に記載の方法。
  7. 前記判断された末端消費者全てに適当な複数の異なるフォーマットに前記正規化イベントからのデータを形式化するステップは、同じ名前を有するメッセージプロパティをマッピングすることによって、前記正規化イベントからの1つまたは複数のプロパティをフォーマットにマッピングするステップを含む、請求項1に記載の方法。
JP2014529930A 2011-09-12 2012-09-10 複数のターゲットへのマルチソースプッシュ通知の分配 Pending JP2014528126A (ja)

Applications Claiming Priority (5)

Application Number Priority Date Filing Date Title
US201161533669P 2011-09-12 2011-09-12
US61/533,669 2011-09-12
US13/278,415 2011-10-21
US13/278,415 US20130067024A1 (en) 2011-09-12 2011-10-21 Distributing multi-source push notifications to multiple targets
PCT/US2012/054349 WO2013039798A2 (en) 2011-09-12 2012-09-10 Distributing multi-source push notifications to multiple targets

Publications (1)

Publication Number Publication Date
JP2014528126A true JP2014528126A (ja) 2014-10-23

Family

ID=47830824

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2014529930A Pending JP2014528126A (ja) 2011-09-12 2012-09-10 複数のターゲットへのマルチソースプッシュ通知の分配

Country Status (6)

Country Link
US (1) US20130067024A1 (ja)
EP (1) EP2756475A4 (ja)
JP (1) JP2014528126A (ja)
KR (1) KR20140072044A (ja)
CN (1) CN103051667B (ja)
WO (1) WO2013039798A2 (ja)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2021523436A (ja) * 2018-05-03 2021-09-02 マイクロソフト テクノロジー ライセンシング,エルエルシー 入力および出力スキーママッピング

Families Citing this family (30)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8595322B2 (en) 2011-09-12 2013-11-26 Microsoft Corporation Target subscription for a notification distribution system
US20130091197A1 (en) 2011-10-11 2013-04-11 Microsoft Corporation Mobile device as a local server
US8949307B2 (en) * 2011-11-15 2015-02-03 Google Inc. Cloud-to-device messaging for application activation and reporting
US10353684B2 (en) * 2012-02-08 2019-07-16 Flytxt BV Method to launch an application on a mobile device using short code
EP2914183B1 (en) 2012-10-31 2019-04-17 Zipline Medical, Inc. Surgical closure apparatus
US20140304182A1 (en) * 2013-04-05 2014-10-09 Microsoft Corporation Badge logical groupiing according to skills and training
US20140324503A1 (en) * 2013-04-30 2014-10-30 Microsoft Corporation Multi-source data subscriptions
TWI513255B (zh) * 2013-06-07 2015-12-11 Mitake Information Corp 經由雙重路線傳遞與接收行動通知之系統、裝置與方法
US10248474B2 (en) * 2014-01-29 2019-04-02 Microsoft Technology Licensing, Llc Application event distribution system
US9847918B2 (en) * 2014-08-12 2017-12-19 Microsoft Technology Licensing, Llc Distributed workload reassignment following communication failure
US10425341B2 (en) * 2015-01-23 2019-09-24 Ebay Inc. Processing high volume network data
CN113037823B (zh) 2015-01-23 2024-03-22 电子湾有限公司 消息传递系统和方法
CN104615702B (zh) * 2015-01-30 2020-05-15 五八有限公司 一种信息推送方法及装置
US9830603B2 (en) 2015-03-20 2017-11-28 Microsoft Technology Licensing, Llc Digital identity and authorization for machines with replaceable parts
US10163076B2 (en) 2015-09-01 2018-12-25 Microsoft Technology Licensing, Llc Consensus scheduling for business calendar
US9979682B2 (en) 2015-09-01 2018-05-22 Microsoft Technology Licensing, Llc Command propagation optimization
US9977666B2 (en) 2015-09-01 2018-05-22 Microsoft Technology Licensing, Llc Add a new instance to a series
US9882854B2 (en) 2015-09-01 2018-01-30 Microsoft Technology Licensing, Llc Email parking lot
US9929989B2 (en) 2015-09-01 2018-03-27 Microsoft Technology Licensing, Llc Interoperability with legacy clients
KR101889159B1 (ko) * 2015-10-21 2018-08-17 주식회사 포스코 철강 공정 미들웨어의 이벤트 서비스 방법 및 프레임워크 시스템
US9813781B2 (en) * 2015-10-27 2017-11-07 Sorenson Media, Inc. Media content matching and indexing
CN107665225B (zh) * 2016-07-29 2022-01-28 北京京东尚科信息技术有限公司 信息推送方法和装置
US10929202B2 (en) * 2016-09-16 2021-02-23 Oracle International Corporation Cloud service notifications
CN106375977A (zh) * 2016-09-18 2017-02-01 中国联合网络通信集团有限公司 一种通信小区收入的计算方法和装置及服务器
US10375191B2 (en) * 2017-11-29 2019-08-06 Microsoft Technology Licensing, Llc Notifications on an online social networking system
US11057442B2 (en) * 2018-01-27 2021-07-06 Vmware, Inc. System and method for workspace sharing
WO2019164807A1 (en) * 2018-02-20 2019-08-29 Veniam, Inc. Systems and methods for real-time handling and processing of data in a network of moving things
CN110971643B (zh) * 2018-09-30 2022-07-29 北京国双科技有限公司 消息推送方法和装置、存储介质和处理器
US11169855B2 (en) * 2019-12-03 2021-11-09 Sap Se Resource allocation using application-generated notifications
US10719517B1 (en) 2019-12-18 2020-07-21 Snowflake Inc. Distributed metadata-based cluster computing

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2007516511A (ja) * 2003-06-13 2007-06-21 ヤフー! インコーポレイテッド アラート配信アーキテクチャのための方法及びシステム
US20100083124A1 (en) * 2008-09-26 2010-04-01 Fwix, Inc. System and method for aggregating web feeds relevant to a geographical locale from multiple sources

Family Cites Families (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CA2361861A1 (en) * 2001-11-13 2003-05-13 Ibm Canada Limited-Ibm Canada Limitee Wireless messaging services using publish/subscribe systems
US7743137B2 (en) * 2005-02-07 2010-06-22 Microsoft Corporation Automatically targeting notifications about events on a network to appropriate persons
US8588578B2 (en) * 2006-03-29 2013-11-19 Transpacific Digidata, Llc Conversion of video data to playable format
US20070260674A1 (en) * 2006-05-02 2007-11-08 Research In Motion Limited Push framework for delivery of dynamic mobile content
US20090187593A1 (en) * 2008-01-17 2009-07-23 Qualcomm Incorporated Methods and Apparatus for Targeted Media Content Delivery and Acquisition in a Wireless Communication Network
US8321401B2 (en) * 2008-10-17 2012-11-27 Echostar Advanced Technologies L.L.C. User interface with available multimedia content from multiple multimedia websites
US8819258B2 (en) * 2009-05-07 2014-08-26 International Business Machines Corporation Architecture for building multi-media streaming applications
KR20110071828A (ko) * 2009-12-21 2011-06-29 한국전자통신연구원 콘텐츠 변환 장치 및 방법

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2007516511A (ja) * 2003-06-13 2007-06-21 ヤフー! インコーポレイテッド アラート配信アーキテクチャのための方法及びシステム
US20100083124A1 (en) * 2008-09-26 2010-04-01 Fwix, Inc. System and method for aggregating web feeds relevant to a geographical locale from multiple sources

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2021523436A (ja) * 2018-05-03 2021-09-02 マイクロソフト テクノロジー ライセンシング,エルエルシー 入力および出力スキーママッピング
JP7360395B2 (ja) 2018-05-03 2023-10-12 マイクロソフト テクノロジー ライセンシング,エルエルシー 入力および出力スキーママッピング

Also Published As

Publication number Publication date
WO2013039798A3 (en) 2013-05-10
EP2756475A4 (en) 2015-04-22
WO2013039798A2 (en) 2013-03-21
KR20140072044A (ko) 2014-06-12
CN103051667A (zh) 2013-04-17
US20130067024A1 (en) 2013-03-14
CN103051667B (zh) 2017-04-19
EP2756475A2 (en) 2014-07-23

Similar Documents

Publication Publication Date Title
JP2014528126A (ja) 複数のターゲットへのマルチソースプッシュ通知の分配
JP6126099B2 (ja) タイムリーイベントデータ分配用マーケットプレイス
US9208476B2 (en) Counting and resetting broadcast system badge counters
US8595322B2 (en) Target subscription for a notification distribution system
US10924414B2 (en) Processing high volume network data
CN113037823B (zh) 消息传递系统和方法
US11567993B1 (en) Copying buckets from a remote shared storage system to memory associated with a search node for query execution
US11394794B2 (en) Fast ingestion of records in a database using data locality and queuing
US10484190B2 (en) Managing channels in an open data ecosystem
US20130066980A1 (en) Mapping raw event data to customized notifications
US9628355B1 (en) System for validating site configuration based on real-time analytics data
WO2016118876A1 (en) Messaging and processing high volume data
JP6067714B2 (ja) イベントデータを取得するスケールアウトシステム
EP3803616A1 (en) Change notifications for object storage
JP2014531072A (ja) 多数のデバイスへのイベントの配信

Legal Events

Date Code Title Description
A711 Notification of change in applicant

Free format text: JAPANESE INTERMEDIATE CODE: A711

Effective date: 20150528

A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20150803

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20160829

A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20160831

A02 Decision of refusal

Free format text: JAPANESE INTERMEDIATE CODE: A02

Effective date: 20170316