JP2012150809A - P2p基盤のストリーミングサービスでバッファリングを行うシステムおよび方法、並びにクライアントでバッファリングを処理するアプリケーションを配布するシステム - Google Patents

P2p基盤のストリーミングサービスでバッファリングを行うシステムおよび方法、並びにクライアントでバッファリングを処理するアプリケーションを配布するシステム Download PDF

Info

Publication number
JP2012150809A
JP2012150809A JP2012008429A JP2012008429A JP2012150809A JP 2012150809 A JP2012150809 A JP 2012150809A JP 2012008429 A JP2012008429 A JP 2012008429A JP 2012008429 A JP2012008429 A JP 2012008429A JP 2012150809 A JP2012150809 A JP 2012150809A
Authority
JP
Japan
Prior art keywords
buffer
size
server
pieces
client
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.)
Granted
Application number
JP2012008429A
Other languages
English (en)
Other versions
JP5529177B2 (ja
Inventor
Young-Wug Kim
永 郁 金
Jong-Soo Kim
宗 銖 金
Jeong-Jun Park
廷 濬 朴
Sung-Gwan Yang
▲勝▼ 官 梁
哉 ▲元▼ ▲呉▼
Jae-Won Oh
Chang-Hee Woo
昌 喜 禹
Sang-Hyeok Lee
▲尚▼ 賢 李
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.)
Naver Cloud Corp
Original Assignee
NHN Business Platform 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
Priority claimed from KR1020110005342A external-priority patent/KR101417890B1/ko
Priority claimed from KR1020110005923A external-priority patent/KR101242830B1/ko
Application filed by NHN Business Platform Corp filed Critical NHN Business Platform Corp
Publication of JP2012150809A publication Critical patent/JP2012150809A/ja
Application granted granted Critical
Publication of JP5529177B2 publication Critical patent/JP5529177B2/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/10Protocols in which an application is distributed across nodes in the network
    • H04L67/104Peer-to-peer [P2P] networks
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L65/00Network arrangements, protocols or services for supporting real-time applications in data packet communication
    • H04L65/60Network streaming of media packets
    • H04L65/70Media network packetisation
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/20Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
    • H04N21/23Processing of content or additional data; Elementary server operations; Server middleware
    • H04N21/236Assembling of a multiplex stream, e.g. transport stream, by combining a video stream with other content or additional data, e.g. inserting a URL [Uniform Resource Locator] into a video stream, multiplexing software data into a video stream; Remultiplexing of multiplex streams; Insertion of stuffing bits into the multiplex stream, e.g. to obtain a constant bit-rate; Assembling of a packetised elementary stream
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/80Generation or processing of content or additional data by content creator independently of the distribution process; Content per se
    • H04N21/83Generation or processing of protective or descriptive data associated with content; Content structuring
    • H04N21/845Structuring of content, e.g. decomposing content into time segments
    • H04N21/8456Structuring of content, e.g. decomposing content into time segments by decomposing the content in the time domain, e.g. in time segments
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/60Network structure or processes for video distribution between server and client or between remote clients; Control signalling between clients, server and network components; Transmission of management data between server and client, e.g. sending from server to client commands for recording incoming content stream; Communication details between server and client 
    • H04N21/63Control signaling related to video distribution between client, server and network components; Network processes for video distribution between server and clients or between remote clients, e.g. transmitting basic layer and enhancement layers over different transmission paths, setting up a peer-to-peer communication via Internet between remote STB's; Communication protocols; Addressing
    • H04N21/637Control signals issued by the client directed to the server or network components
    • H04N21/6377Control signals issued by the client directed to the server or network components directed to server

