JP6485980B2 - ネットワークアドレスの解決 - Google Patents

ネットワークアドレスの解決 Download PDF

Info

Publication number
JP6485980B2
JP6485980B2 JP2017533424A JP2017533424A JP6485980B2 JP 6485980 B2 JP6485980 B2 JP 6485980B2 JP 2017533424 A JP2017533424 A JP 2017533424A JP 2017533424 A JP2017533424 A JP 2017533424A JP 6485980 B2 JP6485980 B2 JP 6485980B2
Authority
JP
Japan
Prior art keywords
content
resource
embedded
address
content distribution
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.)
Active
Application number
JP2017533424A
Other languages
English (en)
Other versions
JP2018506772A (ja
JP2018506772A5 (ja
Inventor
ニュートン、クリストファー
アール. パワー、ウィリアム
アール. パワー、ウィリアム
Original Assignee
レベル スリー コミュニケーションズ,エルエルシー
レベル スリー コミュニケーションズ,エルエルシー
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 レベル スリー コミュニケーションズ,エルエルシー, レベル スリー コミュニケーションズ,エルエルシー filed Critical レベル スリー コミュニケーションズ,エルエルシー
Publication of JP2018506772A publication Critical patent/JP2018506772A/ja
Publication of JP2018506772A5 publication Critical patent/JP2018506772A5/ja
Application granted granted Critical
Publication of JP6485980B2 publication Critical patent/JP6485980B2/ja
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/02Protocols based on web technology, e.g. hypertext transfer protocol [HTTP]
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/40Information retrieval; Database structures therefor; File system structures therefor of multimedia data, e.g. slideshows comprising image and additional audio data
    • G06F16/48Retrieval characterised by using metadata, e.g. metadata not derived from the content or metadata generated manually
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/90Details of database functions independent of the retrieved data types
    • G06F16/95Retrieval from the web
    • G06F16/955Retrieval from the web using information identifiers, e.g. uniform resource locators [URL]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L61/00Network arrangements, protocols or services for addressing or naming
    • H04L61/45Network directories; Name-to-address mapping
    • H04L61/4505Network directories; Name-to-address mapping using standardised directories; using standardised directory access protocols
    • H04L61/4511Network directories; Name-to-address mapping using standardised directories; using standardised directory access protocols using domain name system [DNS]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/10Protocols in which an application is distributed across nodes in the network
    • H04L67/1001Protocols in which an application is distributed across nodes in the network for accessing one among a plurality of replicated servers
    • H04L67/1004Server selection for load balancing
    • H04L67/1021Server selection for load balancing based on client or server locations
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L2101/00Indexing scheme associated with group H04L61/00
    • H04L2101/30Types of network names
    • H04L2101/355Types of network names containing special suffixes
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/10Protocols in which an application is distributed across nodes in the network

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Databases & Information Systems (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Data Mining & Analysis (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Library & Information Science (AREA)
  • Multimedia (AREA)
  • Information Transfer Between Computers (AREA)

Description

[関連出願]
本特許協力条約(PCT)出願は、2014年12月31日に出願された「ネットワークアドレスの解決」と題する米国仮特許出願第62/098,930号に基づく優先権を主張し、その全内容が参照により全ての目的に対して本明細書に完全に組み込まれる。
本開示の態様は、ネットワークアドレスの解決に関し、特に、HTMLドキュメント内または要求クライアントに返される他のコンテンツ内に、リンク解決情報を埋め込むために、解決の流れ(stream)にアプリケーションプログラミングインターフェースを導入することを伴う。
インターネットおよびワールドワイドウェブ(「ウェブ」)はユビキタスになった。今や、数千もしくは数万ものコンテンツプロバイダ(パブリッシャ)がインターネット(特に、ウェブ)を利用して世界中の多数のクライアントにあらゆるコンテンツを提供している。そのコンテンツの一部または全部を供給する仕事の負荷を下げるために、今や、多くのコンテンツプロバイダがコンテンツ配信ネットワーク(CDN)に加入している。CDNを用いると、コンテンツは、1つまたは複数のコンテンツプロバイダサーバに代わって、CDNから(例えば、CDN内の1つまたは複数のサーバから)クライアントに供給され得る。キャッシュを用いるCDNでは、供給される前、またはそのコンテンツへの具体的な要求に応答して、CDNサーバの一部または全部においてコンテンツがキャッシュされてもよい。CDNのエッジサーバ内にコンテンツをキャッシュすると、コンテンツの提供においてエッジサーバよりも効率性に劣る中間層サーバ、オリジンサーバ、または他のロケーションから、コンテンツを取得する必要がないので、CDNのパフォーマンスが向上する。
コンテンツは、ネットワークから定常的にアクセスされている。例えば、テレビの番組や映画は、今や多数のウェブサイトからアクセスされ得る。印刷された新聞はウェブに移行しており、ポータルを提供している。これを通じ、何らかの形式のコンピューティングデバイス(例えば、PC、スマートフォン、またはタブレット)を動作させるクライアントは、ブラウザを用いて、ショートビデオクリップ、記事、画像およびオーディオトラックなどの多数の形式のコンテンツにアクセスし得る。ソフトウェアのアップデートおよびパッチは、以前はディスクで提供され、受信者へ送付されるのみだったが、現在はネットワーク接続のみを使用してデバイスに定期的に配布される。これらの形式のコンテンツの全ては、CDNを用いて配信されてよい。
特にこれらの観察を念頭に置き、本開示における様々な態様が発案され開発された。
本開示における実施形態は、タグを有する少なくとも1つの埋め込みリソースを含むコンテンツリソースへの要求を受信するオペレーションを含むコンテンツ配信方法を伴う。タグを識別すると、少なくとも1つの配信パラメータを用い、修正埋め込みリソースを生成する。また、修正埋め込みリソースを有するコンテンツリソースを配信する。
実施形態はまた、アプリケーションプログラミングインターフェース(API)を生成するためのコンピュータ可読命令を含む非一時的コンピュータ可読媒体と通信している、少なくとも1つのプロセッサを備えるコンテンツ配信デバイスを含んでもよい。APIでは、埋め込みリソース、およびその埋め込みリソースに関連付けられた少なくとも1つのパラメータを受信する。命令はさらに、埋め込みリソースを取得するためのコンテンツ配信ネットワーク内のロケーションに関する情報を提供する、修正埋め込みリソースを生成することを含んでよい。
実施形態はまた、少なくとも1つの埋め込みリソースを含む、HTMLドキュメントなどのオブジェクトドキュメントを備える非一時的コンピュータ可読媒体を含んでもよく、少なくとも1つの埋め込みリソースは、埋め込みリソースを置換するための修正埋め込みリソースを構築すべく、埋め込みリソースが解析されるようにするタグを含み、修正埋め込みリソースは、修正埋め込みリソースを有するドキュメントを受信するブラウザに、埋め込みリソースに関連付けられたコンテンツを取得すべく、コンテンツ配信ネットワークとの通信を開始させる、非一時的コンピュータ可読媒体。
最後に、実施形態はまた、サーバとのHTTP接続を開始する段階を備えるコンテンツ配信方法を含んでもよく、そのHTTP接続はサーバが入手可能なクライアントIPアドレスを含む。少なくとも1つの埋め込みリソースを含むHTMLドキュメントを受信し、埋め込みリソースはコンテンツ配信ネットワークへの参照を含み、これによりコンテンツ配信ネットワークへの参照がクライアントIPアドレスにより影響を受ける。また、参照を用い、少なくとも1つの埋め込みリソースと関連付けられたコンテンツを取得すべく、コンテンツ配信ネットワークに直接要求を開始する。
上記および他の実施形態について、以下により詳細に説明する。
本明細書中に説明される本開示の、上述のおよびその他の目的、特徴、利点は、添付の図面に示されるように、それらの発明概念の特定の実施形態の以下の説明から明らかである。また、図面では、異なる図を通して、同様の参照符号は同じ部分を示し得る。図面は本開示の典型的な実施形態のみを示しており、従って範囲を限定するものとはみなされるべきではない。
一例において、HTMLドキュメントなどのネットワークアセットに含めるための、DNSをバイパスするCDNのノードへの接続を提供する埋め込みリソースの生成に関するネットワーク図およびメッセージフローである。
タグ付けされたリソースを識別し、その後に、埋め込みリソースに関連付けられたコンテンツを供給可能なCDNのノードを識別するために、様々なパラメータをAPIに渡すことにより修正埋め込みリソースを提供する方法を示すフロー図である。
タグ付けされたリソースを含む要求されたアセットの中に埋め込むための修正リソースを生成する方法を示すフロー図である。
一例において、HTMLドキュメントなどのネットワークアセットに含めるためのDNSをバイパスするCDNのノードへの接続を提供する、CDN内からの埋め込みリソースの生成に関するネットワーク図およびメッセージフローである。
タグ付けされたリソースを識別し、その後に、埋め込みリソースに関連付けられたコンテンツを供給可能なCDNのノードを識別するために、様々なパラメータをCDN内のAPIに渡すことにより修正埋め込みリソースを提供する方法を示すフロー図である。
本明細書に記載の様々なシステムおよび方法を実装し得る計算システムの例である。
本開示に記載の態様は、クライアントへコンテンツを供給すべく、コンテンツ配信ネットワーク(CDN)内にあり得るエッジサーバ、ラック、クラスタまたは他のデバイスを選択するための、システムおよび方法を伴う。本開示に記載の態様は、CDNから配信されるリソースのユニフォームリソースロケータ(URL)を構築するときに、代わりにAPIを呼び出すこと、またはCDNにクエリを行うことによるエッジ選択に従来のドメイン名システム(DNS)サーバを使用すること、への代替案を伴う。API呼び出しは、リソース名、リソースを要求するクライアントのロケーション及び/またはクライアントのロケーションを決定するのに用いられ得るクライアントのIPアドレスを含んでよく、及び/または、要求されている(またはリソース内に埋め込まれている)リソースの人気度も含んでよい。APIまたはこれに関連付けられた他の計算エンジンは、ターゲットまたは複数のターゲット(CDNからのコンテンツを供給可能なノード)のリストを生成し、コンテンツ(または埋め込みコンテンツ)が供給され得る元の1つまたは複数のロケーションを提供する。ある特定の形式において、APIは、1つまたは複数のクラスタエッジサーバに対し1つまたは複数の仮想IPアドレス(VIP)を返し得る。APIはまたコンテンツの要求に用いるプロトコルを返し得る。APIはまた、コンテンツがそこから取得され得る絶対URLのリスト、及び/または、呼び出し中のアプリケーションにおけるURL構築に用いられる可能性のあるホストネーム及び/またはIPアドレスのリストを返し得る。
本明細書において用いられる「コンテンツ」という用語は、あらゆる形式のあらゆる種類のデータを意味し、その表現に関わらず、かつ、それが表すものに関わらない。「コンテンツ」という用語は、限定されるものではないが、静的及び/または動的な画像、テキスト、ストリーミングオーディオを含むオーディオコンテンツ、ストリーミングビデオを含むビデオコンテンツ、ウェブページ、コンピュータプログラム、ドキュメント、ファイル等を含んでよい。何らかのコンテンツは、例えば、HTML及びXMLなどのマークアップ言語を用いて、他のコンテンツに埋め込まれてよい。コンテンツは、特に特定の要求に応答して、生成もしくは形成される、または構成されるコンテンツを含む。「リソース」という用語は、場合により、本明細書において、コンテンツを指すものとして用いられる。
図1は本開示の態様を実施するためのネットワーク構成の一例を示し、図2および図3は方法を説明する。図示されたネットワークは、要求のサービス供給およびコンテンツ提供に伴う他の多くのコンポーネントを含むであろう。しかし、本図においてはシステムに伴う一部のコンポーネントにのみ焦点を当てており、他の従来のコンポーネントもネットワーク内に存在することを当業者は容易に理解するであろう。コンテンツ配信に関して、本例においては、要求は、ブラウザなどのユーザエージェント12を動作させるコンピューティングデバイス10から生じる。コンピューティングデバイスは、ブラウザを稼働させることが出来、ネットワーク接続を介し、ユーザにコンテンツを要求する能力を提供することが出来る、パーソナルコンピュータ、シンクライアント、タブレット、スマートフォン、セットトップボックス、またはケーブルボックスなどの何らかの形式のコンピューティングデバイスであってよく、または、ネットワークとやり取りし、そこからコンテンツを要求することに適した、他の何らかのアプリケーションであってもよい。ユーザデバイスは、公衆ネットワークに展開されたコンシューマデバイスであってよく、プライベートネットワークに展開されたエンタープライズデバイスであってよく、または何らかの他のタイプのデバイスであってよい。ネットワーク接続は、多くの例において、1つまたは複数のリゾルバ14を動作させるインターネットサービスプロバイダ(ISP)により供給されるであろう。リゾルバ(DNSリゾルバとも称される)が、要求されたリソースのネットワークアドレスの解決(例えば、ドメイン名をIPアドレスへと変換すること)に使用されるクライアント側のデバイスである。一般的に、リゾルバは、多くの異なるコンポーネントを伴い得るDNSインフラストラクチャ16にコンタクトし(例えば、クエリを行い)、リソースのネットワークアドレスを解決する(オペレーション200)。
本開示の態様を示すべく、ユーザがブラウザのウェブページに、アドレスhttp://www.example.comを入力する場合を検討する。ブラウザ12はリゾルバ14にコンタクトし、続いてリゾルバ14はDNS16からウェブページのインターネットプロトコル(IP)アドレスを要求する。DNSは、ブラウザにウェブページをレンダリングするであろうハイパーテキストマークアップ言語(HTML)ドキュメント20の配信が可能なオリジンサーバ18のIPアドレスを返す。HTMLドキュメントを取得すべく、クライアントデバイスはオリジンサーバ18とTCP接続を確立し、これによりHTTPプロトコル通信をカプセル化してよい(オペレーション210)。オリジンサーバが、クライアントに配信するコンテンツのオリジナルコピーを管理し、及び/または他のノードへコンテンツのコピーの配信を管理するデバイス(またはデバイスの集まり)である。本開示は、オリジンサーバへの接続に関して示されているが、代わりに、要求されるリソースを供給すべくDNSにおいて指定される他の何らかのデバイスと接続されてよい。本例において、オリジンサーバはデータベース22と接続されており、これは埋め込みリソース24を有するHTMLドキュメント20を含む、ストレージアプライアンスなどの何らかの形式のストレージデバイス(または複数のデバイス)に格納されたリソースを整理および管理する。HTMLドキュメントは、ブラウザがウェブページhttp://www.example.com/の表示に使用しているものである。本例において、埋め込みリソース24Aは何らかの形式のコンテンツへのリンクであり、ウェブページが表示されたとき、ユーザはこのリンクを選択することでこのコンテンツを取得することが出来る。
埋め込みリソースは、リソースアドレス計算エンジン30がAPI26への呼び出しを介してコンタクトされることを示すタグを含んでよい(オペレーション220)。例えば、HTMLドキュメントは以下の形式の埋め込みリソースを含んでよい。
http://${CALLAPI:ADDRONLY}/path/resource.txt
または
${CALLAPI:F'ULLURL,path=$ENV{PATH},pop=$POP}
双方の例において、タグは「$」であり、オリジンサーバ18にアドレス(のみ)または完全なURLを取得させるべくAPI26を呼び出しさせる。従って、オリジンサーバのHTMLドキュメント20内のタグ付けされたリソース24Aの存在により、オリジンサーバはAPIを呼び出し、この結果、要求クライアントに返されるHTMLドキュメントは、コンテンツが取得され得るアドレス、またはCDNへのURLを有する修正埋め込みリソース24Bを含む。
オリジンサーバは要求を受信したとき(または要求を受信する少し前のある時点で)、埋め込みリソースのアドレスをフォーマットするため計算エンジン30と通信すべく、APIを呼び出す。タグ付けされた埋め込みリソースの存在はAPI呼び出しを促す。本例において、埋め込みリソースのアドレスは静的ではない。その代わり、要求クライアントへのコンテンツの供給に最適なアドレスが返される。従って、シンプルな例において、HTMLドキュメントは、リソースを識別するであろうタグ付けされた埋め込みリソース24Aと共に最初に公開され、人気度などの他の属性もまた含んでよい。仮にユーザはニューヨークにいて、そのことはAPI呼び出し内のクライアントIPアドレスに基づき、要求クライアントのIPアドレスまたは地理情報などの情報を含むことにより判断されてよく、また、CDNがカリフォルニアおよびニューヨークの双方から要求されたコンテンツを供給することが出来る場合、カルフォルニアからコンテンツを供給するのは、コスト、待ち時間、品質、最適なCDNの利用等を含む多数の理由から最適ではないかもしれない。本システムではその代わりに、API/計算エンジンは、ニューヨークのノードへとクライアントを誘導するであろう埋め込みリソース24B(修正埋め込みリソースとも称される)を作成させてよい。本明細書ではAPI呼び出し(または複数の呼び出し)に関連する計算エンジンとの組み合わせで説明しているが、修正埋め込みリソースを計算し、返すために他のアプリケーションを使用してよい。いくつかの例において、1つのAPIのみ言及されているが、そのような言及は、インターフェースのみならずAPIへの入力を処理し修正埋め込みリソースを生成するための、関連する計算ルーチンおよび機能等もまた含むことを認識されたい。いずれにしても、修正埋め込みリソースが生成されリソースと交代し、そこで修正リソースはコンテンツ供給可能なノードと識別する(オペレーション230)。
APIは、様々なソースからのアドレスを決定する際に用いられる情報を取得してよい。まず、オリジンサーバからの要求は情報を含んでよい。クライアントはTCP接続を介してオリジンサーバにコンタクトするので、クライアントIPアドレスはクライアントからの要求の中に含まれ得る。従って、オリジンサーバはクライアントIPアドレスをAPIに送信してよく、及び/またはオリジンサーバは、APIと共有するための情報28を取得または生成すべくクライアントIPを用いてもよい。例えば、オリジンサーバはクライアントIPアドレスに基づき、クライアントの地理情報を取得してよく、または、IPアドレスをAPIに送信してもよく、APIはクライアントの地理情報を取得してよい。クライアントのロケーションは、埋め込みリソースへの要求を供給するために最適なノードを選択する際に用いられてよい。コンテンツを直接供給すべくIPアドレスを埋め込むことにより、クライアントデバイスはDNSをバイパスしてよく、また、代わりに埋め込みリソースのソースに直接接続してよいことに留意されたい。いずれにせよ、修正埋め込みリソース24Bを有するHTMLドキュメント20はクライアントデバイスに返される(オペレーション240)。
オリジンサーバ、またはオリジンサーバを管理するカスタマに関連付けられた他のデバイスはまた、コンテンツの人気度情報を取得してもよい。例えば、http://www.example.com/がオンラインビデオプロバイダのホームページであり、埋め込みリソースは劇場で人気だった最近リリースの映画のものである場合を検討する。このような例においては、ビデオプロバイダによって映画がリリースされるとき、それは最初非常に人気があるものであり得、この人気度はトラックされAPI(およびその計算エンジン)に共有され得る。同じ例において、カスタマは、例えば、ビデオの最初のリリースは契約者(ユーザベース)の間で非常に人気であるだろう、というその理解に基づいて、人気度を「高」にプリセットし得る。人気度のスケールは多数の可能な形式があり得、1=低、2=中、3=高というものや、1が不人気で10が最も人気がある1〜10のスケール、等である。カスタマが定義する人気度は、オリジンにおいて最初に定義されるようHTMLページのタグ付けされた埋め込みリソースに含まれてよく、また、APIへの別の入力として提供されてもよい。スケールはコンテンツの要求数に基づいてよく、それは個々の時間(例えば、一日当たり、一分当たり、一秒当たり、等の要求数)に基づいてよい。最後に、人気度は予測され得、また地域化もされ得る。例えば、リソースがニュース記事の場合、何らかの特定の地域において、または何らかの特定の時に、最初に人気となり得る。例えば、早朝の国内ニュース速報記事が米国の東海岸で実際に人気になり得る。カスタマはそれから、西海岸におけるその人気度を予測し得、システムは自動的に、全ての要求に対し人気度を「高」の値に設定し得る。
地理情報を含むクライアント情報及び人気度に加え、オリジンサーバはまた、ポリシー情報、政治情報、制限等などの他の情報も渡してよい。例えば、何らかのコンテンツの配信は地理的に限定され得る。例えば、リアルタイムのスポーツコンテンツの取得は、そのイベントに参加しているチームのどちらか一方または両方の地域に限定され得る。何らかのコンテンツには地政学的な配信制限があり得る。この情報もまた、CDNに別々に格納されてよく、または別々にCDNからアクセス可能であってよく、修正埋め込みリソースに渡される、または修正埋め込みリソースを生成するのに用いられてよい。図3を参照すると、計算エンジンは、他の情報とともにCDN情報を受信するが、それはその情報を、コンテンツを受信可能なノード、ノードの集まりまたはVIP等、を識別するために用いてよい(オペレーション300)。
同様の情報はAPIに提供され得る、または、他のソースからのAPIによりアクセス可能であり得る。例えば、CDNは、自身で人気度情報を管理してよく、それをトラックしてもよく、これはCDNの他のカスタマに起因する要求を説明し得る。よくある場合として、CDNは多数のカスタマを有するであろうし、またそのカスタマへの一部または全部のコンテンツ配信を担うであろう。さらに、多くの例では、カスタマは同じコンテンツを有する複数のウェブプロパティを有するだろう。従って、クライアントは、コンテンツの取得のために、それらのウェブプロパティのいずれかにコンタクトしてよい。従って、CDNは何らかのコンテンツの人気度についてより大きな視点を有する。
いずれにしても、API26は、タグ付けされたリソース、または修正するよう識別されたリソースに関連する、オリジンサーバから(または何らかの他の要求ソースから)の要求を受信すると、計算エンジン30へのインターフェースを提供する。計算エンジン30は、コンテンツを供給するために、CDN内の1つまたは複数のノード32を決定すべく、APIを通じエンジンに渡される情報を用いる。(オペレーション310)。計算エンジンは、そこからコンテンツを供給するノードを決定する際に、クライアントIP、カスタマ(例えば、カスタマIDを通して)、一部または全部の形式の人気度、リソースの配信プロトコル、および様々な他の形式の情報を考慮し用いてよい(オペレーション320)。例えば、計算エンジンは、コンテンツを供給するクライアントに最も近いノード(CS1)を選ぶべく、地理情報を用いてよい。計算エンジンはさらにネットワークトラフィックを考慮してよく、最も近いノードがビジーすぎる場合、近くにあってよりビジーではない別のノード(例えば、CS2)を選択してよい。コンテンツが何らかの人気度閾値に達し、再度要求される可能性がある場合、計算エンジンはさらに、IPアドレスと共に、ノードにコンテンツのコピーをキャッシュさせる命令を埋め込んでよい。いくつかの例において、例えば、ノードはまだコンテンツを有してないことがあり得、要求を受信すると、オリジンサーバ、別のノード、または他の場所からコンテンツを要求しなくてはならない。そのような例において、命令はノードにコンテンツをキャッシュし保持させ、次の要求を直接供給することが出来るであろう。
APIは、コンテンツがそこから取得され得る絶対URL、及び/または、呼び出し中のアプリケーションにおけるURL構築に用いられる可能性のあるホストネーム及び/またはIPアドレスのリストを返す(オペレーション330)。同様に、オリジンサーバはAPIにドキュメントを渡してよく、APIは修正埋め込みリソースが直接埋め込まれるようにし、修正されたドキュメントをオリジンサーバに返す。従って、クライアントブラウザがウェブページを表示するとき、例えば、修正埋め込みリソース(例えば、リンク)はコンテンツを配信可能な、CDN内にあるノード(例えば、エッジサーバ)の絶対URLを含んでよい。ユーザがリンクを選択するとき、ブラウザはコンテンツのノードに直接コンタクトするだろう。ホストネームの場合、埋め込みリソースは、CDNのネームサーバ34が直接コンタクトされるようにCDNへの具体的な参照を含んでよく、CDNが任意の形式のインテリジェントトラフィックマネジメント(ITM)または他の形式のエッジ選択を実行し、要求を処理可能なCDN内にあるノードのIPアドレスを返し得るように、任意の他のDNS処理をバイパスする。ホストネームもまたAPIにより決定された要求を供給可能なノードへの参照を含むであろう、という場合があり得る。そのような場合、ホストネームは、要求を供給するロケーションの近くに用意されたCDNロケーションを参照するが、絶対URLに対して、あるレベルのフェイルオーバーまたは負荷バランシング等を可能にする。そのような場合、ホストネームは、要求を供給可能な様々なマシンに関連付けられたVIPにマッピングされ得る。
API、および要求を供給する最適ノードを解決するためにそれを呼び出すことを伴い得る、代替の実装では、それはAPIにコンタクトして最適ネットワークアドレスを構築するプロセスは、CDNによって代わりに担われ、カスタマオリジンサーバまたはCDN外の他のデバイスを必ずしも伴わない。実施形態はAPIを伴うものとして本明細書に説明されているが、APIは、異種のシステムが情報を計算エンジンに均一かつ予測可能に渡し、計算エンジンが情報を返すための便利かつ効率的な方法であることに留意されたい。しかしながら、計算エンジンとの通信方法および計算エンジンへの情報伝達には、他の形式のものもまた可能である。さらに、APIはエンジンの機能性を含んでよく、必ずしも計算エンジン機能からの個々のメカニズムとして見なされなくてよい。
ここで図4および図5を参照すると、図1〜3のシステムおよびプロセスと同一の方式で、クライアントデバイス40がブラウザ42を用いてネットワークリソースへ初期要求をし、要求は受信される(オペレーション510)。例えば、クライアントはhttp://www.example.comを要求する。クライアントリゾルバ44はDNS46にクエリを行い、それは要求されたコンテンツと関連付けられたオリジンサーバ・ネームサービス(OS−NS)48からCNAMEを返す(オペレーション520)。CNAMEはDNSで用いられるメカニズムで、別のドメインの名前またはアドレスを特定する。この場合、CNAMEはCDN50のドメインを指し、例えば、www.example.com.c.cdn.net.である。そのような場合、クライアントデバイス(または他のアクセスデバイス)はシームレスに、ネームサーバ52、またはcdn.netドメインのサーバにコンタクトするよう誘導されるだろう。ネームサーバは要求を解決し、CDNへのエントリポイント、例えば、ページ56をそこから取得するノード54を返すだろう。しかしながら、上述の例のように、クライアントがどのようにCDNに誘導されているかに関わらず、クライアントデバイスからのCDNへの要求はHTTP接続を伴ってよく、要求デバイスのIPアドレス(クライアントIP)および要求されたページに関する情報を含んでよい(オペレーション530)。ページ(例えば、www.example.com)は1つまたは複数の埋め込みリソースを有し、それは上述されたタグ付けされたリソース58Aであってよい。従って、ページ宛にコンタクトされるCDNノード(例えば、エッジサーバまたはCDNオリジンサーバ)はタグ付けされた埋め込みリソース58Aの存在を認識し、要求クライアントデバイス40へ返されるページ内に含めるための埋め込みリソース(「修正埋め込みリソース」と称される)58Bを返すために、API/計算ノード60にコンタクトするだろう(オペレーション540および550)。
API/計算エンジンは、様々な可能なソースからの様々なタイプの情報へのアクセスを有するだろう。例えば、上述のように、APIは情報を渡されてよく、また他のソースからの情報を受信してよい。その情報は、ページ内の埋め込みリンクのアドレスを生成するため計算エンジンにより用いられ得る。ページおよび埋め込みリンク(例えば、リソースへのリンク)は要求クライアントへ返される。可能な一例において、埋め込みリソースはリソースを配信するために、VIPまたはエッジサーバへのダイレクトリンクを含んでよい。計算エンジンは、修正埋め込みリソース58Bを生成するとき、クライアントリゾルバのロケーション、クライアントのロケーション(クライアントIPに基づき)、ポリシー、CDNによりトラックされた人気度または元々の埋め込みリソースに含まれる人気度、地理的な制限、プロトコル、および他のパラメータを考慮してよく、その情報は格納され、計算され、またはCDN情報格納62からアクセスされてよい。従って、ページ56(例えば、HTMLドキュメント)がクライアントデバイス40に返され、修正埋め込みリソース58Bが選択されるとき、クライアントデバイス(例えば、ブラウザ)は直接、API/計算エンジンにより定義されたノードにコンタクトしてよく、そうでなければリソースを取得するためCDNにコンタクトしてよい。
図6は、計算システム600の例示的な概略図を示す。計算システム600は、本明細書に記載の様々なデータを収集し、オリジンサーバ、CDN−OSまたはそれ以外からの要求を受信し、および最適なCDNノードを決定すべくデータおよび要求を処理し得る、CDNノード計算エンジン(およびAPI)608を実装する。アプリケーション608の計算システムはバス601(すなわち、インターコネクト)、少なくとも1つのプロセッサ602または他の計算要素、少なくとも1つの通信ポート603、メインメモリ604、リムーバブルストレージ媒体605、リードオンリメモリ606、および大容量ストレージデバイス607を含む。プロセッサ602は、任意の既知のプロセッサであってよく、限定されないが、例えば、Intel(登録商標) Itanium(登録商標)またはItanium 2(登録商標)プロセッサ、AMD(登録商標) Opteron(登録商標)もしくはAthlon MP(登録商標)プロセッサ、またはMotorola(登録商標)系列のプロセッサなどである。通信ポート603は、モデムに基づくダイアルアップ接続を使用するRS−232ポート、10/100イーサネット(登録商標)ポート、カッパもしくはファイバを用いたギガビットポート、またはUSBポートのうちのいずれかであり得る。通信ポート603は、ローカルエリアネットワーク(LAN)、ワイドエリアネットワーク(WAN)またはコンピュータシステム600が接続する任意のネットワーク、などのネットワークに応じて選ばれてよい。ランデブーアプリケーションは、周辺デバイス(例えば、入力/出力(I/O)ポート609を介したディスプレイスクリーン630、入力デバイス616)と通信していてよい。
メインメモリ604はランダムアクセスメモリ(RAM)または当技術分野において通常知られている任意の他のダイナミックストレージデバイスであり得る。リードオンリメモリ606は、プロセッサ602への命令などの静的情報を格納するための、プログラマブルリードオンリメモリ(PROM)チップなどの任意の静的ストレージデバイスであり得る。大容量ストレージデバイス607は情報と命令を格納すべく用いられ得る。例えば、Adaptec(登録商標)系列の小型コンピュータシリアルインターフェース(SCSI)ドライブなどのハードディスク、光ディスク、RAID(Redundant Array of Independent Disks)などのディスクアレイ、例えばAdaptec(登録商標)系列のRAIDドライブなど、または任意の他の大容量ストレージデバイスが用いられてよい。
バス601は、1つ以上のプロセッサ602を、他のメモリ、ストレージおよび通信ブロックと通信可能に結合する。バス601は、使用されるストレージデバイスに応じ、PCI/PCI−X、SCSIまたはユニバーサルシリアルバス(USB)に基づくシステムバス(または他のもの)であり得る。リムーバブルストレージ媒体605はあらゆる種類の外部ハードドライブ、サムドライブ、コンパクトディスクリードオンリメモリ(CD−ROM)、書き換え可能なコンパクトディスク(CD−RW)、デジタルビデオディスクリードオンリメモリ(DVD−ROM)等、であり得る。
本明細書に記載の実施形態はコンピュータプログラム製品として提供されてよく、コンピュータプログラム製品は、コンピュータ(または他の電子デバイス)にプロセスを実行させるようプログラムすべく用いられ得る命令をその内部に格納する機械可読媒体を含んでよい。機械可読媒体は、限定されないが、光ディスク、CD−ROM、光磁気ディスク、ROM、RAM、消去可能プログラマブルリードオンリメモリ(EPROM)、電気的に消去可能なプログラマブルリードオンリメモリ(EEPROM)、磁気カードもしくは光学カード、フラッシュメモリ、または電子的命令の格納に適した他のタイプの媒体/機械可読媒体を含んでよい。
図示されるように、メインメモリ604は埋め込みリソースアプリケーション650−1で符号化され、それは、本明細書に記載のAPI/計算エンジンに関連して説明される機能を含んでよく、また上述および以下にさらに説明されるような機能性をサポートする。例えば、一実施形態において、アプリケーション650−1は本明細書に記載の様々なプロセス及び/または命令を含んでよく、または実装してよい。アプリケーション650−1(及び/または本明細書に記載の他のリソース)は、本明細書に記載の種々の実施形態に係る処理機能をサポートする、データ及び/またはロジック命令(例えば、メモリ、またはディスクなどの別のコンピュータ可読媒体に格納されるコード)などのソフトウェアコードとして実施され得る。一実施形態のオペレーションの間、プロセッサ602は、650−1のロジック命令を起動、作動、実行、解釈、または実施するために、バス601の使用を介してメインメモリ604にアクセスする。
上述の説明は、例示的なシステム、方法、技術、命令シーケンス及び/または、本開示の技術を具現化するコンピュータプログラム製品を含む。しかしながら、記載の開示は、これらの具体的な詳細なしに実施されてよいことは理解されよう。本開示においては、開示された方法は、デバイスに可読な命令セットまたはソフトウェアとして実装されてよい。さらに、開示された方法における段階の具体的な順序または階層は例示的なアプローチの一例であることは理解されよう。設計上の優先事項に基づき、方法における段階の具体的な順序または階層は、開示される主題内に留まりながら再配置され得ることは理解されよう。添付の方法の請求項は、サンプルの順番における様々な段階の要素を提示し、また、提示された具体的な順序または階層に必ずしも限定されることを意味しない。
記載の開示はコンピュータプログラム製品またはソフトウェアとして提供されてよく、それは命令をその内部に格納する機械可読媒体を含んでよく、その命令はコンピュータシステム(または他の電子デバイス)に本開示に係るプロセスを実行させるようプログラムすべく用いられてよい。機械可読媒体は、マシン(例えば、コンピュータ)によって可読な形式(例えば、ソフトウェア、処理アプリケーション)で情報を格納する任意のメカニズムを含む。機械可読媒体は、限定されるものではないが、磁気記憶媒体、光記憶媒体(例えば、CD−ROM)、磁気光記憶媒体、リードオンリメモリ(ROM)、ランダムアクセスメモリ(RAM)、消去可能プログラム可能メモリ(例えば、EPROMまたはEEPROM)、フラッシュメモリ、または電子的命令の格納に適した他のタイプの媒体を含んでよい。
本開示およびその付随する利点の多くは前述の記載により理解されると考えられる。また、開示される主題から逸脱することなく、または、その本質的な利点の全てを犠牲にすることなしに、コンポーネントの形式、構成および配置において様々な変更が施されてよいことは明らかであろう。記載の形式は単に説明上のものに過ぎず、このような変更を網羅し含むことが、以下の特許請求の範囲の意図するところである。
様々な実施形態に関して本開示は説明されてきたが、これらの実施形態は例示的なものであり本開示の範囲はそれらに限定されないことは理解されよう。多くのバリエーション、変更、追加および改善が可能である。より一般的に、本開示に係る実施形態は特定の実施のコンテキストにおいて説明されてきた。機能性は、本開示の様々な実施形態において、異なるブロックで分割もしくは結合されてよく、または異なる用語で説明されてもよい。これらおよび他のバリエーション、変更、追加および改善は、以下の特許請求の範囲において定義される本開示の範囲に該当し得る。

Claims (14)

  1. タグを有する少なくとも1つの埋め込みリソースを含むコンテンツリソースについてクライアントデバイスからの要求をオリジンシステムにより受信する段階と、
    前記タグを識別すると、少なくとも1つの配信パラメータを用いて修正埋め込みリソースを、前記オリジンシステムにより、前記オリジンシステムから分離したコンテンツ配信ネットワークから取得する段階と、
    前記修正埋め込みリソースを有する前記コンテンツリソースを、前記オリジンシステムにより前記クライアントデバイスに配信する段階であって、前記修正埋め込みリソースは、前記埋め込みリソースと関連付けられたコンテンツを配信できる前記コンテンツ配信ネットワーク内のノードへのダイレクトリンクを含む、段階と、
    を備える
    コンテンツ配信方法。
  2. 前記タグは一意のタグである、請求項1に記載のコンテンツ配信方法。
  3. 前記要求はhttp接続を介して受信され、前記少なくとも1つの配信パラメータは前記クライアントデバイスのIPアドレスを含み、
    記IPアドレスに基づく情報を、前記コンテンツ配信ネットワークのアプリケーションプログラミングインターフェース(API)に伝達する段階と、
    前記APIと関連して、前記埋め込みリソースと関連付けられたパラメータを取得する段階と、
    記IPアドレスと前記パラメータとに基づいて、前記埋め込みリソースに関連付けられた前記コンテンツを供給できる、前記コンテンツ配信ネットワーク内にある前記ノードついてのロケーション情報を識別する段階と、
    前記ノードへの前記ダイレクトリンクを含むように前記修正埋め込みリソースを生成する段階と、
    をさらに備える
    請求項1または2に記載のコンテンツ配信方法。
  4. 前記パラメータは人気度パラメータである、請求項3に記載のコンテンツ配信方法。
  5. 前記パラメータは配信プロトコルパラメータである、請求項3に記載のコンテンツ配信方法。
  6. 前記情報は前記IPアドレスである、請求項3から5のいずれか一項に記載のコンテンツ配信方法。
  7. 前記情報は地理情報である、請求項3から5のいずれか一項に記載のコンテンツ配信方法。
  8. 前記ロケーション情報は、IPアドレス、仮想IPアドレス、および1つまたは複数の絶対ユニフォームリソースロケータのうちの少なくとも1つを含む、請求項3から7のいずれか一項に記載のコンテンツ配信方法。
  9. 前記要求はhttp接続を介し、前記少なくとも1つの配信パラメータは前記クライアントデバイスについてのロケーション識別子であり、
    記ロケーション識別子に基づいて、前記埋め込みリソースをサービス供給するコンテンツ配信ノードに関連する前記修正埋め込みリソースを生成すべく、前記ロケーション識別子を、前記オリジンシステムにより、アプリケーションプログラミングインターフェース(API)に渡す段階をさらに備える、請求項1から8のいずれか一項に記載のコンテンツ配信方法。
  10. 前記コンテンツリソースはハイパーテキストマークアップ言語(HTML)ドキュメントであり、前記埋め込みリソースはリンクである、請求項1から9のいずれか一項に記載のコンテンツ配信方法。
  11. コンテンツ配信ネットワークであって、
    アプリケーションプログラミングインターフェース(API)を提供し、
    前記APIにおいて、埋め込みリソース、および前記埋め込みリソースに関連付けられた少なくとも1つのパラメータを、前記コンテンツ配信ネットワークから分離したオリジンシステムから受信し、
    前記埋め込みリソースに関連付けられたコンテンツを取得するための前記コンテンツ配信ネットワーク内のノードへのダイレクトリンクを提供する修正埋め込みリソースを生成し、
    前記コンテンツ配信ネットワークにより、前記修正埋め込みリソースを前記オリジンシステムに配信し、
    前記コンテンツを取得すべく、前記ノードにおいて、クライアントデバイスから要求を受信し、
    前記コンテンツを前記クライアントデバイスに提供するための、
    コンピュータ可読命令を含む非一時的コンピュータ可読媒体と通信している少なくとも1つのプロセッサ
    を備える、コンテンツ配信ネットワーク
  12. 前記コンピュータ可読命令はさらに、リソース内で前記埋め込みリソースと、前記修正埋め込みリソースとを置換するためのものである、請求項11に記載のコンテンツ配信ネットワーク
  13. 前記リソースはHTMLドキュメントであり、前記修正埋め込みリソースはリンクである、請求項11または12に記載のコンテンツ配信ネットワーク
  14. 前記修正埋め込みリソースは、前記埋め込みリソースに関連付けられた前記コンテンツを取得すべく、前記ノードとの通信を促すためのIPアドレスと、前記埋め込みリソースに関連付けられた前記コンテンツを取得すべく、前記ノードとの通信を促すための仮想IPアドレスと、前記埋め込みリソースに関連付けられた前記コンテンツを取得すべく、前記ノードとの通信を促すための1つまたは複数の絶対ユニフォームリソースロケータと、のうちの少なくとも1つを含む、請求項11から13のいずれか一項に記載のコンテンツ配信ネットワーク
JP2017533424A 2014-12-31 2015-12-31 ネットワークアドレスの解決 Active JP6485980B2 (ja)

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
US201462098930P 2014-12-31 2014-12-31
US62/098,930 2014-12-31
PCT/US2015/068284 WO2016109797A1 (en) 2014-12-31 2015-12-31 Network address resolution

Publications (3)

Publication Number Publication Date
JP2018506772A JP2018506772A (ja) 2018-03-08
JP2018506772A5 JP2018506772A5 (ja) 2019-02-14
JP6485980B2 true JP6485980B2 (ja) 2019-03-20

Family

ID=56165673

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2017533424A Active JP6485980B2 (ja) 2014-12-31 2015-12-31 ネットワークアドレスの解決

Country Status (8)

Country Link
US (6) US10057322B2 (ja)
EP (1) EP3241341A4 (ja)
JP (1) JP6485980B2 (ja)
CN (1) CN107113337B (ja)
CA (1) CA2972593A1 (ja)
HK (1) HK1244973A1 (ja)
SG (1) SG11201705147UA (ja)
WO (1) WO2016109797A1 (ja)

Families Citing this family (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
SG11201705147UA (en) 2014-12-31 2017-07-28 Level 3 Communications Llc Network address resolution
SG11201705144RA (en) * 2014-12-31 2017-07-28 Level 3 Communications Llc Network address resolution
WO2016137574A1 (en) * 2015-02-27 2016-09-01 Level 3 Communications, Llc Network address resolution
US11349912B2 (en) * 2016-11-29 2022-05-31 Level 3 Communications, Llc Cross-cluster direct server return in a content delivery network (CDN)
US11196705B2 (en) * 2018-01-05 2021-12-07 Nextroll, Inc. Identification services for internet-enabled devices
US11328826B2 (en) 2018-06-12 2022-05-10 Clarius Mobile Health Corp. System architecture for improved storage of electronic health information, and related methods
CN110276028B (zh) * 2019-06-25 2021-10-08 云深互联(北京)科技有限公司 针对业务系统的内部链路功能需求的处理方法和装置
CN114329262B (zh) * 2021-12-20 2022-07-26 江苏云工场信息技术有限公司 一种基于cdn的动态文档生成方法及装置

Family Cites Families (36)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7054935B2 (en) 1998-02-10 2006-05-30 Savvis Communications Corporation Internet content delivery network
US8296396B2 (en) 1998-02-10 2012-10-23 Level 3 Communications, Llc Delivering resources to clients in a distributed computing environment with rendezvous based on load balancing and network conditions
US6185598B1 (en) 1998-02-10 2001-02-06 Digital Island, Inc. Optimized network resource location
US6108703A (en) * 1998-07-14 2000-08-22 Massachusetts Institute Of Technology Global hosting system
US6944634B2 (en) * 2002-04-24 2005-09-13 Hewlett-Packard Development Company, L.P. File caching method and apparatus
US7143170B2 (en) * 2003-04-30 2006-11-28 Akamai Technologies, Inc. Automatic migration of data via a distributed computer network
US8590032B2 (en) * 2003-12-10 2013-11-19 Aventail Llc Rule-based routing to resources through a network
US7516445B2 (en) * 2005-06-30 2009-04-07 Microsoft Corporation Locating source code when stopping in a debugger
US7730187B2 (en) * 2006-10-05 2010-06-01 Limelight Networks, Inc. Remote domain name service
US7962597B2 (en) * 2008-03-31 2011-06-14 Amazon Technologies, Inc. Request routing based on class
CN102047244B (zh) * 2008-04-04 2013-02-27 第三雷沃通讯有限责任公司 在内容分发网络(cdn)中处理长尾内容
US8073940B1 (en) * 2008-11-17 2011-12-06 Amazon Technologies, Inc. Managing content delivery network service providers
US8756341B1 (en) * 2009-03-27 2014-06-17 Amazon Technologies, Inc. Request routing utilizing popularity information
US8412823B1 (en) * 2009-03-27 2013-04-02 Amazon Technologies, Inc. Managing tracking information entries in resource cache components
US8688837B1 (en) * 2009-03-27 2014-04-01 Amazon Technologies, Inc. Dynamically translating resource identifiers for request routing using popularity information
US8397073B1 (en) * 2009-09-04 2013-03-12 Amazon Technologies, Inc. Managing secure content in a content delivery network
US8489724B2 (en) * 2010-09-14 2013-07-16 Cdnetworks Co., Ltd. CNAME-based round-trip time measurement in a content delivery network
WO2012034720A1 (en) * 2010-09-15 2012-03-22 Telefonaktiebolaget L M Ericsson (Publ) Sending protected data in a communication network via an intermediate unit
US8577992B1 (en) * 2010-09-28 2013-11-05 Amazon Technologies, Inc. Request routing management based on network components
US8819283B2 (en) * 2010-09-28 2014-08-26 Amazon Technologies, Inc. Request routing in a networked environment
EP2663929B1 (en) * 2011-01-12 2018-08-29 Level 3 Communications, LLC Customized domain names in a content delivery network (cdn)
US8893083B2 (en) * 2011-08-09 2014-11-18 International Business Machines Coporation Collective operation protocol selection in a parallel computer
GB2494027B (en) * 2011-08-25 2014-05-21 Ibm A computer-implemented method enabling a web application to call at least one native function of a mobile device
US9154551B1 (en) * 2012-06-11 2015-10-06 Amazon Technologies, Inc. Processing DNS queries to identify pre-processing information
US9608886B2 (en) * 2012-08-26 2017-03-28 At&T Intellectual Property I, L.P. Methods, systems, and products for monitoring domain name servers
US20140068005A1 (en) * 2012-08-31 2014-03-06 Microsoft Corporation Identification, caching, and distribution of revised files in a content delivery network
US10652087B2 (en) * 2012-12-13 2020-05-12 Level 3 Communications, Llc Content delivery framework having fill services
US9729605B2 (en) * 2012-12-27 2017-08-08 Akamai Technologies Inc. Mechanism for distinguishing between content to be served through first or second delivery channels
US8954405B2 (en) * 2013-02-25 2015-02-10 International Business Machines Corporation Content validation for documentation topics using provider information
US9037643B2 (en) * 2013-03-15 2015-05-19 Edgecast Networks, Inc. Dynamic tag management for optimizing content delivery
US9819721B2 (en) * 2013-10-31 2017-11-14 Akamai Technologies, Inc. Dynamically populated manifests and manifest-based prefetching
US10165029B2 (en) * 2014-01-31 2018-12-25 Fastly Inc. Caching and streaming of digital media content subsets
SG11201705147UA (en) 2014-12-31 2017-07-28 Level 3 Communications Llc Network address resolution
US10469609B2 (en) * 2015-12-31 2019-11-05 Time Warner Cable Enterprises Llc Methods and apparatus for serving content to customer devices based on dynamic content popularity
US10609140B2 (en) * 2017-08-28 2020-03-31 Salesforce.Com, Inc. Dynamic resource management systems and methods
US10810279B2 (en) * 2018-02-07 2020-10-20 Akamai Technologies, Inc. Content delivery network (CDN) providing accelerated delivery of embedded resources from CDN and third party domains

Also Published As

Publication number Publication date
CA2972593A1 (en) 2016-07-07
JP2018506772A (ja) 2018-03-08
US10764355B2 (en) 2020-09-01
SG11201705147UA (en) 2017-07-28
CN107113337B (zh) 2021-02-12
US10057322B2 (en) 2018-08-21
CN107113337A (zh) 2017-08-29
US11729249B2 (en) 2023-08-15
US11451612B2 (en) 2022-09-20
US20180359304A1 (en) 2018-12-13
US20230388361A1 (en) 2023-11-30
WO2016109797A1 (en) 2016-07-07
EP3241341A1 (en) 2017-11-08
US20200389513A1 (en) 2020-12-10
US20160191455A1 (en) 2016-06-30
US12034794B2 (en) 2024-07-09
US20190327286A1 (en) 2019-10-24
EP3241341A4 (en) 2018-08-08
US10348801B2 (en) 2019-07-09
US20230018743A1 (en) 2023-01-19
HK1244973A1 (zh) 2018-08-17

Similar Documents

Publication Publication Date Title
US11627108B2 (en) Network address resolution
JP6485980B2 (ja) ネットワークアドレスの解決
US11575773B2 (en) Request processing in a content delivery framework
JP7222465B2 (ja) コンテンツ配信方法、コンテンツ配信ネットワークおよび装置

Legal Events

Date Code Title Description
A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20181228

A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20181228

A871 Explanation of circumstances concerning accelerated examination

Free format text: JAPANESE INTERMEDIATE CODE: A871

Effective date: 20181228

A975 Report on accelerated examination

Free format text: JAPANESE INTERMEDIATE CODE: A971005

Effective date: 20190107

TRDD Decision of grant or rejection written
A01 Written decision to grant a patent or to grant a registration (utility model)

Free format text: JAPANESE INTERMEDIATE CODE: A01

Effective date: 20190122

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20190218

R150 Certificate of patent or registration of utility model

Ref document number: 6485980

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R150

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250