JP3563541B2 - データ格納装置及びデータ格納方法 - Google Patents

データ格納装置及びデータ格納方法 Download PDF

Info

Publication number
JP3563541B2
JP3563541B2 JP24329196A JP24329196A JP3563541B2 JP 3563541 B2 JP3563541 B2 JP 3563541B2 JP 24329196 A JP24329196 A JP 24329196A JP 24329196 A JP24329196 A JP 24329196A JP 3563541 B2 JP3563541 B2 JP 3563541B2
Authority
JP
Japan
Prior art keywords
disk device
disk
data
time limit
write request
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.)
Expired - Fee Related
Application number
JP24329196A
Other languages
English (en)
Other versions
JPH1091357A (ja
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.)
Toshiba Corp
Original Assignee
Toshiba 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 Toshiba Corp filed Critical Toshiba Corp
Priority to JP24329196A priority Critical patent/JP3563541B2/ja
Priority to US08/927,015 priority patent/US6021464A/en
Publication of JPH1091357A publication Critical patent/JPH1091357A/ja
Application granted granted Critical
Publication of JP3563541B2 publication Critical patent/JP3563541B2/ja
Anticipated expiration legal-status Critical
Expired - Fee Related legal-status Critical Current

Links

Images

Classifications

    • 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/21Server components or server architectures
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0602Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
    • G06F3/0614Improving the reliability of storage systems
    • G06F3/0619Improving the reliability of storage systems in relation to data integrity, e.g. data losses, bit errors
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0628Interfaces specially adapted for storage systems making use of a particular technique
    • G06F3/0655Vertical data movement, i.e. input-output transfer; data movement between one or more hosts and one or more storage devices
    • G06F3/0659Command handling arrangements, e.g. command buffers, queues, command scheduling
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0668Interfaces specially adapted for storage systems adopting a particular infrastructure
    • G06F3/0671In-line storage system
    • G06F3/0683Plurality of storage devices
    • G06F3/0689Disk arrays, e.g. RAID, JBOD
    • 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

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Human Computer Interaction (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Multimedia (AREA)
  • Signal Processing (AREA)
  • Computer Security & Cryptography (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)

Description

【0001】
【発明の属する技術分野】
本発明は、ディスク装置に対する制限時間付きのデータ書き込み要求を含むアクセス要求をスケジュールするデータ格納装置及びデータ格納方法に関する。
【0002】
【従来の技術】
制限時間付きのジョブを扱う実時間システムでは、リアルタイムスケジューリングを導人することにより複数のジョブを各々の制限時間内で処理できるように処理順序を決定する。リアルタイムスケジューリングの方式には従来から様々な方式が考案、実施されている。
【0003】
制限時間付のディスクアクセス要求が周期的に発生するような実時間システムでは、ディスクアクセスの処理に上記スケジューリング(および後述する判定手段)が適用される。このようなシステムの例としては、ディスクに格納された映像データを連続してクライアントに転送するビデオサーバや、プラントの状態監視/記録システムなどがある。このようなシステムではデータ格納装置としての十分な転送能力を確保するために、ディスク装置を複数台準備する場合が多い。
【0004】
また、周期的に発生する制限時間付きのジョブを扱う場合には、一般にはそのシステム全体の処理能力、各ジョブの発生周期、処理時間、その他必要となる資源をもとに新しいジョブの処理を受け付けても良いがどうかを判断して処理受け付けを許可または拒否する。この判定手段はアドミッション・コントロール(admission control)と呼ばれ、スケジューリング方式やシステムに応じてその判断基準が定められる。
【0005】
しかし実際には、アドミッション・コントロールで許可されたジョブであっても、ジョブの発生周期が外的要因により変化して全てのジョブが各々の制限時間内で完了することが保証できなくなる場合がある。
【0006】
例えばビデオサーバにおいて、ビデオカメラからの出力を直接符号化しネットワークを介して送られてくる映像データをビデオサーバで受信してディスク装置に格納するような場合には、ネットワークの遅延による到着時刻のジッタが原因でディスクアクセス要求の発生周期に揺らぎが生じることがある。すると、ある時刻に予定以上の要求が特定のディスク装置に集中して、どのようにスケジュールを組み換えたとしても全てのディスクアクセス要求を制限時間内で実行することが不可能になることがある。この場合、上記のようにしてネットワークを介して送られてきた映像データは、ディスク装置に格納することができずに失われてしまい、二度と再現することができなくなってしまう。
【0007】
そこで従来は、書き込み要求に関してこの問題を解決する方法として、書き込みデータを保持するバッファメモリを大きくすることによりデータを保持することが可能な時間を長くして、書き込み要求の制限時間を長くする方法が一般的であった。しかし、例えば、ストリームのセグメントをN台のディスク装置に順番に格納していく場合、アクセスの周期をTとすると、時間N×Tだけ次の空きタイムスロットを待つ必要があり、その時間データをバッファに保持するためには1ストリーム当たりダブルバッファの割り付けでは足りずに、セグメント(N+1)個分のバッファを準備する必要があった。
【0008】
【発明が解決しようとする課題】
上記したように従来のデータ格納装置では、外的要因により書き込み要求が特定のディスク装置に予定以上に集中してしまった場合、複数のディスク装置全体としての転送能力には余裕があるにもかかわらず書き込み要求に対応できずにデータをとりこぼしてしまう問題点があった。また、データをとりこぼさずに格納するためには、データ保持可能時間を延長するために大量のバッファメモリを用意する必要があり、ハードウェア効率を損なう問題点があった。
【0009】
本発明は、上記事情を考慮してなされたものであり、1つのディスク装置に対して書き込みの制限時間を持つ書き込み要求が集中するような場合でも、書き込みの制限時間を延長するためにバッファメモリを増加することなく、データをディスク装置に格納することが可能なデータ格納装置及びデータ格納方法を提供することを目的とする。
【0010】
【課題を解決するための手段】
本発明(請求項1)は、複数のディスク装置と、ディスク装置に対するアクセス要求をスケジュールする制御装置とを備えたデータ格納装置において、あるディスク装置に制限時間付きの新しい書き込み要求を発行したと仮定した場合に、該書き込み要求を含むそのディスク装置に対する全てのアクセス要求の制限時間が保証されるか否かを判定する手段と、この手段により全てのアクセス要求の制限時間が保証されると判定されたディスク装置を、前記新しい書き込み要求について書き込み対象となるディスク装置として選択する手段と、この手段により選択されたディスク装置に対する全てのアクセス要求の制限時間が保証されるようにそれら全てのアクセス要求をスケジュールして該ディスク装置に発行する手段とを備えたことを特徴とする。
【0011】
本発明(請求項2)は、複数のディスク装置と、ディスク装置に対するアクセス要求をスケジュールする制御装置を持つデータ格納装置において、指定ディスク装置に対する制限時間付きの新しい書き込み要求を受けた場合、該書き込み要求を含む該指定ディスク装置に対する全てのアクセス要求の制限時間が保証されるか否かを判定する手段と、この手段により全てのアクセス要求の制限時間が保証されると判定されなかった場合、前記指定ディスクとは異なるディスク装置を、前記新しい書き込み要求について書き込み対象となるディスク装置として選択する手段とを備えたことを特徴とする。
【0012】
指定ディスクとは異なるディスク装置を選択するにあたっては、負荷の低いディスク装置を優先的に選択するようにしても良いし、空き領域の大きいディスク装置を優先的に選択するようにしても良いし、ランダムに選択するようにしても良い。さらに、そのディスク装置に対する全てのアクセス要求の制限時間が保証されるか否かをもとにして選択するようにしても良い。
【0013】
本発明(請求項3)は、請求項2に記載のデータ格納装置において、各データが現在格納されているディスク装置と本来格納されるべきディスク装置との対応を記憶する手段をさらに備えたことを特徴とする。
【0014】
本発明(請求項4)は、複数のディスク装置に対するアクセス要求をスケジュールする制御装置によるデータ格納方法において、あるディスク装置に制限時間付きの新しい書き込み要求を発行したと仮定した場合に、該書き込み要求を含むそのディスク装置に対する全てのアクセス要求の制限時間が保証されるか否かを判定し、全てのアクセス要求の制限時間が保証されると判定された場合、そのディスク装置を、前記新しい書き込み要求について書き込み対象となるディスク装置として選択し、この選択されたディスク装置に対する全てのアクセス要求の制限時間が保証されるようにそれら全てのアクセス要求をスケジュールして該ディスク装置に発行することを特徴とする。
【0015】
本発明(請求項5)は、請求項4に記載のデータ格納方法において、制限時間付きの書き込み要求が発生した際に、あるディスク装置に前記書き込み要求を発行したと仮定した場合にそのディスク装置に対する全てのアクセス要求の制限時間が保証されるディスク装置の集合に含まれ、且つその中で最も優先度の高いディスク装置を、前記書き込み要求について書き込み対象となるディスク装置として選択することを特徴とする。
【0016】
本発明(請求項6)は、請求項5に記載のデータ格納方法において、あるデータを格納すべき特定のディスク装置が書き込み要求内で指定されている場合にはその特定のディスク装置を最も優先度の高いディスク装置とすることを特徴とする。
【0017】
なお、請求項5において、ディスク装置を選択するにあたっては、負荷の低いディスク装置を優先的に選択するようにしても良いし、空き領域の大きいディスク装置を優先的に選択するようにしても良い。
【0018】
本発明(請求項7)は、複数のディスク装置に対するアクセス要求をスケジュールする制御装置によるデータ格納方法において、指定ディスク装置に対する制限時間付きの新しい書き込み要求を受けた場合、該書き込み要求を含む該指定ディスク装置に対する全てのアクセス要求の制限時間が保証されるか否かを判定し、全てのアクセス要求の制限時間が保証されると判定されなかった場合、前記指定ディスクとは異なるディスク装置を、前記新しい書き込み要求について書き込む対象となるディスク装置として選択することを特徴とする。
【0019】
本発明(請求項8)は、請求項7に記載のデータ格納方法において、あるデータを格納すべき特定のディスク装置が書き込み要求内で指定されていて、且つ該特定のディスク装置とは異なるディスク装置が書き込みディスク装置として選択された場合、この選択された前記特定のディスク装置とは異なるディスク装置にデータが書き込まれた後に、該データを該特定のディスク装置とは異なるディスク装置から読み出して所定の記憶領域に一旦保持し、その後、該データを該所定の記憶領域から該特定のディスク装置に書き込むことを特徴とする。
【0020】
本発明によれば、制限時間を持つ他のディスクアクセスに影響を及ぼさずにバッファメモリ上での書き込みデータ保持時間を短くすることが可能になり、その結果、空いたメモリ領域をそれ以降に発生する書き込み要求のデータ保持に使用することができる。
【0021】
したがって、1つのディスク装置に対して書き込みの制限時間を持つ書き込み要求が集中するような場合に対処するために大量のバッファメモリを持たなくとも、連続して発生する書き込み要求をデータを失うことなく処理しディスク装置に格納することが可能となる。
【0022】
【発明の実施の形態】
以下、図面を参照しながら発明の実施の形態を説明する。
本実施形態は、概略的には、ディスク装置への書き込み要求があったときに、次のデータの到着までに書き込みを終了することができないのであれば、まず、他のディスク装置に一旦書き込んでおくことで、データを全て受信可能にしておく。その後、システムに余裕があるときにデータを本来のディスク装置に移動させるようにしたものである。
【0023】
図1に、本発明の一実施形態に係るデータ格納装置の構成を示す。
本実施形態のデータ格納装置は、制御装置2、ディスク装置3、メモリ装置4を備えている。
【0024】
制御装置2は、スケジューリング部22、書き込みディスク装置選択部23、スケジューリング可能性判定部24、データ管理部25を有する。スケジューリング部22は、周期的ジョブテーブル221、アクセス要求テーブル222を有する。データ管理部25は、データ移動予約テーブル251、データ配置テーブル252を有する。なお、以下では、スケジューリング可能性判定部を判定部と呼ぶ。また、書き込みディスク装置選択部を選択部と呼ぶ。
【0025】
ディスク装置3は、データを格納するために用いられる。ここでは、ディスク装置3は、制御装置2(のスケジューリング部22)から発行されたアクセス命令に応じ指定されたデータの書き込みや読み出しを行うコントローラを内蔵するものとする。
【0026】
メモリ装置4は、ディスク装置3に書き込むデータやディスク装置3から読み出したデータを一旦保持するバッファとして用いられる。メモリ装置4は、1台のメモリからなる場合と、複数のメモリからなるメモリ群である場合とが考えられる。
【0027】
データ保存用の複数のディスク装置3とバッファ用のメモリ装置4はSCSIバス等のデータ転送ライン8で接続されており、メモリ装置4上に格納されているデータをどのディスク装置3に対しても書き込むことが可能である。
【0028】
また、ネットワークを介して接続された装置との間でデータの受け渡しを行う場合、ネットワーク入出力装置(図示せず)がバス8に接続される。
制御装置2では、判定部24、選択部23、スケジューリング部22が動作する。これらを実現する形態には、ソフトウェアとして、OSのカーネルに組み込む形態や、ユーザプログラムとして動作させる形態が考えられる。また、OSとアプリケーションンフトが動作するCPUとは別のCPUを持つコンピュータを制御装置として用意し、該コンピュータ上で、判定部24、選択部23、スケジューリング部22をソフトウェアとして動作させる形態も考えられる。もちろん、判定部24、選択部23およびスケジューリング部22をハードウェア回路として実現しても良い。
【0029】
スケジューリング部22は、主として、アクセス要求の受け付け、アクセス命令のスケジューリング、周期的ジョブの登録、アクセス命令の発行などを行う。例えば、アクセス要求の受け付けは随時行われ、スケジューリングと周期的ジョブの登録とアクセス命令の発行は周期的に行われる。
【0030】
アクセス要求としては、非周期的に発行されるアクセス要求や、登録された周期的ジョブの個別のアクセス要求がある。ここでの周期的ジョブとは、周期的に発行される一連のアクセス要求のことである。
【0031】
後述するディスク装置間でのデータ再配置のためのアクセス要求は、制限時間なしの非周期的ジョブである。
なお、アクセス要求は、スケジューリング部22の外部から(例えばユーザプログラムから)だけでなく、スケジューリング部22内から発行される場合もある。例えば、スケジューリング部22自体が時間のマスタになるような周期的ジョブの場合には、スケジューリング部22自体が個別のアクセス要求を発行する形態を取ることも可能である。
【0032】
スケジューリング部22は、各ディスク装置3に対して現在発行されているアクセス要求の管理表222と、周期的ジョブの管理表221を持つ。周期的ジョブの管理表221では、各周期的ジョブについて予定周期とデータサイズ(1回の処理に必要な時間はこれらから得られる)、必要ならば複数のディスク装置3への格納順序の規則等が管理されている。
【0033】
これら管理表221,222の情報は判定部24でも必要となるため、必要に応じて管理表221,222の一部をスケジューリング部22から判定部24へと転送する手段を設ける。また、スケジューリング部22と判定部24でこれらの管理表221,222を共有する構成も可能である。
【0034】
なお、以下では、アクセス要求の管理表をアクセス要求テーブルと呼ぶ。また、周期的ジョブの管理表を周期的ジョブテーブルと呼ぶ。
スケジューリング部22が選択部23へ渡す要求Roは、データが格納されているメモリ領域のアドレス、データのサイズ、制限時間の情報を持つ。そのデータを書き込むディスク装置Doが指定されている場合には、指定ディスク装置Doの情報も含まれる。
【0035】
データ管理部25は、ファイル(例えばストリーム)毎にデータ配置テーブル252を持つ。データ配置テーブル252には、各ファイルごとに、該ファイルに属する各データ(例えばセグメント)のディスク装置3上での格納位置を示す情報が保持される。また、データ管理部25は、現在格納されているディスク装置3から別のディスク装置3へ移動させるべきデータを保持するデータ移動予約テーブル251を持つ。データ配置テーブル252とデータ移動予約テーブル251のサイズが大きくなる場合には、その一部のみを制御装置2上に保持しておき、全体は制御装置2の外部の記憶装置に保持してもよい。
【0036】
図2は、本実施形態における制御装置2の処理手順の一例を示すフローチャートである。
書き込み要求が制御装置2内部の要求受付部(図示せず)の待ち行列に積まれると、スケジューリング部22によって取り出され、要求Roの形式でスケジューリング部22から選択部23に渡される(ステップS11)。
【0037】
選択部23では、要求Roを受信すると、後述の選択優先順位に従って優先順位の高いディスク装置3を書き込みディスク候補Dcとして選択し、要求Roと書き込みディスク候補Dcの情報を判定部24へ渡す(ステップS12,S13)。書き込みディスク候補Dcの情報としては、ディスク装置識別子だけでも良い。
【0038】
書き込みディスク候補を選択する優先順位の基準としては、
(a)最初から書き込むディスク装置3が指定されている場合には指定ディスク装置3を優先的に選択する。
(b)負荷の低いディスク装置3を優先的に選択する。
(c)空き領域の大きいディスク装置3を優先的に選択する。
といった基準があり、これらを組み合わせて使用しても良い。
【0039】
なお、優先順位を設けずに、ランダムに選択する方法も考えられる。あるいは、まず上記の(a)の基準を用い、指定がない場合にランダムに選択する方法も考えられる。
【0040】
次に、選択部23から判定部24に要求Roとディスク装置Dcの情報が渡されると、判定部24は書き込みディスク候補Dcのスケジュール情報を調べる(ステップS14)。具体的には、現在そのディスク装置Dcに発行されているアクセス要求に関する情報(アクセス要求テーブル222の情報)と、周期的に発行されるアクセス要求の情報(周期的ジョブテーブル221の情報)をスケジューリング部22に要求し、スケジューリング部22はそれらの情報を判定部24に転送する。アクセス要求テーブル222や周期的ジョブテーブル221を共有している場合には判定部24がテーブル221,222を直接参照してもよい。
【0041】
次に、要求Roがディスク装置Dcに対して発行されたと仮定すると要求Roも含めた全てのアクセス要求が各々の制限時間内に実行可能となるスケジュールを作成することが可能がどうかを判定する。判定結果は選択部23へ返される(ステップS15)。判定方法はスケジューリング部22で採られるスケジューリング方式に合わせる。
【0042】
次に、判定部24から選択部23にスケジューリング可能という判定結果が返された場合、選択部23は書き込みディスク候補Dcを書き込み要求を発行するディスク装置Dtとして選択して、ディスク装置Dtの識別情報をスケジューリング部22に返す(ステップS16,S17)。スケジュール可能でないと判定結果が返された場合、選択部23は次に優先順位が高いディスク装置3を書き込みディスク候補Dcとして以上の動作を繰り返す。
【0043】
なお、選択部23及び判定部24の動作方式としては、上記のように優先度にしたがって書き込みディスク候補Dcを1つずつ選択し、判定する処理を繰り返す方式以外の動作方式も考えられる。例えば、まず全てのディスク装置3に対して判定を行ない、要求Roも含めてスケジューリング可能であると判定されたディスク装置3の集合を求め、その集合の中で最も優先度の高いディスク装置3を書き込み要求を発行するディスク装置Dtとしてスケジューリング部22に返す方式が考えられる。
【0044】
次に、選択部23からスケジューリング部22に書き込み要求を発行するディスク装置Dtが返されると、スケジューリング部22は要求Roと書き込み要求を発行するディスク装置Dtの情報をアクセス要求テーブル222に登録する(ステップS18)。
【0045】
以上で、スケジューリング部22から渡された1つの要求Roに対する選択部23および判定部24の処理が終了する。
さて、スケジューリング部22では、アクセス要求テーブル222に基づき各ディスク装置3にアクセス命令を出していく。その際、アクセス命令が書き込み命令の場合には、そのデータが属するファイルのデータ配置テーブル252に書き込み要求を発行するディスク装置Dtのディスク装置識別子とデータが格納されたディスク装置Dt上の位置(例えばブロック番号)を追加する。
【0046】
以上のような本実施形態によれば、外的要因によりネットワークを介して受信するデータの到着時刻が予定時刻からずれてしまい、ある時刻に特定のディスク装置3にアクセスが集中してしまった場合であっても、その時点で時間的制約の守られる他のディスク装置3に書き込み要求を分散させるので、バッファを増加させず、かつ、受信データをとりこぼさずにディスク装置3に格納することが可能である。
【0047】
ここで、要求Roで本来の書き込みディスク装置Doが指定されていて、かつこのディスク装置Doと書き込み要求を発行するディスク装置Dtが異なる結果となった場合には、後にデータをディスク装置Dtから本来の書き込みディスク装置Doへ移動させる必要がある。以下では、そのような処理について説明する。
【0048】
上記のような場合、まず、スケジューリング部22がアクセス要求テーブル222に基づき各ディスク装置3に命令を出す時点で、前述のようにデータ配置テーブル252にそのデータのエントリを迫加するのに加えて、データ移動予約テーブル251にデータ配置テーブル252上でのエントリを示すポインタと本来の書き込みディスクDoを登録する。
【0049】
図3に、この動作のフローチャートを示す。すなわち、スケジューリング部22は、アクセス要求テーブル222を参照して実行すべき要求Roとディスク装置の識別子Dtを取り出し(ステップS21)、識別子Dtのディスク装置に対してRoで指定される書き込み命令を発行し(ステップS22)、データ配置テーブル252にそのデータのエントリEoを登録する(ステップS23)。そして、書き込みディスク装置Dtと本来書き込むべきディスク装置Doが異なる場合、データ移動予約テーブル251に上記エントリEoへのポインタと本来の書き込みディスク装置の識別子Doを登録する(ステップS24,S25)。
【0050】
その後、システムの負荷が低い状態に移った時点で、書き込んだディスク装置Dtから本来書き込むべきディスク装置Doにデータを移動させる処理を行う。
図4は、データ再配置処理の手順の一例を示すフローチャートである。
【0051】
概略的には、データ移動予約テーブル251にエントリが存在し、かつディスク装置Dtから読み出したデータを格納するためのバッファ領域が確保できる場合(ステップS31,S32でYESの場合)、そのエントリで登録されているデータを本来書き込まれるべきディスク装置3に移動させる(ステップS33〜S39)。
【0052】
この処理は、(1)ステップS31〜S39の処理の実行部あるいはプロセスを設けることにより実現しても良いし、(2)ステップS31とS32の処理の実行部あるいはプロセスと、ステップS33〜S39の処理の実行部あるいはプロセスに分けて設け、前者が後者を起動するようにしても良い。
【0053】
以下、データ再配置処理についてより詳しく説明する。
スケジューリング部22は、適当なタイミングで繰り返しデータ移動予約テーブル251とバッファ領域の負荷状態を監視している。データ移動予約テーブル251にエントリが存在し、かつ、バッファ領域等の資源に余裕がある場合(ステップS31,S32でYESの場合)には、データ移動予約テーブル251からエントリの情報を取り出して、そのエントリをテーブルから削除する(ステップS33)。取り出したエントリの情報をもとにデータ配置テーブル252を検索して、そのデータが書き込まれているディスク装置Dtとそのディスク上での位置を調べる(ステップS34,S35)。次に、制限時間を指定せずにそのデータの読み出し要求を発行してその実行完了を待つ(ステップS36,S37)。
【0054】
そして、読み出し要求の実行完了を確認した後、書き込みディスク装置3としてDoを指定して、制限時間を指定せずに書き込み要求を発行する(ステップS38)。そして、書き込み要求完了を待つ(ステップS39)。
【0055】
データ配置テーブル252上の当該データのエントリの追加は、図3で示されるように、スケジューリング部22が書き込み要求に対応する命令を各ディスク装置3に発行する際に行なわれる。書き込み要求の実行完了を確認した後、移動前のデータと移動前のデータ配置テーブル252内のエントリを削除する。
【0056】
以上のような本実施形態によれば、受信時のデータ格納状態に関係なく、本データ格納装置に対して外部装置またはソフトウェアが最初に指定したディスク装置3に自動的にデータを再配置させることができる。
【0057】
次に、図1のデータ格納装置をビデオサーバとした場合について説明する。
まず、ここで扱うビデオサーバの構成と動作について説明する。
ビデオサーバは、複数のクライアントに対して映像ストリームを同時に且つ途切れなく供給する装置である。ビデオサーバでは、同時に複数のストリームを供給するために、ストリームデータを小さなセグメントに分割してディスク装置3に格納しておき、時分割多重読み出しを行なう。さらに、各ストリームが途切れないようにするために、セグメントを保持するバッファ領域の確保、ディスク装置3からバッファ領域へのセグメントの読み出し、バッファ領域からクライアントへのセグメントの転送をスケジューリングする。
【0058】
図5はここで扱うビデオサーバにおけるデータ転送のタイムチャートの例である。(a)はディスクアクセスのタイムチャート、(b)は送信ストリームのバッファ利用タイムチャート、(c)は受信ストリームのバッファ利用タイムチャートである。また、(a)〜(b)においてTは周期を表わし、矢印はアクセス要求が発生するタイミングを表わす。
【0059】
ここでは、ストリームデータは、転送時間Tとなるセグメントに分割され、先頭から順にディスク装置の識別子が例えば0,1,…,N−1,0,…となるようにサイクリックにディスク装置に格納されるものとする。図5ではN=3の例を示してある。各ストリームの供給は周期Tでセグメントの読み出しと転送の繰り返しで実現される。各動作は時間軸を一定時間で区切ったタイムスロットで管理され、1タイムスロットで1回のディスクアクセスが行なわれる。
【0060】
このようにスケジューリングする場合に必要となるバッファメモリとしては、通常、各ストリームにセグメント長を単位としたダブルバッファを割り付ければ十分である。
【0061】
外部からリアルタイムに転送されてくるストリームを受信してディスク装置3に格納する場合は以下のようになる。データが正確に一定レートで転送されてくるのであれば、時間Tで受信したデータを1セグメントとして周期Tでディスク装置0,1,…,N−1,0,…の順で書き込むことにより、他の読み出し中のストリームに影響を与えずに格納することが可能である。このような書き込みのストリームに対しても1ストリーム当たりダブルバッファを割り付ければ十分である。しかし、既に説明したようにネットワークでの遅延等、ビデオサーバが管理できない外的要因により1セグメント分の量のデータの到着が遅れる場合には、図5のようなスケジューリングは不可能である。
【0062】
そこで、このようなビデオサーバに本発明を適用することで、上記不都合に対処することができる。
本ビデオサーバの構成は基本的に図1〜図4で説明したものと同様で、制御装置2、メモリ装置4、複数のディスク装置3、ネットワーク入出力装置(図示せず)が共通のバスで接続され、制御装置2はスケジューリング部22、選択部23、判定部24、データ管理部25を有し、また、各部分の働きも基本的に同様である。
【0063】
スケジューリング部22内の周期的ジョブテーブル221には各ストリームに関する情報とタイムスロットに関する情報が記録される。具体的には、各ストリームの状態(例えば送信用または書き込み用)、使用されるデータ、割り付けられたメモリ領域、転送先(クライアント)、ディスクアクセスを行なうタイムスロット、転送を開始するタイムスロットの情報などである。これらの情報をもとにして、図5のようなタイミングで動作することが予測され、この時間的制約を満たすようにスケジューリングが行われる。
【0064】
また、アクセス要求テーブル222には、データが到着して書き込み準備ができている書き込み要求とメモリ領域が確保されて読み出し準備ができている読み出し要求が登録される。各タイムスロットで実際にディスク装置3に送られるアクセス命令はこのアクセス要求テーブル222内の要求から選ばれる。
【0065】
データ管理部25内のデータ配置テーブル252には、各ストリームデータ毎に、各セグメントが格納されているディスク装置番号、各セグメントのディスク上でのブロック番号、各セグメントの大きさの情報が登録される。また、データ移動予約テーブル251には、書き込むべきディスク装置3が指定されていたにもかかわらず異なるディスク装置3に書き込まれたセグメントについて、そのストリームデータ識別子、セグメント番号、本来書き込むべきディスク装置識別子が登録される。
【0066】
以下、本ストリームサーバの動作について説明する。
最初にストリームデータの書き込みが周期的ジョブとして登録される。登録要求を受けたスケジューリング部22は、メモリ領域の確保を行ない、周期的ジョブテーブル221に書き込みストリームとして登録する。また、新しいストリームデータ用のエントリをデータ配置テーブル252に準備する。なお、ダブルバッファの割り付けやタイムスロットの割り付けが不可能である場合には、メモリ領域やディスク装置3の転送能力が足りないのでそのストリームデータの書き込みを許可しないものとする。
【0067】
ネットワーク入出力装置が受信したデータは割り付けられたダブルバッファの片方の領域に保持される。データが1セグメント(転送時間T)の大きさに達すると、スケジューリング部22は受信したデータの書き込み要求を制御装置2内部の要求受付部(図示せず)に出す。同時に受信するバッファをもう一方のバッファに切替える。書き込み要求には、バッファメモリのアドレス、セグメントの大きさ、制限時間、書き込みディスク装置3の情報が含まれる。この制限時間は、次のセグメントを確保するために周期Tでバッファメモリを空けなければならないという制限である。また、書き込みディスク装置3はディスク装置0,1,…,N−1,0,…の順に指定される。
【0068】
スケジューリング部22は、要求受付部から取り出した要求が書き込み要求であった場合、その要求Roを選択部23へ渡す(図2のステップS11)。
選択部23は、優先度に従って優先順位が高いディスク装置3を書き込みディスク装置候補Dcとして選択し、要求Roと書き込みディスク装置候補Dcのディスク装置識別子ID(Dc)を判定部24へ渡す。優先度については前述した通りであり、例えば、書き込むディスク装置Doが最も高く、それ以外のディスク装置3では、現時点から周期Tの間でのアクセスが少ない順に優先度を高くする。(ステップS12,S13)
判定部24は,スケジューリング部22内の周期的ジョブテーブル221とアクセス要求テーブル222を検索して、ディスク装置Dcについて今後制限時間以内に空きタイムスロットが存在するかどうかを調べる。存在する場合はスケジューリング可能と判定し、存在しない場合は不可能と判定する。判定結果は選択部23に返される。なお、この判定手段にはスケジューリング方式に応じて様々な方式が適用される(ステップS14,S15)。
【0069】
選択部23は、返された判定結果がスケジューリング可能であれば、ディスク装置Dcを実際の書き込みディスク装置Dtとして選択して、そのディスク装置識別子をスケジューリング部22へ返す。判定結果がスケジューリング不可能であれば、次に優先度の高いディスク装置3を書き込みディスク装置候補Dcとして上記の動作を繰り返す(ステップS15,S16)。
【0070】
スケジューリング部22は、ディスク装置識別子ID(Dt)を選択部23から返されると、要求Roとディスク装置識別子ID(Dt)の組をアクセス要求テーブル222に登録する(ステップS17)。
【0071】
なお、前述したように選択部23及び判定部24は、上記のようにディスク候補を1つずつ選択し判定する処理を繰り返す代わりに、全てのディスク装置に対して判定を行ない、スケジューリング可能であると判定されたディスク装置のうち最も優先度の高いディスク装置の識別子をスケジューリング部22に返すようにしても良い。
【0072】
以上では書き込み要求のアクセス要求テーブル222への登録までの動作を説明してきたが、読み出しストリームの場合には図5のタイムチャートで示したタイミングで読み出し要求がアクセス要求テーブル222に登録される。
【0073】
スケジューリング部22は、アクセス要求テーブル222に基づき、各タイムスロットで各ディスク装置3が実行すべき命令を生成して各ディスク装置3に送る。このとき、その命令が書き込み命令の場合、そのストリームデータに対応するデータ配置テーブル252にセグメント番号、ディスク装置識別子ID(Dt)、ディスク上のブロック番号、セグメントの大きさを登録する(図3のステップS21〜S25)。
【0074】
以上の動作によりネットワーク入出力部より受信したストリームデータをとりこぼさずにディスク装置3に格納することが可能である。しかし、各セグメントがディスク装置0,1,…,N−1,0,…の順に格納されている保証はないため、そのままでは図5のようなタイミングでストリームを供給することができない。そこで、スケジューリング部22では、負荷が低くなり1ストリーム分またはそれ以上のバッファ領域を確保できる状態になると、その領域を利用してセグメントのディスク間移動を行なう。
【0075】
まず、データをディスク装置3に格納する際に、データ移動予約テーブル251に必要な情報を記録しておく。具体的には、スケジューリング部22から各ディスク装置3が実行すべき命令を生成して転送する際に、要求Roで指定された本来の書き込みディスクDoと選択部23で選択された書き込みディスクDtとが異なる場合には、書き込み命令をディスク装置3へ送ると同時に、ストリームデータ識別子、セグメント番号、本来の書き込みディスク装置3の識別子ID(D0)の組をデータ移動予約テーブル251に登録しておく。このストリームデータ識別子とセグメント番号により、そのセグメントの格納場所を記録してあるデータ配置テーブル252内のエントリを特定できる。
【0076】
データ移動予約テーブル251にエントリが存在する状態になり、バッファ領域が確保できる状態になると、スケジューリング部22はディスク装置間でデータを再配置させる。ここでは、スケジューリング部22が、データ移動予約テーブル251のエントリの存在と、バッファ領域の確保の可能性をチェックし(図4のステップS31、S32に対応)、データを再配置する場合には、バッファ領域を確保してデータ移動用のプロセス(図4のステップS33〜S39に対応)を生成するものとする。
【0077】
データ移動用のプロセスでは、まずデータ移動予約テーブル251から1個のエントリの情報を取り出して、そのエントリ自体はデータ移動予約デーブルから削除する。
【0078】
取り出したエントリの情報には、そのセグメントが属するストリームデータ識別子StIDとセグント番号SegNo、本来の書き込みディスク装置識別子ID(D0)が含まれている。そのStIDに対応するストリームデータの格納場所を示すデータ配置テーブル252のSegNoで表されるエントリの情報を調べる。これにより、そのセグメントが格納されているディスク装置識別子ID(Dt)、セグメントが格納されているブロック位置、セグメントの大きさが得られる。
【0079】
読み出し要求が完了したことを確認した後で、ディスク装置Do上でそのセグメントを格納するブロックを確保する。その後、制限時間を指定せずに、ディスク装置Do、ブロック位置、大きさ、バッファ領域を指定して書き込み要求を構成し、要求の待ち行列に積む。そして、その書き込み要求の実行完了を待つ。書き込み要求が完了したことを確認した後で、そのセグメントが格納されていたDt上のブロックを全て解放する。
【0080】
以上、本発明を適用したビデオサーバの実施形態について説明してきた。
前述したように従来は、ネットワークでの遅延等で書き込み周期がずれると、最悪の場合には時間(N×T)だけ次の空きタイムスロットを待つ必要があった。その時間データをバッファに保持するためには1ストリーム当たりダブルバッファの割り付けでは足りずに、セグメント(N+1)個分のバッファを準備する必要があった。
【0081】
しかし本発明をビデオサーバに適用することにより、書き込み周期がずれる場合であっても1書き込みストリーム当たりダブルバッファを割り付ければ十分であり、メモリ総量を削減することが可能である
ところで、セグメントのディスク間移動は、バッファ領域が確保できるのであれば、そのセグメントが含まれるストリームデータの受信/送信中に並行して行なわれてもよい。
【0082】
ただし、セグメントのディスク間移動が完全に終了していない期間では、そのセグメントが含まれるストリームデータの送信が途切れなく実行される保証はない。そこで、セグメントのディスク間移動が完全に終了していない期間にそのセグメントが含まれるストリームデータの送信要求が到着した場合には、
(1)連続性の保証がないことをクライアントに通知した上で送信を開始する
(2)ディスク間移動が完全に終了しない間は送信要求を拒否する
のいづれかの方針を選択して実行するのが望ましい。
本発明は、上述した実施の形態に限定されるものではなく、その技術的範囲において種々変形して実施することができる。
【0083】
【発明の効果】
本発明によれば、制限時間付きの書き込み要求については、全てのアクセス要求の制限時間が保証されると判定されたディスク装置にデータを格納するようにしたので、1つのディスク装置に対して書き込みの制限時間を持つ書き込み要求が集中するような場合に対処するために大量のバッファメモリを持たなくとも、連続して発生する書き込み要求をデータを失うことなく確実にディスク装置に格納することができる。
【図面の簡単な説明】
【図1】本発明の一実施形態に係るデータ格納装置の構成を示す図
【図2】同実施形態におけるディスク装置の選択と判定の処理手順の一例を示すフローチャート
【図3】同実施形態におけるデータ書き込み時の処理手順の一例を示すフロ−チャー卜
【図4】同実施形態におけるデータ再配置の処理手順の一例を示すフロ−チャー卜
【図5】本発明を適用するビデオサーバのディスクアクセスのタイムチャートとバッファ利用タイムチャー卜を示す図
【符号の説明】
2…制御装置
3…ディスク装置
4…メモリ装置
22…スケジューリング部
221…周期的ジョブテーブル
222…アクセス要求テーブル
23…書き込みディスク装置選択部
24…スケジューリング可能性判定部
25…データ管理部
251…データ移動予約テーブル
252…データ配置テーブル

Claims (8)

  1. 複数のディスク装置と、ディスク装置に対するアクセス要求をスケジュールする制御装置とを備えたデータ格納装置において、
    あるディスク装置に制限時間付きの新しい書き込み要求を発行したと仮定した場合に、該書き込み要求を含むそのディスク装置に対する全てのアクセス要求の制限時間が保証されるか否かを判定する手段と、
    この手段により全てのアクセス要求の制限時間が保証されると判定されたディスク装置を、前記新しい書き込み要求について書き込み対象となるディスク装置として選択する手段と、
    この手段により選択されたディスク装置に対する全てのアクセス要求の制限時間が保証されるようにそれら全てのアクセス要求をスケジュールして該ディスク装置に発行する手段とを備えたことを特徴とするデータ格納装置。
  2. 複数のディスク装置と、ディスク装置に対するアクセス要求をスケジュールする制御装置を持つデータ格納装置において、
    指定ディスク装置に対する制限時間付きの新しい書き込み要求を受けた場合、該書き込み要求を含む該指定ディスク装置に対する全てのアクセス要求の制限時間が保証されるか否かを判定する手段と、
    この手段により全てのアクセス要求の制限時間が保証されると判定されなかった場合、前記指定ディスクとは異なるディスク装置を、前記新しい書き込み要求について書き込み対象となるディスク装置として選択する手段とを備えたことを特徴とするデータ格納装置。
  3. 各データが現在格納されているディスク装置と本来格納されるべきディスク装置との対応を記憶する手段をさらに備えたことを特徴とする請求項2に記載のデータ格納装置。
  4. 複数のディスク装置に対するアクセス要求をスケジュールする制御装置によるデータ格納方法において、
    あるディスク装置に制限時間付きの新しい書き込み要求を発行したと仮定した場合に、該書き込み要求を含むそのディスク装置に対する全てのアクセス要求の制限時間が保証されるか否かを判定し、
    全てのアクセス要求の制限時間が保証されると判定された場合、そのディスク装置を、前記新しい書き込み要求について書き込み対象となるディスク装置として選択し、
    この選択されたディスク装置に対する全てのアクセス要求の制限時間が保証されるようにそれら全てのアクセス要求をスケジュールして該ディスク装置に発行することを特徴とするデータ格納方法。
  5. 制限時間付きの書き込み要求が発生した際に、あるディスク装置に前記書き込み要求を発行したと仮定した場合にそのディスク装置に対する全てのアクセス要求の制限時間が保証されるディスク装置の集合に含まれ、且つその中で最も優先度の高いディスク装置を、前記書き込み要求について書き込み対象となるディスク装置として選択することを特徴とする請求項4に記載のデータ格納方法。
  6. あるデータを格納すべき特定のディスク装置が書き込み要求内で指定されている場合にはその特定のディスク装置を最も優先度の高いディスク装置とすることを特徴とする請求項5に記載のデータ格納方法。
  7. 複数のディスク装置に対するアクセス要求をスケジュールする制御装置によるデータ格納方法において、
    指定ディスク装置に対する制限時間付きの新しい書き込み要求を受けた場合、該書き込み要求を含む該指定ディスク装置に対する全てのアクセス要求の制限時間が保証されるか否かを判定し、
    全てのアクセス要求の制限時間が保証されると判定されなかった場合、前記指定ディスクとは異なるディスク装置を、前記新しい書き込み要求について書き込む対象となるディスク装置として選択することを特徴とするデータ格納方法。
  8. あるデータを格納すべき特定のディスク装置が書き込み要求内で指定されていて、且つ該特定のディスク装置とは異なるディスク装置が書き込みディスク装置として選択された場合、
    この選択された前記特定のディスク装置とは異なるディスク装置にデータが書き込まれた後に、該データを該特定のディスク装置とは異なるディスク装置から読み出して所定の記憶領域に一旦保持し、その後、該データを該所定の記憶領域から該特定のディスク装置に書き込むことを特徴とする請求項7に記載のデータ格納方法。
JP24329196A 1996-09-13 1996-09-13 データ格納装置及びデータ格納方法 Expired - Fee Related JP3563541B2 (ja)

Priority Applications (2)

Application Number Priority Date Filing Date Title
JP24329196A JP3563541B2 (ja) 1996-09-13 1996-09-13 データ格納装置及びデータ格納方法
US08/927,015 US6021464A (en) 1996-09-13 1997-09-10 Real time disk array which guarantees write deadlines by selecting an alternate disk

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
JP24329196A JP3563541B2 (ja) 1996-09-13 1996-09-13 データ格納装置及びデータ格納方法

Publications (2)

Publication Number Publication Date
JPH1091357A JPH1091357A (ja) 1998-04-10
JP3563541B2 true JP3563541B2 (ja) 2004-09-08

Family

ID=17101665

Family Applications (1)

Application Number Title Priority Date Filing Date
JP24329196A Expired - Fee Related JP3563541B2 (ja) 1996-09-13 1996-09-13 データ格納装置及びデータ格納方法

Country Status (2)

Country Link
US (1) US6021464A (ja)
JP (1) JP3563541B2 (ja)

Families Citing this family (53)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
DE69912662T2 (de) * 1998-03-10 2004-05-13 Matsushita Electric Industrial Co., Ltd., Kadoma Vorrichtung und Verfahren zur Aufzeichnung von Daten in der Restaufnahmekapazität von Datenträgern
JP4473455B2 (ja) * 1999-01-12 2010-06-02 富士通株式会社 記録媒体へのアクセスを制御するアクセス制御装置および方法
US6691208B2 (en) * 1999-03-12 2004-02-10 Diva Systems Corp. Queuing architecture including a plurality of queues and associated method for controlling admission for disk access requests for video content
US6317808B1 (en) * 1999-03-26 2001-11-13 Adc Telecommunications, Inc. Data storage system and method of routing or assigning disk write requests among a set of disks using weighted available disk space values
US6766426B1 (en) * 1999-03-31 2004-07-20 Sony Corporation Apparatus and method for moving data among memories of networked devices
US6529972B1 (en) * 1999-08-10 2003-03-04 Intel Corporation Message translation and data proxy service for remote data transport in a computer network
US6721789B1 (en) * 1999-10-06 2004-04-13 Sun Microsystems, Inc. Scheduling storage accesses for rate-guaranteed and non-rate-guaranteed requests
US6438630B1 (en) * 1999-10-06 2002-08-20 Sun Microsystems, Inc. Scheduling storage accesses for multiple continuous media streams
US6957313B2 (en) * 2000-12-01 2005-10-18 Hsia James R Memory matrix and method of operating the same
US7734867B1 (en) * 2002-05-17 2010-06-08 Hewlett-Packard Development Company, L.P. Data storage using disk drives in accordance with a schedule of operations
WO2005010766A1 (ja) * 2003-07-24 2005-02-03 Fujitsu Limited データ格納システム
US7509373B2 (en) * 2003-11-24 2009-03-24 At&T Intellectual Property I, L.P. Methods for providing communications services
JP4321464B2 (ja) * 2005-03-11 2009-08-26 ヤマハ株式会社 情報記録装置及びプログラム
US7620710B2 (en) * 2005-12-19 2009-11-17 Commvault Systems, Inc. System and method for performing multi-path storage operations
JP2008146536A (ja) * 2006-12-13 2008-06-26 Hitachi Ltd ストレージ装置及びこれを用いたデータ管理方法
CN101685381B (zh) * 2008-09-26 2013-07-24 美光科技公司 固态大容量存储装置的数据串流
EP2438513B1 (en) 2009-06-03 2015-03-18 Hewlett Packard Development Company, L.P. Scheduling realtime information storage system access requests
KR101527308B1 (ko) * 2011-03-14 2015-06-09 휴렛-팩커드 디벨롭먼트 컴퍼니, 엘.피. 메모리 인터페이스
JP4877423B1 (ja) * 2011-03-15 2012-02-15 オムロン株式会社 Plcのcpuユニット、plc用システムプログラムおよびplc用システムプログラムを格納した記録媒体
JP5861706B2 (ja) 2011-06-28 2016-02-16 富士通株式会社 スケジューリング方法およびシステム
GB2509505A (en) * 2013-01-04 2014-07-09 Ibm Issuing a write to a secondary storage device, when a write to a primary storage device takes too long
US20150256601A1 (en) * 2014-03-10 2015-09-10 Palo Alto Research Center Incorporated System and method for efficient content caching in a streaming storage
US9660825B2 (en) 2014-12-24 2017-05-23 Cisco Technology, Inc. System and method for multi-source multicasting in content-centric networks
US9954795B2 (en) 2015-01-12 2018-04-24 Cisco Technology, Inc. Resource allocation using CCN manifests
US10333840B2 (en) 2015-02-06 2019-06-25 Cisco Technology, Inc. System and method for on-demand content exchange with adaptive naming in information-centric networks
US10075401B2 (en) 2015-03-18 2018-09-11 Cisco Technology, Inc. Pending interest table behavior
US10075402B2 (en) 2015-06-24 2018-09-11 Cisco Technology, Inc. Flexible command and control in content centric networks
US10701038B2 (en) 2015-07-27 2020-06-30 Cisco Technology, Inc. Content negotiation in a content centric network
US9986034B2 (en) 2015-08-03 2018-05-29 Cisco Technology, Inc. Transferring state in content centric network stacks
US9832123B2 (en) 2015-09-11 2017-11-28 Cisco Technology, Inc. Network named fragments in a content centric network
US10355999B2 (en) 2015-09-23 2019-07-16 Cisco Technology, Inc. Flow control with network named fragments
US9977809B2 (en) 2015-09-24 2018-05-22 Cisco Technology, Inc. Information and data framework in a content centric network
US10313227B2 (en) 2015-09-24 2019-06-04 Cisco Technology, Inc. System and method for eliminating undetected interest looping in information-centric networks
US10454820B2 (en) 2015-09-29 2019-10-22 Cisco Technology, Inc. System and method for stateless information-centric networking
US10263965B2 (en) 2015-10-16 2019-04-16 Cisco Technology, Inc. Encrypted CCNx
US9912776B2 (en) 2015-12-02 2018-03-06 Cisco Technology, Inc. Explicit content deletion commands in a content centric network
US10097346B2 (en) 2015-12-09 2018-10-09 Cisco Technology, Inc. Key catalogs in a content centric network
US10257271B2 (en) 2016-01-11 2019-04-09 Cisco Technology, Inc. Chandra-Toueg consensus in a content centric network
US10305864B2 (en) 2016-01-25 2019-05-28 Cisco Technology, Inc. Method and system for interest encryption in a content centric network
US10043016B2 (en) 2016-02-29 2018-08-07 Cisco Technology, Inc. Method and system for name encryption agreement in a content centric network
US10051071B2 (en) 2016-03-04 2018-08-14 Cisco Technology, Inc. Method and system for collecting historical network information in a content centric network
US10742596B2 (en) 2016-03-04 2020-08-11 Cisco Technology, Inc. Method and system for reducing a collision probability of hash-based names using a publisher identifier
US10264099B2 (en) 2016-03-07 2019-04-16 Cisco Technology, Inc. Method and system for content closures in a content centric network
US10067948B2 (en) 2016-03-18 2018-09-04 Cisco Technology, Inc. Data deduping in content centric networking manifests
US10091330B2 (en) 2016-03-23 2018-10-02 Cisco Technology, Inc. Interest scheduling by an information and data framework in a content centric network
US10320760B2 (en) 2016-04-01 2019-06-11 Cisco Technology, Inc. Method and system for mutating and caching content in a content centric network
US9930146B2 (en) 2016-04-04 2018-03-27 Cisco Technology, Inc. System and method for compressing content centric networking messages
US10425503B2 (en) 2016-04-07 2019-09-24 Cisco Technology, Inc. Shared pending interest table in a content centric network
US10063414B2 (en) 2016-05-13 2018-08-28 Cisco Technology, Inc. Updating a transport stack in a content centric network
US10135948B2 (en) 2016-10-31 2018-11-20 Cisco Technology, Inc. System and method for process migration in a content centric network
US10243851B2 (en) 2016-11-21 2019-03-26 Cisco Technology, Inc. System and method for forwarder connection information in a content centric network
US10712953B2 (en) * 2017-12-13 2020-07-14 International Business Machines Corporation Management of a data written via a bus interface to a storage controller during remote copy operations
CN114237500B (zh) * 2021-12-09 2024-08-09 北京美信时代科技有限公司 一种通过缓存事务提高写入效率的方法及系统

Family Cites Families (11)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH06332623A (ja) * 1993-05-24 1994-12-02 Mitsubishi Electric Corp アレイ型記録装置及び記録装置
JP3200500B2 (ja) * 1993-05-27 2001-08-20 株式会社日立製作所 ディスク装置及びディスク制御方法
JP3597550B2 (ja) * 1993-12-10 2004-12-08 株式会社日立製作所 ディスクアレイ装置
JP3104953B2 (ja) * 1993-12-17 2000-10-30 日本電信電話株式会社 多重読み取り特殊再生方法
JPH07239756A (ja) * 1994-02-28 1995-09-12 Nippon Telegr & Teleph Corp <Ntt> 入出力スケジューリング方法及び入出力スケジューリングシステム
US5544313A (en) * 1994-05-11 1996-08-06 International Business Machines Corporation Baton passing optimization scheme for load balancing/configuration planning in a video-on-demand computer system
JPH08152976A (ja) * 1994-11-28 1996-06-11 Fujitsu Ltd 記憶装置のアクセス方法
US5642152A (en) * 1994-12-06 1997-06-24 Microsoft Corporation Method and system for scheduling the transfer of data sequences utilizing an anti-clustering scheduling algorithm
US5583995A (en) * 1995-01-30 1996-12-10 Mrj, Inc. Apparatus and method for data storage and retrieval using bandwidth allocation
US5646676A (en) * 1995-05-30 1997-07-08 International Business Machines Corporation Scalable interactive multimedia server system for providing on demand data
US5787482A (en) * 1995-07-31 1998-07-28 Hewlett-Packard Company Deadline driven disk scheduler method and apparatus with thresholded most urgent request queue scan window

Also Published As

Publication number Publication date
US6021464A (en) 2000-02-01
JPH1091357A (ja) 1998-04-10

Similar Documents

Publication Publication Date Title
JP3563541B2 (ja) データ格納装置及びデータ格納方法
JP3878508B2 (ja) 回路群制御システム
US8499102B2 (en) Managing read requests from multiple requestors
US5802394A (en) Method for accessing one or more streams in a video storage system using multiple queues and maintaining continuity thereof
US7325041B2 (en) File distribution system in which partial files are arranged according to various allocation rules associated with a plurality of file types
US8155134B2 (en) System-on-chip communication manager
JPH0981497A (ja) 実時間ストリームサーバ並びに実時間ストリームデータの格納方法および転送方法
US5463381A (en) Database system having a plurality of nodes communicating with each other via communication network
US6343351B1 (en) Method and system for the dynamic scheduling of requests to access a storage system
JP2010015610A (ja) 情報処理装置、情報処理装置の制御方法、およびプログラム
JP3382176B2 (ja) 要求処理方法および要求処理装置
US5339449A (en) System and method for reducing storage channels in disk systems
JP2003131908A (ja) 記憶制御装置
JPH0683745A (ja) データ処理システムおよび方法
JP4502375B2 (ja) ファイルシステムおよびその制御方法
CN112463064B (zh) 基于双链表结构的i/o指令管理方法及装置
JP3609841B2 (ja) ファイル管理装置
JP3288213B2 (ja) サーバ
WO2017018978A1 (en) Scheduling jobs in a computing cluster
JPH08227343A (ja) 2次記憶装置の制御装置および制御システム
JP2002175208A (ja) デジタル映像・音声データの配信システム、ビデオサーバ及びバッファの制御方法
JPH07319839A (ja) 分散共有メモリ管理方法及びネットワーク計算機システム
JP3022829B2 (ja) 記憶装置の自動割り当て装置
JPH05216844A (ja) マルチプロセッサデータ処理システムにおける改良されたタスク分散のための方法および装置
JP2001346142A (ja) デジタル映像・音声データの配信システム、ビデオサーバ及びバッファの制御方法

Legal Events

Date Code Title Description
A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20040127

A521 Written amendment

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20040308

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20040406

A521 Written amendment

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20040506

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

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20040603

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20090611

Year of fee payment: 5

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20100611

Year of fee payment: 6

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20100611

Year of fee payment: 6

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20110611

Year of fee payment: 7

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20120611

Year of fee payment: 8

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20120611

Year of fee payment: 8

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20130611

Year of fee payment: 9

LAPS Cancellation because of no payment of annual fees