Landscapes

  • Engineering & Computer Science (AREA)
  • Signal Processing (AREA)
  • Multimedia (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Information Transfer Between Computers (AREA)
  • Data Exchanges In Wide-Area Networks (AREA)
  • Communication Control (AREA)
  • Two-Way Televisions, Distribution Of Moving Picture Or The Like (AREA)

Abstract

【課題】P2P基盤のストリーミングサービスでバッファリングを行うシステムおよび方法、並びにクライアントでバッファリングを処理するアプリケーションを配布するシステムを提供する。
【解決手段】本発明の一実施形態に係るアプリケーションを配布するシステムは、ストリーミングサービスを提供するサーバまたはストリーミングサービスが提供される少なくとも一つの他のピアからデータストリームのピースを受信して第1バッファに格納し、格納されたピースのうちコンテンツの再生に用いられたピースの少なくとも一部を第2バッファに格納するようにクライアントで動作するアプリケーションをクライアントに配布することを特徴する。
【選択図】図10

Description

本発明の実施形態は、P2P基盤のストリーミングサービスでバッファリングを行うシステムおよび方法、並びにクライアントでバッファリングを処理するアプリケーションを配布するシステムに関する。
P2Pサービス(Peer to Peer Service)は、インターネット上の情報を検索エンジンを経由し検索しなければならない既存方式とは異なり、インターネットに接続された全てのパーソナルコンピュータから直接に情報の提供を受けるサービスである。
また、一般的に「ストリーミング」とは、ネットワークを介してファイルをリアルタイムに受信して再生する技術であり、最も多く用いられる技術としてプログレッシブストリーミング(progressive streaming)がある。
このようなストリーミング技術をP2P技術に用いる場合、サーバおよびサービス側の負荷を減らすことができるため、コスト軽減という効果を奏し得る。これを実現するために、P2P基盤のストリーミングサービスを用いるクライアントは、マルチメディアファイルのようなコンテンツを再生させる専用プレーヤに、P2P基盤のストリーミングサービスを用いるために必要な機能を搭載し、P2P基盤のストリーミングをサービスするサーバと通信してP2P基盤のストリーミングサービスの実現を図る。より具体的に説明すると、サーバがウェブページを介して提供可能なコンテンツインデックスをユーザに提供し、クライアントはこのインデックスからサービスされるコンテンツをクリックして選択する。そして、サービスされるコンテンツが選択されると、クライアントにインストールされている専用プレーヤが実行されて選択されたコンテンツが再生される。このとき、専用プレーヤは、P2P技術を用いて選択されたコンテンツをサーバおよび他のピア(peer)から受信して再生する。
P2P基盤のストリーミングサービスを利用しようとするユーザクライアントがサーバに接続された後、ユーザクライアントからコンテンツが選択されると、選択されたコンテンツを保有しているピアを検索してユーザクライアントにコンテンツが提供されるように連結させる。すなわち、ユーザクライアントの専用プレーヤは、選択されたコンテンツのファイルをサーバまたはコンテンツを保有している他のピアに受信して再生する。
このとき、従来技術に係るP2P基盤のストリーミングサービスでは、ピアのネットワーク状況に応じて、ピア間、およびピアとサーバとの間の同期化を維持することが困難になることがある。このような場合に、そのようなピア間、およびピアとサーバとの間の同期化が行われない場合、データの共有率が低下してしまう虞がある。
本明細書では、P2P基盤のストリーミングサービスにおいて、ピア間またはピアとサーバとの間に同期化を効率的に行ってデータの共有率を極大化することのできるシステムおよび方法が提供される。
本発明の目的は、ピア間の同期化が行われない場合にも、コンテンツの再生に既に用いられたピースを捨てることなく、一定の量を追加的にバッファリングすることによって、ピア間のデータの共有率を極大化することのできるバッファリングシステムおよび方法を提供する。
本発明の目的は、ネットワーク状況に応じて送信されたデータストリームのピースを格納するバッファの大きさを動的に調整することによって、ピア間の同期化およびピアとサーバとの間の同期化を維持して共有率の低下を防止することのできるバッファリングシステムおよび方法を提供する。
本発明の目的は、バッファの大きさを動的に増加(または減少)させるものの、コンテンツの再生に既に用いられたピースをバッファリングするバッファの大きさを同一の大きさだけ減少(または増加)させて、全体のバッファの大きさを同一に維持することのできるバッファリングシステムおよび方法を提供する。
アプリケーションを配布するシステムであって、ストリーミングサービスを提供するサーバまたはストリーミングサービスが提供される少なくとも一つの他のピアからデータストリームのピースを受信して第1バッファに格納し、格納されたピースのうちコンテンツの再生に用いられたピースの少なくとも一部を第2バッファに格納するようにクライアントで動作するアプリケーションをクライアントに配布することを特徴とするシステムが提供される。
本発明の一実施形態によると、第1バッファおよび第2バッファに格納されたピースは、ストリーミングサービスが提供される少なくとも一つの他のクライアントに送信可能であってもよい。
他の一実施形態によると、ネットワーク状況に応じて第1バッファの大きさがアプリケーションによって動的に調整されてもよい。
また、他の一実施形態によると、アプリケーションは、第1バッファの大きさを増加させた分だけ第2バッファの大きさを減少させ、または第1バッファの大きさを減少させた分だけ第2バッファの大きさを増加させることにより、第1バッファおよび第2バッファを含む全体バッファの大きさを同一に維持してもよい。
また、他の一実施形態によると、第1バッファは順次にピースを受信するためのピース選択方法であるプログレッシブを用いて、デリバリーサーバを介して受信されたピースが格納される第1領域、少なくとも一つの他のクライアントからプログレッシブを用いて受信されたピースが格納される第2領域、およびネットワーク上で最も希有なピースを先に受信するためのピース選択方法である「Rarest First」を用いて少なくとも一つの他のクライアントから受信されたピースが格納される第3領域を含んでもよい。
また、他の一実施形態によると、ネットワーク状況に応じて第3領域の大きさがアプリケーションによって動的に調整されて第1バッファの大きさが調整されてもよい。
また、他の一実施形態によると、ネットワーク状況は、クライアントにおけるダウンロードの速度およびアップロードの速度のうち少なくとも一つを含んでもよく、第1バッファの大きさはダウンロードの速度およびアップロードの速度のうち少なくとも一つによってアプリケーションに応じて動的に調整されてもよい。
また、他の一実施形態によると、サーバは、複数のパケット化サーバを含み、複数のパケット化サーバは、それぞれ同一数のパケット化サーバを含む主パケット化サーバ群と副パケット化サーバ群とに分類され、主パケット化サーバ群の障害発生時に副パケット化サーバ群が主パケット化サーバ群を代替してもよい。
また、他の一実施形態によると、サーバは、複数のデリバリーサーバを含み、ストリーミングサービスを提供するシステムにおいて、同時接続者数に応じて用いられる複数のデリバリーサーバの数を調整することによってトラフィックが調整されてもよい。
ストリーミングサービスを提供するサーバまたはストリーミングサービスが提供される少なくとも一つの他のピアから送信されたデータストリームのピースを第1バッファに格納するステップと、格納されたピースのうちコンテンツの再生に用いられたピースの少なくとも一部を第2バッファに格納するステップとを含み、第1バッファおよび第2バッファに格納されたピースは、ストリーミングサービスが提供される少なくとも一つの他のピアに送信可能であることを特徴とするバッファリング方法が提供される。
本発明によると、ピア間に同期化が行われない場合にもコンテンツの再生に既に用いられたピースを捨てることなく一定の量を追加的にバッファリングすることによって、ピア間にデータの共有率を極大化することができる。
本発明によると、ネットワーク状況に応じて送信されたデータストリームのピースを格納するバッファの大きさを動的に調整することによって、ピア間の同期化およびピアとサーバとの間の同期化を維持して共有率の低下を防止することができる。
本発明によると、バッファの大きさを動的に増加(または減少)させるものの、コンテンツの再生に既に用いられたピースをバッファリングするバッファの大きさを同一の大きさだけ減少(または増加)させて、全体のバッファの大きさを同一に維持することができる。
本発明の一実施形態に係るP2P基盤のストリーミングサービスを提供するシステムの論理的な構成を示す図である。 本発明の一実施形態に係るP2P基盤のストリーミングサービスを提供するシステムの物理的な構成を示す図である。 本発明の一実施形態に係るパケット化サーバの二重化を説明するための図である。 本発明の一実施形態に係るデリバリーサーバの二重化を説明するための図である。 本発明の一実施形態に係るインデックスサーバの二重化を説明するための図である。 本発明の一実施形態に係るピア管理システムを示す図である。 本発明の一実施形態に係るピアで利用可能なバッファを説明するための図である。 本発明の一実施形態に係るコンテンツの再生に用いられたピースをバッファリングするためのバッファの一例を示す図である。 本発明の一実施形態に係る領域ごとの大きさの調整が可能なピアのバッファの一例を示す図である。 本発明の一実施形態に係るバッファリングシステムの内部構成を説明するためのブロック図である。 本発明の一実施形態に係るバッファリング方法を示すフローチャートである。
以下、本発明の実施形態を添付する図面を参照しながら詳細に説明する。
図1は、本発明の一実施形態に係るP2P基盤のストリーミングサービスを提供するシステムの論理的な構成を示す図である。図1は、メディアソース110、パケット化サーバ120、デリバリーサーバグループ130、クライアント140、および複数のピア150を示している。
ここで、メディアソース110は、データストリームを提供するエンコーダを意味する。パケット化サーバ120は、このようなメディアソース110からデータストリームを受信してピースにインデックスしてもよい。データストリームをP2Pサービスを介して提供するためにピースにインデックスする方法は、既に公知された様々な方法の一つの方法を用いてもよい。パケット化サーバ120はメディアソース110ごとに一つずつ存在してもよい。例えば、プロ野球を中継するときに4つの試合が行われる場合、4つの試合に対して4つのメディアソース110が存在すれば、パケット化サーバ120も4つ用いてもよい。このようなパケット化サーバ120については図3を参照してより詳しく説明する。
デリバリーサーバグループ130は、少なくとも一つのデリバリーサーバ131から構成されてもよい。このとき、デリバリーサーバグループ130で動作するデリバリーサーバ131の数は同時接続者数に応じて調整してもよい。デリバリーサーバ131は、パケット化サーバ120からインデックスされたピースを受信し、これをバッファリングしてもよい。このとき、クライアント140のリクエストに応じてピースをクライアント140に送信してもよい。
ここで、クライアント140はPCのようなユーザ端末を意味し、図1に示すようにピア141とプレーヤ142を含んでもよい。ピア141は、デリバリーサーバ131と複数のピア150のうち、少なくとも一つからピースを受信してプレーヤ142にデータストリームを送信してもよい。一例として、ピア141は、クライアント140にインストールされて動作するプログラムであってもよい。複数のピア150も複数のクライアントにインストールされて動作するようにしてもよい。
すなわち、パケット化サーバ120からピースに変換されたデータストリームは、デリバリーサーバグループ130を介して全体クライアントのうち少なくとも一部に送信されてもよく、一つのクライアント140の立場からは、デリバリーサーバ131と他のクライアントからピースを受信してデータストリームをプレーヤ142に送信することによって、ユーザはP2P基盤のストリーミングサービスが提供されるようになる。
このとき、本発明の一実施形態に係るサーバ使用量調整システムは、図1を参照して説明したシステムそのものを意味し、必要に応じて図1を参照して説明したシステムに含まれ、関連していてもよい。サーバ使用量調整システムは、同時接続者数を考慮して適応的にサーバ使用量を調整することによって、同時接続者数に関係なく常に低いサーバトラフィックを維持することができる。このとき、サーバ使用量は、同時接続者の流入率を用いて決定される定数の現在の同時接続者数の比率に基づいて調整されてもよい。一例として、サーバ使用量を下記の数式(1)のように算出されてもよい。
サーバ使用量=c/n …数式(1)
ここで、「c」は同時接続者の流入率を用いて決定される定数、「n」は現在の同時接続者数をそれぞれ意味する。このとき、「c」は経験的テストを介して管理者やシステムによって決定される定数として、基本的には同時接続者の流入率が高いほど相対的に大きい値に決定されてもよく、流入率が低いほど相対的に小さい値に決定されてもよい。このような数式(1)は「c」名のトラフィックとして、「n」名のユーザをカバーすることを意味する。例えば、「c」が6であれば、6人に提供するためのトラフィックであり、「n」名(現在の同時接続者)の全てをカバーすることを意味する。
すなわち、同時接続者の流入率が高まって現在の同時接続者数が増加しても、定数である「c」は固定される一方、「n」が増加するためサーバ使用量は次第に減少することになる。したがって、同時接続者数に関係なく、常に低いサーバ使用量を維持することができる。
このために、サーバ使用量調整システムは、現在の同時接続者数を提供する現在の同時接続者数提供部(図示せず)および同時接続者の流入率を用いて決定される定数の現在の同時接続者数の比率に基づいて、サーバ使用量を調整するサーバ使用量調整部(図示せず)を備えてもよい。
図2は、本発明の一実施形態に係るP2P基盤のストリーミングサービスを提供するシステムの物理的な構成を示す図である。図2は、P2P基盤のストリーミングサービスのための装備を提供する外部IDC210、データストリームを提供するエンコーダ業者220、および外部IDC210がクライアント240にデータストリームを提供する過程を管理するための内部IDC230を示している。
外部IDC210は、パケット化サーバ211、メインネットチェッカー213、サブネットチェッカー214、デリバリーサーバ212、およびインデックスサーバ215、並びに複数のスイッチ216を備えてもよい。ここで、パケット化サーバ211、デリバリーサーバ212、メインネットチェッカー213、サブネットチェッカー214、およびインデックスサーバ215は、それぞれ一つのサーバではない複数のサーバから構成されてもよく、複数のスイッチ216は、それぞれ複数のサーバのうち該当するサーバにデータを送信したり、該当するサーバからデータを受信するために用いられてもよい。複数のスイッチ216はそれぞれ一例としてL4スイッチを用いてもよい。
パケット化サーバ211は、エンコーダ業者220のメディアエンコーダ221からデータストリームを受信し、受信されたデータストリームをシステムで用いるためのデータに加工する。すなわち、パケット化サーバ211はデータストリームを複数のピースに変換してもよい。既に説明したように、メディアエンコーダ221ごとに一つずつのパケット化サーバ211で実行されてもよい。
デリバリーサーバ212は、パケット化サーバ211から受信したピースをクライアント240のリクエストに応じてクライアント240に送信する。また、インデックスサーバ215は、クライアント240のインデックスを維持して検索サービスを提供する。ここで、メインネットチェッカー213とサブネットチェッカー214はピア間の接続を中継する中継サーバを意味する。
次の表1は、同時接続者数が15万人であり、コンテンツビットレートが500kbps、共有率が80%である場合に必要なサーバの数を示している。
Figure 2012150809
内部IDC230が含んでいるLMS231は、ピア管理システムを意味する。このようなLMS231は、パケット化サーバ211、デリバリーサーバ212、およびインデックスサーバ215を管理するサーバとして、サーバのアップロードやダウンロード状態またはトラフィック、クエリ数、リソース(CPU、メモリ)、共有率などをモニタリングしてもよい。また、LMS231は、同時接続者数、ユニーク訪問者数、共有率、ユーザの速度分布、平均視聴時間、および視聴チャネル数などの統計データを生成してDB232に格納してもよい。すなわち、DB232は統計データを格納するサーバを意味する。
このとき、上述したように本発明の一実施形態に係るシステムは、同時接続者数を考慮して適応的にサーバ使用量を調整することによって、同時接続者数に関係なく、常に低いサーバトラフィックを維持することができる。このとき、サーバ使用量は、同時接続者の流入率を用いて決定される定数である現在の同時接続者数の比率に基づいて調整してもよい。一例として、サーバ使用量を前述した数式(1)のように算出してもよく、このようなサーバ使用量は、図2を参照して説明したデリバリーサーバ212のトラフィックを意味する。また、図1を参照して説明したサーバ使用量調整システムは、図2を参照して説明したシステムそのものを意味し、前述したLMS231に含まれてもよい。
図3は、本発明の一実施形態に係るパケット化サーバの二重化を説明するための図である。図3は、4個のエンコーダ310〜340によってデータストリームが提供される場合、主パケット化サーバ群350で4個のパケット化サーバが動作する可能性があることを示している。すなわち、「PS−1」、「PS−2」、「PS−3」および「PS−4」は前述した4個のパケット化サーバを意味する。
このとき、4個のパケット化サーバは、4個のエンコーダ310〜340から受信されるデータストリームをP2Pで用いられる形態のデータに変換し、全てのデリバリーサーバに変換されたデータを送信してもよい。このとき、4個のパケット化サーバと全てのデリバリーサーバは、スイッチ370を用いてデータを送受信してもよい。
このようなパケット化サーバは、CPUやトラフィックなどのリソースの使用量が多くない。例えば、20台のデリバリーサーバ(同時接続者数15万人基準)が接続した場合、1Mbpsの大きさのコンテンツに対して20Mbpsのトラフィックのみを用いる。
また、パケット化サーバごとに4個のエンコーダ310〜340から互いに異なるデータストリームが送信されるため、図3に示すように、ピースは主パケット化サーバ群350と副パケット化サーバ群360のうち、一つのサーバ群でのみ生成されなければならない。したがって、主パケット化サーバ群350と副パケット化サーバ群360はアクティブ/スタンバイの形態で動作してもよい。副パケット化サーバ群360は、主パケット化サーバ群350の障害に対応するために用いられてもよい。
図4は、本発明の一実施形態に係るデリバリーサーバの二重化を説明するための図である。パケット化サーバ群410で変換されたデータであるピースはデリバリーサーバ群420に送信される。このとき、「DS−n」は「n」番目のデリバリーサーバを意味し、デリバリーサーバ群420内に「n」個のデリバリーサーバが存在することを意味する。
各デリバリーサーバは、パケット化サーバからピースが送信されて一定の数だけバッファリングを行って、クライアントのピアのリクエストに応じて該当ピースをピアに送信する。このとき、デリバリーサーバ群420のデリバリーサーバもスイッチ430にバインディングされてもよく、同時接続者数の増加に応じてデリバリーサーバを増加させることでトラフィックを調整することができる。
図5は、本発明の一実施形態に係るインデックスサーバの二重化を説明するための図である。インデックスサーバ群510は、複数のインデックスサーバを含んでもよく、「IS−n」は「n」番目のインデックスサーバを意味し、インデックスサーバ群510内に「n」個のインデックスサーバが存在することを意味する。
このとき、複数のインデックスサーバのそれぞれはクライアントのピアを管理する。より詳しくは、クライアントにインストールされたピアを管理し、ピアのリクエストに応じる検索結果を送信する。また、インデックスサーバはメッセージ送信を行なってもよく、ピアと持続的な接続を維持することができる。このようなインデックスサーバそれぞれはスイッチ520とバインディングしてもよく、同時接続者数に応じてインデックスサーバを増加させてもよい。
図6は、本発明の一実施形態に係るピア管理システムを示す図である。図6に示されたLMS610はピア管理システムを、IS620はインデックスサーバを、PS630はパケット化サーバを、DS640はデリバリーサーバをそれぞれ意味する。このとき、ピア管理システムは、インデックスサーバ、パケット化サーバ、およびデリバリーサーバに対する管理、配布、更新、およびモニタリング機能を行い、ピアに対する統計収集および分析機能を行なってもよい。例えば、ピア管理システムは、CPUやメモリの使用量またはトラフィックのように前述したサーバの状態をモニタリングし、障害状況に対するイベント通知機能(例えば、SMSまたはe−mailなど)を提供してもよい。
図7は、本発明の一実施形態に係るピアで利用可能なバッファを説明するための図である。ピアは上述したように、クライアントにインストールされて動作できるソフトウェアとして、いずれのピースをどこから受信するかを決定する。次の表2は、ピアにおけるピースの選択方法と受信可能なソースを示している。
Figure 2012150809
表2において「Rarest First」は、ネットワーク上で最も希有な(rare)ピースを先に受信するピース選択方法を意味し、「Progressive」は前から順次にピースを受信するピース選択方法を意味する。このとき、ピースはデリバリーサーバを介して受信したり他のピアから受信してもよい。
このとき、ピアは再生を円滑にして共有効率を上げるために、受信されたピースを格納するバッファを用いてもよい。図7は、第1バッファ710〜第3バッファ730を示している。
まず、第1バッファ710は、「Progressive」を介して受信されたピースを格納するための第1範囲711と、「Rarest First」を介して受信されたピースを格納するための第2範囲712とに分類してもよい。同時に、第1バッファ710は、デリバリーサーバを介して受信されたピースを格納するための第3範囲713と他のピアを介して受信されたピースを格納するための第4範囲714とに分類してもよい。
第2バッファ720は、実際に分離されたバッファの領域を示している。すなわち、第2バッファ720はデリバリーサーバを介して「Progressive」に受信されたピースを格納するための第1領域721、他のピアを介して「Progressive」に受信されたピースを格納するための第2領域722、および他のピアを介して「Rarest First」に受信されたピースを格納するための第3領域723に区分してもよい。
第3バッファ730は、分離された領域の大きさが互いに異なることを示している。すなわち、第3バッファ730は、領域A731、領域B732、および領域C733がそれぞれ互いに異なる大きさの比率で構成された一例を示す。一例として、領域A731、領域B732、領域C733の大きさの比率は1:4:16の比率を有してもよい。このような比率は必要に応じて調整されてもよい。また、必要に応じて領域B732と領域C733にも一定部分のピースがデリバリーサーバから受信されて格納してもよい。
このとき、ピアとピアとの間の同期化が行われない場合には、共有率の低下が生じることがある。このような場合において、共有率を極大化するために、本発明の実施形態に係るピアは、コンテンツの再生されて用いられたピースを捨てることなく、一定の量をバッファリングするためのバッファ(以下、「Z−Buffer」という。)をさらに用いてもよい。
図8は、本発明の一実施形態に係るコンテンツの再生に用いられたピースをバッファリングするためのバッファの一例を示す図である。図8において、第1点線ボックス810は、第1ピアバッファおよび第2ピアバッファを示している。また、第1点線ボックス810には、第1ピアと第2ピアとの間に同期化が行われない場合の共有可能なバッファの大きさ811を示している。すなわち、第1ピアと第2ピアとの間に同期化が行われない場合、データの共有率は減少する。第2点線ボックス820は、「Z−Buffer」を用いることで共有可能なバッファの大きさ821を増加させることによって、データの共有率を極大化することが可能であることを示している。
一般的に、バッファリングは、ストリーミングサービスでコンテンツの再生を円滑にして共有効率も高めることができるが、ディレイによって画面が遅れる短所があることから、バッファリングの使用を最小化しなければならない。しかし、上述したように、バッファリングを最小化するためのバッファの大きさを用いる場合、ピア間の同期化が行われないのであれば、共有率が減少してしまう問題が発生する。したがって、本発明の実施形態に係るピアでは、既に再生したピースの一定の量を捨てることなく、追加的にバッファリングすることによって、バッファリングの使用を最小化すると同時に共有率を極大化することを可能にする。
また、P2Pストリーミングサービスでは、既に説明したように、ピアのネットワーク状況に応じて、ピア間、またはピアとサーバとの間の同期化を維持することが困難になり、これにより、共有率の低下が生じることがある。そこで、本発明の実施形態に係るピアは、全体のバッファの大きさは維持するものの、既存のバッファの大きさと「Z−Buffer」の大きさを動的に調整することによって、ピア間およびピアとサーバとの間の同期化を維持することを可能にする。
図9は、本発明の一実施形態に係る領域ごとの大きさの調整が可能なピアのバッファの一例を示す図である。ここで、領域C910は、図7において、他のピアを介して「Rarest First」に受信されたピースを格納するための領域であることを既に説明したものである。図9に示す実施形態によれば、このような領域C910のバッファの大きさを第1大きさ920から第2大きさ930に増加させ、同時に「Z−Buffer」の大きさを第3大きさ940から第4大きさ950に減少させてもよい。これにより、全体のバッファの大きさが一定に維持され得る。
すなわち、ピアのネットワーク状況が悪い場合、ピア間およびピアとサーバとの間の同期化を維持することが困難であり、同期化が維持されない場合に共有率は低下する。したがって、本発明の実施形態に係るピアは、既存のバッファの大きさと「Z−Buffer」の大きさを動的に調整することによって、同期化を維持させることで共有率の低下を防止することができる。
言い換えれば、既に再生したピースの一定の量をバッファリングする「Z−Buffer」を用いることによりピア間に同期化が行われないためバッファリングされるピースがずれた場合にも、共有できる部分を増加させることによって共有率を極大化することができる。また、既存のバッファの大きさと「Z−Buffer」の大きさを動的に調整することによって、ピア間およびピアとサーバとの間の同期化を維持することができる。
前述したネットワーク状況は、ピアにおけるダウンロードの速度およびアップロードの速度のうち、少なくとも一つのネットワークの状態を、測定可能な全ての要素のうち少なくとも1つによって決定してもよく、このようなネットワーク状況に応じてバッファの大きさを決定してもよい。
図9には、領域C910の大きさと、「Z−Buffer」の大きさを同時に調整する一例のみを説明したが、必要に応じて領域Aまたは領域Bの大きさを調整してもよく、3つの領域のうち2つ以上の領域の大きさを調整してもよい。
図10は、本発明の一実施形態に係るバッファリングシステムの内部構成を説明するためのブロック図である。本実施形態に係るバッファリングシステム1000は、前述したピア、すなわち、P2Pストリーミングサービスが提供されるクライアント端末のように、バッファリングが必要な端末に含まれて動作してもよい。このとき、バッファリングシステム1000は、図10に示すように、格納部1010を備え、必要に応じてバッファ大きさ調整部1020をさらに備える。
格納部1010は、ストリーミングサービスを提供するサーバ、またはストリーミングサービスが提供される少なくとも一つの他のピアから送信されたデータストリームのピースを第1バッファに格納し、格納されたピースのうち、コンテンツの再生に用いられたピースの少なくとも一部を第2バッファに格納する。このとき、第1バッファおよび第2バッファに格納されたピースは、ストリーミングサービスが提供される少なくとも一つの他のピアに提供されてもよい。すなわち、ピア間の同期化が合わない場合にも第2バッファを用いて既に再生に用いられたピースを捨てることなく一定の量を追加的にバッファリングすることによって、既に再生に用いられたピースをまだ受信されていない他のピアに送信することができることから、ピア間のデータの共有率を極大化することができる。
バッファ大きさ調整部1020は、ネットワーク状況に応じて第1バッファの大きさを動的に調整する。このとき、バッファ大きさ調整部1020は、第1バッファの大きさを増加させた分だけ第2バッファの大きさを減少させたり、第1バッファの大きさを減少させた分だけ第2バッファの大きさを増加させることにより、全体のバッファの大きさを同一に維持できるように調整する。ここで、一例として、ネットワーク状況は、ピアにおけるダウンロードの速度およびアップロードの速度のうち少なくとも一つを含んでもよい。この場合、バッファ大きさ調整部1020は、ダウンロードの速度およびアップロードの速度のうち少なくとも一つに応じて第1バッファおよび第2バッファの大きさを調整してもよい。例えば、ダウンロードの速度およびアップロードの速度のうち少なくとも一つの範囲に応じて予め第1バッファの大きさを決定してもよい。この場合、バッファ大きさ調整部1020は、現在のダウンロードの速度およびアップロードの速度のうち少なくとも一つによって予め決定された大きさに第1バッファの大きさを増加または減少させてもよい。
このとき、第1バッファは、順次にピースを受信するためのピース選択方法であるプログレッシブを用いてサーバから受信されたピースを格納するための第1領域、プログレッシブを用いて少なくとも一つの他のピアから受信されたピースを格納するための第2領域、およびネットワーク上で最も希有なピースを先に受信するためのピース選択方法である「Rarest first」を用いて、少なくとも一つの他のピアから受信されたピースを格納するための第3領域を含んでもよい。この場合、バッファ大きさ調整部1020は、第3領域の大きさを調整して第1バッファの大きさを調整してもよい。
図11は、本発明の一実施形態に係るバッファリング方法を示すフローチャートである。本実施形態に係るバッファリング方法は、図10を参照して説明したバッファリングシステム1000によって行われてもよい。図11を参照し、バッファリングシステム1000によって各ステップが行われる過程を説明することにより、本発明の一実施形態に係るバッファリング方法について説明する。
ステップS1110において、バッファリングシステム1000は、ストリーミングサービスを提供するサーバまたはストリーミングサービスが提供される少なくとも一つの他のピアから送信されたデータストリームのピースを第1バッファに格納する。
ステップS1120において、バッファリングシステム1000は、格納されたピースのうちコンテンツの再生に用いられたピースの少なくとも一部を第2バッファに格納する。このとき、第1バッファおよび第2バッファに格納されたピースはストリーミングサービスが提供される少なくとも一つの他のピアに提供されてもよい。すなわち、ピア間の同期化が合わない場合にも第2バッファを用いて既に再生に用いられたピースを捨てることなく一定の量を追加的にバッファリングすることによって、既に再生に用いられたピースをまだ受信されていない他のピアに送信することができることから、ピア間のデータの共有率を極大化することができる。
ステップS1130において、バッファリングシステム1000は、ネットワーク状況に応じて第1バッファの大きさを動的に調整する。このとき、バッファリングシステム1000は、第1バッファの大きさを増加させた分だけ第2バッファの大きさを減少させ、または第1バッファの大きさを減少させた分だけ第2バッファの大きさを増加させることによって、全体のバッファの大きさが同一に維持されるように調整する。ここで、一例として、ネットワーク状況は、ピアにおけるダウンロードの速度およびアップロードの速度のうち少なくとも一つを含んでもよい。このとき、バッファリングシステム1000は、ダウンロードの速度およびアップロードの速度のうち少なくとも一つに応じて第1バッファおよび第2バッファの大きさを調整してもよい。例えば、ダウンロードの速度およびアップロードの速度のうち少なくとも一つの範囲に応じて第1バッファの大きさを予め決定してもよい。このとき、バッファリングシステム1000は、現在のダウンロードの速度およびアップロードの速度のうち少なくとも一つに応じて予め決定された大きさに第1バッファの大きさを増加または減少させてもよい。
このとき、第1バッファは、順次にピースを受信するためのピース選択方法であるプログレッシブを用いてサーバから受信されたピースを格納するための第1領域、プログレッシブを用いて少なくとも一つの他のピアから受信されたピースを格納するための第2領域、およびネットワーク上で最も希有なピースを先に受信するためのピース選択方法である「Rarest First」を用いて少なくとも一つの他のピアから受信されたピースを格納するための第3領域を含んでもよい。この場合、バッファリングシステム1000は、第3領域の大きさを調整することにより第1バッファの大きさを調整してもよい。
他の実施形態に係るバッファリング方法は、実質的にバッファリングシステム1000の役割を担い、クライアント端末に設けられるアプリケーションによって行われてもよい。このとき、このようなアプリケーションをクライアントに配布するシステムは、P2P基盤のストリーミングサービスを提供するシステムに含まれていてもよく、またはP2P基盤のストリーミングサービスを提供するシステムに関連するシステムであってもよい。
前述したアプリケーションは、ストリーミングサービスを提供するサーバまたはストリーミングサービスが提供される少なくとも一つの他のピアからデータストリームのピースを受信して第1バッファに格納し、格納されたピースのうちコンテンツの再生に用いられたピースの少なくとも一部を第2バッファに格納するようにクライアントで動作してもよい。
第1バッファおよび第2バッファに格納されたピースは、ストリーミングサービスが提供される少なくとも一つの他のクライアントに送信可能であり、ネットワーク状況に応じて第1バッファの大きさがアプリケーションによって動的に調整されてもよい。このとき、アプリケーションは、第1バッファの大きさを増加させた分だけ第2バッファの大きさを減少させ、または第1バッファの大きさを減少させた分だけ第2バッファの大きさを増加させることにより、第1バッファおよび第2バッファを含む全体のバッファの大きさを同一に維持することができる。
また、第1バッファは、順次にピースを受信するためのピース選択方法であるプログレッシブを用いてデリバリーサーバによって受信されたピースが格納される第1領域、少なくとも一つの他のクライアントからプログレッシブを用いて受信されたピースが格納される第2領域、およびネットワーク上で最も希有なピースを先に受信するためのピース選択方法である「Rarest First」を用いて、少なくとも一つの他のクライアントから受信されたピースが格納される第3領域を含んでもよい。この場合には、ネットワーク状況に応じて第3領域の大きさがアプリケーションによって動的に調整されて第1バッファの大きさを調整してもよい。
ネットワーク状況は、クライアントにおけるダウンロードの速度およびアップロードの速度のうち少なくとも一つを含んでもよく、この場合、第1バッファの大きさはダウンロードの速度およびアップロードの速度のうち少なくとも一つに応じてアプリケーションによって動的に調整されてもよい。
ストリーミングサービスを提供するサーバは、複数のパケット化サーバを含んでもよく、この場合、複数のパケット化サーバは、それぞれの同一数のパケット化サーバを含む主パケット化サーバ群と副パケット化サーバ群とに分類され、主パケット化サーバ群の障害時に副パケット化サーバ群が主パケット化サーバ群を代替してもよい。
また、ストリーミングサービスを提供するサーバは、複数のデリバリーサーバを含んでもよく、この場合、ストリーミングサービスを提供するシステムにおいて、同時接続者数に応じて用いられる複数のデリバリーサーバの数を調整することによってトラフィックを調整してもよい。
もちろん、ストリーミングサービスを提供するサーバは、複数のパケット化サーバと複数のデリバリーサーバとを全て含んでもよい。
このように、本発明の実施形態に係るバッファリングシステムおよび方法を用いると、ピア間に同期化が行われない場合にもコンテンツの再生に既に用いられたピースを捨てることなく一定の量を追加的にバッファリングすることによって、ピア間にデータの共有率を極大化することができる。また、ネットワーク状況に応じて送信されたデータストリームのピースを格納するバッファの大きさを動的に調整することによって、ピア間およびピアとサーバとの間の同期化を維持することにより、共有率の低下を防止することができる。また、バッファの大きさを動的に増加(または減少)させるものの、コンテンツの再生に既に用いられたピースをバッファリングするバッファの大きさを同一の大きさだけ減少(または増加)させることにより、全体のバッファの大きさを同一に維持することができる。
本発明の実施形態に係る方法は、多様なコンピュータ手段を介して様々な処理を実行することができるプログラム命令の形態で実現され、コンピュータ読取可能な記録媒体に記録されてもよい。コンピュータ読取可能な媒体は、プログラム命令、データファイル、データ構造などのうちの一つまたはその組合せを含んでもよい。媒体に記録されるプログラム命令は、本発明の目的のために特別に設計されて構成されたものでもよく、コンピュータソフトウェア分野の技術を有する当業者にとって公知のものであり、使用可能なものであってもよい。コンピュータ読取可能な記録媒体の例としては、ハードディスク、フロッピー(登録商標)ディスク及び磁気テープのような磁気媒体、CD−ROM、DVDのような光記録媒体、光ディスクのような光磁気媒体、及びROM、RAM、フラッシュメモリなどのようなプログラム命令を保存して実行するように特別に構成されたハードウェア装置が含まれてもよい。プログラム命令の例としては、コンパイラによって生成されるような機械語コード(machine code)だけでなく、インタプリタなどを用いてコンピュータによって実行され得る高級言語コード(higher level code)を含む。上述したハードウェア装置は、本発明の動作を行うために一つ以上のソフトウェアのレイヤで動作するように構成されてもよい。
上述したように、本発明を限定された実施形態と図面によって説明したが、本発明は、上記の実施形態に限定されることなく、本発明が属する分野における通常の知識を有する者であれば、このような実施形態から多様な修正及び変形が可能である。
したがって、本発明の範囲は、開示された実施形態に限定されるものではなく、特許請求の範囲だけではなく特許請求の範囲と均等なものなどによって定められるものである。
1000 バッファリングシステム
1010 格納部
1020 バッファ大きさ調整部

Claims (16)

  1. アプリケーションを配布するシステムであって、
    ストリーミングサービスを提供するサーバまたは前記ストリーミングサービスが提供される少なくとも一つの他のピアからデータストリームのピースを受信して第1バッファに格納し、前記格納されたピースのうちコンテンツの再生に用いられたピースの少なくとも一部を第2バッファに格納するようにクライアントで動作する前記アプリケーションを前記クライアントに配布することを特徴とするシステム。
  2. 前記第1バッファおよび前記第2バッファに格納されたピースは、前記ストリーミングサービスが提供される少なくとも一つの他のクライアントに送信可能であることを特徴とする請求項1に記載のシステム。
  3. ネットワーク状況に応じて前記第1バッファの大きさが前記アプリケーションによって動的に調整されることを特徴とする請求項1に記載のシステム。
  4. 前記アプリケーションは、前記第1バッファの大きさを増加させた分だけ前記第2バッファの大きさを減少させ、または前記第1バッファの大きさを減少させた分だけ前記第2バッファの大きさを増加させることにより、前記第1バッファおよび前記第2バッファを含む全体バッファの大きさを同一に維持することを特徴とする請求項3に記載のシステム。
  5. 前記第1バッファは順次にピースを受信するためのピース選択方法であるプログレッシブを用いて、前記デリバリーサーバを介して受信されたピースが格納される第1領域、前記少なくとも一つの他のクライアントから前記プログレッシブを用いて受信されたピースが格納される第2領域、およびネットワーク上で最も希有なピースを先に受信するためのピース選択方法である「Rarest First」を用いて前記少なくとも一つの他のクライアントから受信されたピースが格納される第3領域を含むことを特徴とする請求項1に記載のシステム。
  6. ネットワーク状況に応じて前記第3領域の大きさが前記アプリケーションによって動的に調整されて前記第1バッファの大きさが調整されることを特徴とする請求項5に記載のシステム。
  7. 前記ネットワーク状況は、クライアントにおけるダウンロードの速度およびアップロードの速度のうち少なくとも一つを含むことを特徴とする請求項3または請求項6に記載のシステム。
  8. 前記サーバは、複数のパケット化サーバを含み、
    前記複数のパケット化サーバは、それぞれ同一数のパケット化サーバを含む主パケット化サーバ群と副パケット化サーバ群とに分類され、前記主パケット化サーバ群の障害発生時に前記副パケット化サーバ群が前記主パケット化サーバ群を代替することを特徴とする請求項1に記載のシステム。
  9. 前記サーバは、複数のデリバリーサーバを含み、
    前記ストリーミングサービスを提供するシステムにおいて、同時接続者数に応じて用いられる前記複数のデリバリーサーバの数を調整することによってトラフィックが調整されることを特徴とする請求項1に記載のシステム。
  10. ストリーミングサービスを提供するサーバまたは前記ストリーミングサービスが提供される少なくとも一つの他のピアから送信されたデータストリームのピースを第1バッファに格納するステップと、
    前記格納されたピースのうちコンテンツの再生に用いられたピースの少なくとも一部を第2バッファに格納するステップと、
    を含み、
    前記第1バッファおよび前記第2バッファに格納されたピースは、前記ストリーミングサービスが提供される少なくとも一つの他のピアに送信可能であることを特徴とするバッファリング方法。
  11. ネットワーク状況に応じて前記第1バッファの大きさを動的に調整するステップをさらに含むことを特徴とする請求項10に記載のバッファリング方法。
  12. 前記動的に調整するステップは、前記第1バッファの大きさを増加させた分だけ前記第2バッファの大きさを減少させ、または前記第1バッファの大きさを減少させた分だけ前記第2バッファの大きさを増加させることにより、前記全体バッファの大きさを同一に維持するステップを含むことを特徴とする請求項11に記載のバッファリング方法。
  13. 前記第1バッファは順次にピースを受信するためのピース選択方法であるプログレッシブを用いて、前記デリバリーサーバを介して受信されたピースが格納される第1領域、前記少なくとも一つの他のクライアントから前記プログレッシブを用いて受信されたピースが格納される第2領域、およびネットワーク上で最も希有なピースを先に受信するためのピース選択方法である「Rarest First」を用いて前記少なくとも一つの他のクライアントから受信されたピースが格納される第3領域を含むことを特徴とする請求項10に記載のバッファリング方法。
  14. ネットワーク状況に応じて前記第3領域の大きさを調整して前記第1バッファの大きさを調整するステップをさらに含むことを特徴とする請求項13に記載のバッファリング方法。
  15. 前記ネットワーク状況は、ピアにおけるダウンロードの速度およびアップロードの速度のうち少なくとも一つを含むことを特徴とする請求項11または請求項14に記載のバッファリング方法。
  16. 請求項10乃至15のいずれか一項に記載のバッファリング方法を行うプログラムを記録したコンピュータで読み出し可能な記録媒体。
JP2012008429A 2011-01-19 2012-01-18 P2p基盤のストリーミングサービスでバッファリングを行うシステムおよび方法、並びにクライアントでバッファリングを処理するアプリケーションを配布するシステム Active JP5529177B2 (ja)

Applications Claiming Priority (4)

Application Number Priority Date Filing Date Title
KR10-2011-0005342 2011-01-19
KR1020110005342A KR101417890B1 (ko) 2011-01-19 2011-01-19 P2p 기반의 스트리밍 서비스에서 데이터 스트림을 패킷타이징하는 시스템 및 방법
KR1020110005923A KR101242830B1 (ko) 2011-01-20 2011-01-20 P2p 기반의 스트리밍 서비스에서 버퍼링을 수행하는 시스템 및 방법 그리고 클라이언트에서 버퍼링을 처리하는 어플리케이션을 배포하는 시스템
KR10-2011-0005923 2011-01-20

Publications (2)

Publication Number Publication Date
JP2012150809A true JP2012150809A (ja) 2012-08-09
JP5529177B2 JP5529177B2 (ja) 2014-06-25

Family

ID=46792949

Family Applications (3)

Application Number Title Priority Date Filing Date
JP2012008396A Pending JP2012151849A (ja) 2011-01-19 2012-01-18 P2p基盤のストリーミングサービスのデータストリームをパケット化するシステムおよび方法
JP2012008429A Active JP5529177B2 (ja) 2011-01-19 2012-01-18 P2p基盤のストリーミングサービスでバッファリングを行うシステムおよび方法、並びにクライアントでバッファリングを処理するアプリケーションを配布するシステム
JP2015149291A Active JP5934828B2 (ja) 2011-01-19 2015-07-29 P2p基盤のストリーミングサービスのデータストリームをパケット化するシステムおよび方法

Family Applications Before (1)

Application Number Title Priority Date Filing Date
JP2012008396A Pending JP2012151849A (ja) 2011-01-19 2012-01-18 P2p基盤のストリーミングサービスのデータストリームをパケット化するシステムおよび方法

Family Applications After (1)

Application Number Title Priority Date Filing Date
JP2015149291A Active JP5934828B2 (ja) 2011-01-19 2015-07-29 P2p基盤のストリーミングサービスのデータストリームをパケット化するシステムおよび方法

Country Status (2)

Country Link
US (2) US9736236B2 (ja)
JP (3) JP2012151849A (ja)

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2017126902A (ja) * 2016-01-14 2017-07-20 公立大学法人岩手県立大学 ミキサ装置及びライブ中継システム
JP7059509B1 (ja) 2019-03-27 2022-04-26 ストリームルート ピア・トゥ・ピアネットワークにおけるストリーミングコンテンツの配信方法

Families Citing this family (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR101212366B1 (ko) 2010-11-25 2012-12-13 엔에이치엔비즈니스플랫폼 주식회사 P2p 기반의 스트리밍 서비스에서 서버 사용량을 조절하는 시스템 및 방법
JP2012151849A (ja) 2011-01-19 2012-08-09 Nhn Business Platform Corp P2p基盤のストリーミングサービスのデータストリームをパケット化するシステムおよび方法
FR3034943B1 (fr) * 2015-04-07 2017-04-14 Streamroot Inc Procede de lecture en continu sur un equipement client d'un contenu diffuse au sein d'un reseau pair a pair
US10057337B2 (en) 2016-08-19 2018-08-21 AvaSure, LLC Video load balancing system for a peer-to-peer server network
CN109040231B (zh) * 2018-07-31 2021-06-11 优视科技新加坡有限公司 数据传输方法、装置、设备/终端/服务器及计算机可读存储介质
CN109347968B (zh) * 2018-11-07 2021-09-24 网宿科技股份有限公司 一种下载资源文件的数据块的方法、设备和系统
US10749949B2 (en) * 2018-11-19 2020-08-18 Palo Alto Research Center Incorporated Dynamic content distribution protocol for an enterprise environment
US11102272B2 (en) * 2019-12-19 2021-08-24 Wangsu Science and Technology Co., Ltd. Method and device for downloading resource file

Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH11312030A (ja) * 1998-02-06 1999-11-09 Nec Corp オンデマンドサ―バの電源オンオフの制御を可能にするオンデマンドシステム

Family Cites Families (52)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5233603A (en) 1988-04-21 1993-08-03 Nec Corporation Packet switch suitable for integrated circuit implementation
JP3192901B2 (ja) * 1995-01-13 2001-07-30 沖電気工業株式会社 可変速度データ送信装置及び可変速度データ受信装置
US6307487B1 (en) * 1998-09-23 2001-10-23 Digital Fountain, Inc. Information additive code generator and decoder for communication systems
JP2001069169A (ja) * 1999-08-27 2001-03-16 Nippon Telegr & Teleph Corp <Ntt> サーバ配置制御装置
JP2001244984A (ja) * 2000-03-01 2001-09-07 Nec Corp データ蓄積回路、データ蓄積装置、及びデータ蓄積方法
US7653706B2 (en) 2000-07-19 2010-01-26 Akamai Technologies, Inc. Dynamic image delivery system
WO2002035816A1 (fr) * 2000-10-26 2002-05-02 Mitsubishi Denki Kabushiki Kaisha Systeme de reseau de telephone internet, procede d'acces a un reseau et adaptateur pour dispositif vocal
JP2002208953A (ja) * 2001-01-09 2002-07-26 Brother Ind Ltd 通信システム
JP2004343417A (ja) 2003-05-15 2004-12-02 Comtech 2000:Kk VoIP多重化装置
KR101035219B1 (ko) * 2003-10-08 2011-05-18 디지털 파운튼, 인크. Fec-기반 신뢰도 제어 프로토콜
WO2005065084A2 (en) * 2003-11-13 2005-07-21 Commvault Systems, Inc. System and method for providing encryption in pipelined storage operations in a storage network
KR100496172B1 (ko) 2004-05-29 2005-06-17 주식회사 티나루 P2p 환경의 웹서버에서 중앙서버를 이용한 듀얼웹서비스 시스템 및 그 방법
KR100689443B1 (ko) 2004-08-21 2007-03-08 삼성전자주식회사 방송 데이터를 저장하기 위한 디지털 방송 시스템 및송수신 방법
US20080134258A1 (en) * 2005-08-12 2008-06-05 Stuart Goose Multi-Source and Resilient Video on Demand Streaming System for a Peer-to-Peer Subscriber Community
US7873035B2 (en) * 2005-12-19 2011-01-18 Audiocodes, Inc. Method and apparatus for voice-over-IP call recording and analysis
JP2007259000A (ja) * 2006-03-23 2007-10-04 Nec Corp データ転送装置及びデータ転送方法等
KR101176663B1 (ko) 2006-04-17 2012-08-23 주식회사 케이티 실시간 온라인 게임 서비스 시스템 및 그 방법
KR100805885B1 (ko) 2006-04-20 2008-02-20 고려대학교 산학협력단 Vod 서버 대수 예측산정 장치 및 그 동작방법
US20080201424A1 (en) * 2006-05-01 2008-08-21 Thomas Darcie Method and apparatus for a virtual concert utilizing audio collaboration via a global computer network
KR100967700B1 (ko) 2006-09-08 2010-07-07 주식회사 아이큐브 피-투-피 방식의 주문형 비디오 서비스 시스템
US9210085B2 (en) * 2006-10-05 2015-12-08 Bittorrent, Inc. Peer-to-peer streaming of non-live content
US20080098123A1 (en) 2006-10-24 2008-04-24 Microsoft Corporation Hybrid Peer-to-Peer Streaming with Server Assistance
US20080162670A1 (en) * 2006-12-04 2008-07-03 Swarmcast, Inc. Automatic configuration of embedded media player
CN101282281B (zh) 2007-04-03 2011-03-30 华为技术有限公司 一种媒体分发系统、装置及流媒体播放方法
US8019830B2 (en) 2007-04-16 2011-09-13 Mark Thompson Methods and apparatus for acquiring file segments
US8316146B2 (en) 2007-07-13 2012-11-20 Spotify Ab Peer-to-peer streaming of media content
US7710973B2 (en) * 2007-07-19 2010-05-04 Sofaer Capital, Inc. Error masking for data transmission using received data
US20090031370A1 (en) * 2007-07-23 2009-01-29 The Directv Group, Inc. Method and system for communicating broadband content availability through a satellite
US9237101B2 (en) * 2007-09-12 2016-01-12 Digital Fountain, Inc. Generating and communicating source identification information to enable reliable communications
KR100932265B1 (ko) * 2007-10-17 2009-12-16 한국전자통신연구원 패킷 전송 방법 및 장치
US20090113235A1 (en) 2007-10-30 2009-04-30 Selinger Robert D Raid with redundant parity
EP2235642A4 (en) * 2007-12-13 2016-08-03 Highwinds Holdings Inc CONTENT DELIVERY NETWORK
WO2009076251A2 (en) * 2007-12-13 2009-06-18 General Electric Company Accelerating peer-to-peer content distribution
US8150675B1 (en) 2008-05-30 2012-04-03 Adobe Systems Incorporated Network simulation for download progress and latency
US20100153578A1 (en) 2008-07-16 2010-06-17 Nokia Corporation Method and Apparatus for Peer to Peer Streaming
US10430338B2 (en) * 2008-09-19 2019-10-01 Oracle International Corporation Selectively reading data from cache and primary storage based on whether cache is overloaded
US20100083268A1 (en) 2008-09-29 2010-04-01 Morris Robert P Method And System For Managing Access To A Resource By A Process Processing A Media Stream
US9094721B2 (en) * 2008-10-22 2015-07-28 Rakuten, Inc. Systems and methods for providing a network link between broadcast content and content located on a computer network
US7991906B2 (en) * 2008-12-09 2011-08-02 Hong Kong Applied Science And Technology Research Institute Co., Ltd. Method of data request scheduling in peer-to-peer sharing networks
JP2010141567A (ja) * 2008-12-11 2010-06-24 Toshiba Corp 通信装置、通信方法及びプログラム
US9288010B2 (en) 2009-08-19 2016-03-15 Qualcomm Incorporated Universal file delivery methods for providing unequal error protection and bundled file delivery services
KR101269678B1 (ko) 2009-10-29 2013-05-30 한국전자통신연구원 P2p 스트리밍 장치, 방법 및 시스템 구성방법
US20110225312A1 (en) * 2010-03-10 2011-09-15 Thomson Licensing Unified cache and peer-to-peer method and apparatus for streaming media in wireless mesh networks
US8918533B2 (en) 2010-07-13 2014-12-23 Qualcomm Incorporated Video switching for streaming video data
US9185439B2 (en) * 2010-07-15 2015-11-10 Qualcomm Incorporated Signaling data for multiplexing video components
US9456015B2 (en) * 2010-08-10 2016-09-27 Qualcomm Incorporated Representation groups for network streaming of coded multimedia data
KR101212366B1 (ko) 2010-11-25 2012-12-13 엔에이치엔비즈니스플랫폼 주식회사 P2p 기반의 스트리밍 서비스에서 서버 사용량을 조절하는 시스템 및 방법
JP2012151849A (ja) 2011-01-19 2012-08-09 Nhn Business Platform Corp P2p基盤のストリーミングサービスのデータストリームをパケット化するシステムおよび方法
US9270299B2 (en) * 2011-02-11 2016-02-23 Qualcomm Incorporated Encoding and decoding using elastic codes with flexible source block mapping
WO2012154287A2 (en) * 2011-02-28 2012-11-15 Bittorrent, Inc. Peer-to-peer live streaming
US20120297405A1 (en) 2011-05-17 2012-11-22 Splendorstream, Llc Efficiently distributing video content using a combination of a peer-to-peer network and a content distribution network
US8443086B2 (en) * 2011-06-22 2013-05-14 National Chiao Tung University Decentralized structured peer-to-peer network and load balancing methods thereof

Patent Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH11312030A (ja) * 1998-02-06 1999-11-09 Nec Corp オンデマンドサ―バの電源オンオフの制御を可能にするオンデマンドシステム

Non-Patent Citations (5)

* Cited by examiner, † Cited by third party
Title
CSNG200900270009; 鈴木 慧, 川原崎 雅敏: 'P2P映像配信における連携ピア選択方式の提案と評価' 電子情報通信学会技術研究報告 Vol.109, No.37, 20090514, p.55-60, 社団法人電子情報通信学会 *
CSNG201100029009; 藤本 貴也, 遠藤 伶, 松本 敬, 重野 寛: 'P2P VoD Streamingにおける動画の人気度考慮によるピア帯域有効活用' 電子情報通信学会技術研究報告 Vol.110, No.372, 20110113, p.63-68, 社団法人電子情報通信学会 *
JPN6013051997; 藤本 貴也, 遠藤 伶, 松本 敬, 重野 寛: 'P2P VoD Streamingにおける動画の人気度考慮によるピア帯域有効活用' 電子情報通信学会技術研究報告 Vol.110, No.372, 20110113, p.63-68, 社団法人電子情報通信学会 *
JPN6013051998; 鈴木 慧, 川原崎 雅敏: 'P2P映像配信における連携ピア選択方式の提案と評価' 電子情報通信学会技術研究報告 Vol.109, No.37, 20090514, p.55-60, 社団法人電子情報通信学会 *
JPN7013003850; Yung Ryn CHOE, Derek L. SCHUFF, Jagadeesh M. DYABERI, Vijay S. PAI: 'Improving VoD Server Efficiency with BitTorrent' Proceedings of the 15th international conference on Multimedia (MULTIMEDIA '07) , 20070923, p.117-126, ACM *

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2017126902A (ja) * 2016-01-14 2017-07-20 公立大学法人岩手県立大学 ミキサ装置及びライブ中継システム
JP7059509B1 (ja) 2019-03-27 2022-04-26 ストリームルート ピア・トゥ・ピアネットワークにおけるストリーミングコンテンツの配信方法
JP2022524639A (ja) * 2019-03-27 2022-05-09 ストリームルート ピア・トゥ・ピアネットワークにおけるストリーミングコンテンツの配信方法

Also Published As

Publication number Publication date
JP5934828B2 (ja) 2016-06-15
JP2012151849A (ja) 2012-08-09
US20130024583A1 (en) 2013-01-24
JP2015222982A (ja) 2015-12-10
US9438669B2 (en) 2016-09-06
JP5529177B2 (ja) 2014-06-25
US9736236B2 (en) 2017-08-15
US20130018991A1 (en) 2013-01-17

Similar Documents

Publication Publication Date Title
JP5529177B2 (ja) P2p基盤のストリーミングサービスでバッファリングを行うシステムおよび方法、並びにクライアントでバッファリングを処理するアプリケーションを配布するシステム
US11539768B2 (en) System and method of minimizing network bandwidth retrieved from an external network
US9497035B2 (en) Method, device, and system for playing media based on P2P
KR101104729B1 (ko) 최적의 캐시조각 획득방식을 이용하는 컨텐츠 분산 저장형 멀티미디어 스트리밍 시스템 및 방법
JP5536742B2 (ja) P2p基盤のストリーミングサービスのサーバ使用量を調整するシステムおよび方法
US20240179200A1 (en) System and method of minimizing network bandwidth retrieved from an external network
Zhang et al. Topology-aware peer-to-peer on-demand streaming
KR101242830B1 (ko) P2p 기반의 스트리밍 서비스에서 버퍼링을 수행하는 시스템 및 방법 그리고 클라이언트에서 버퍼링을 처리하는 어플리케이션을 배포하는 시스템
KR101262622B1 (ko) P2p 기반의 스트리밍 서비스에서 서버 사용량을 조절하는 시스템 및 방법
KR101914105B1 (ko) P2p 기반의 스트리밍 서비스에서 버퍼링을 수행하는 시스템 및 방법 그리고 클라이언트에서 버퍼링을 처리하는 어플리케이션을 배포하는 시스템
KR100797389B1 (ko) 다중 디스크립션 코딩을 이용한 클러스터 기반의 스트리밍시스템 및 그 방법
KR101695910B1 (ko) P2p 기반의 스트리밍 서비스에서 데이터 스트림을 패킷타이징하는 시스템 및 방법
Gotoh et al. Evaluation of P2P streaming systems for webcast
KR101417890B1 (ko) P2p 기반의 스트리밍 서비스에서 데이터 스트림을 패킷타이징하는 시스템 및 방법
KR101649562B1 (ko) P2p 기반의 스트리밍 서비스에서 데이터 스트림을 패킷타이징하는 시스템 및 방법
KR20120116378A (ko) P2p 기반의 스트리밍 서비스에서 버퍼링을 수행하는 시스템 및 방법 그리고 클라이언트에서 버퍼링을 처리하는 어플리케이션을 배포하는 시스템
Cao et al. P2P-based Video-on-Demand Service Using Multiple Cache Replacement Algorithm
Gotoh et al. Design and implementation of P2P streaming systems for webcast

Legal Events

Date Code Title Description
A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20120830

A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20130918

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20131022

A601 Written request for extension of time

Free format text: JAPANESE INTERMEDIATE CODE: A601

Effective date: 20140120

A602 Written permission of extension of time

Free format text: JAPANESE INTERMEDIATE CODE: A602

Effective date: 20140123

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20140221

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: 20140401

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20140416

R150 Certificate of patent or registration of utility model

Ref document number: 5529177

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R150

S111 Request for change of ownership or part of ownership

Free format text: JAPANESE INTERMEDIATE CODE: R313113

R371 Transfer withdrawn

Free format text: JAPANESE INTERMEDIATE CODE: R371

S111 Request for change of ownership or part of ownership

Free format text: JAPANESE INTERMEDIATE CODE: R313113

R350 Written notification of registration of transfer

Free format text: JAPANESE INTERMEDIATE CODE: R350

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

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

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250