JP2004280779A - ストレージシステムのリモートコピーに於いて空白データを省略する方法と装置 - Google Patents

ストレージシステムのリモートコピーに於いて空白データを省略する方法と装置 Download PDF

Info

Publication number
JP2004280779A
JP2004280779A JP2003358734A JP2003358734A JP2004280779A JP 2004280779 A JP2004280779 A JP 2004280779A JP 2003358734 A JP2003358734 A JP 2003358734A JP 2003358734 A JP2003358734 A JP 2003358734A JP 2004280779 A JP2004280779 A JP 2004280779A
Authority
JP
Japan
Prior art keywords
data
storage system
blank
blank data
secondary storage
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Pending
Application number
JP2003358734A
Other languages
English (en)
Other versions
JP2004280779A5 (ja
Inventor
Chiyokuki Watanabe
直企 渡辺
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.)
Hitachi Ltd
Original Assignee
Hitachi Ltd
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 Hitachi Ltd filed Critical Hitachi Ltd
Publication of JP2004280779A publication Critical patent/JP2004280779A/ja
Publication of JP2004280779A5 publication Critical patent/JP2004280779A5/ja
Pending legal-status Critical Current

Links

Images

Classifications

    • 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/0646Horizontal data movement in storage systems, i.e. moving data in between storage devices or systems
    • G06F3/065Replication mechanisms
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/07Responding to the occurrence of a fault, e.g. fault tolerance
    • G06F11/16Error detection or correction of the data by redundancy in hardware
    • G06F11/20Error detection or correction of the data by redundancy in hardware using active fault-masking, e.g. by switching out faulty elements or by switching in spare elements
    • G06F11/2053Error detection or correction of the data by redundancy in hardware using active fault-masking, e.g. by switching out faulty elements or by switching in spare elements where persistent mass storage functionality or persistent mass storage control functionality is redundant
    • G06F11/2056Error detection or correction of the data by redundancy in hardware using active fault-masking, e.g. by switching out faulty elements or by switching in spare elements where persistent mass storage functionality or persistent mass storage control functionality is redundant by mirroring
    • G06F11/2082Data synchronisation
    • 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/0608Saving storage space on storage systems
    • 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/061Improving I/O performance
    • G06F3/0613Improving I/O performance in relation to throughput
    • 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/067Distributed or networked storage systems, e.g. storage area networks [SAN], network attached storage [NAS]
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/07Responding to the occurrence of a fault, e.g. fault tolerance
    • G06F11/16Error detection or correction of the data by redundancy in hardware
    • G06F11/20Error detection or correction of the data by redundancy in hardware using active fault-masking, e.g. by switching out faulty elements or by switching in spare elements
    • G06F11/2053Error detection or correction of the data by redundancy in hardware using active fault-masking, e.g. by switching out faulty elements or by switching in spare elements where persistent mass storage functionality or persistent mass storage control functionality is redundant
    • G06F11/2056Error detection or correction of the data by redundancy in hardware using active fault-masking, e.g. by switching out faulty elements or by switching in spare elements where persistent mass storage functionality or persistent mass storage control functionality is redundant by mirroring
    • G06F11/2071Error detection or correction of the data by redundancy in hardware using active fault-masking, e.g. by switching out faulty elements or by switching in spare elements where persistent mass storage functionality or persistent mass storage control functionality is redundant by mirroring using a plurality of controllers
    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y10TECHNICAL SUBJECTS COVERED BY FORMER USPC
    • Y10STECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y10S707/00Data processing: database and file management or data structures
    • Y10S707/99951File or database maintenance
    • Y10S707/99952Coherency, e.g. same view to multiple users
    • Y10S707/99953Recoverability
    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y10TECHNICAL SUBJECTS COVERED BY FORMER USPC
    • Y10STECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y10S707/00Data processing: database and file management or data structures
    • Y10S707/99951File or database maintenance
    • Y10S707/99952Coherency, e.g. same view to multiple users
    • Y10S707/99955Archiving or backup

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Human Computer Interaction (AREA)
  • Quality & Reliability (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)

Abstract

【課題】ストレージシステムの性能を向上する方法と装置を提供する。
【解決手段】セカンダリサブシステムにイニシャルコピーを作成するとき、あるいはプライマリストレージサブシステムに最初にデータを保存するときに、空白データを省略する。非空白データを順番に送付することにより、欠落しているアドレスが空白データであると識別する、あるいは空白データの存在する位置を指定する省略メッセージにより、データを省略することができる。
【選択図】図5

Description

本発明はストレージシステムに関し特にリモートコピー処理に関する。
[01] 最新のストレージシステムでは、膨大な量のデータをネットワーク上の多様なローカル及びリモートサイトに迅速に保存し、かつバックアップする機能をユーザーに提供する。このようなシステムでは、プライマリストレージサイトのディスクのイニシャルコピーはセカンダリストレージサイトのディスクに作成される。通常、ストレージシステムでは、ディスク全体のコピーを自動的に取るように設定されており、プライマリサイトとリモートサイトのディスクがリモートコピーのペアに設定されている。この処理を実行するにあたり、通常プライマリサイトのディスクのイニシャルコピーがセカンダリサイトの対応するディスクに作成される。プライマリサイトでの処理でデータが更新されると、更新されたデータがプライマリサイトからセカンダリサイトに転送されて、セカンダリサイトに“ミラー”される。
[02] しかしながら、データ処理システムの顧客あるいはユーザーの多くは、設置しているハードディスクドライブの容量いっぱいを使用してはいない、ということは良く知られたことである。したがって、各ハードディスクドライブには、セカンダリドライブにバックアップあるいは転送するべきデータのみならず、大量の“空白”データが存在する。この空白データは、ハードディスクのその時点で顧客が使用していない部分の全てを意味する。例えば、空白データは、ディスクのフォーマットされたが使われていない部分から構成されている場合もある。
[03] ハードディスクの容量が増大し続けており、プライマリサイトのハードディスク全体をセカンダリサイトのハードディスクへリモートコピー処理でコピーする場合、空白データの転送と保存にかなりの時間とネットワーク資源が消費される。空白データの大量コピーは、システムの資源とネットワークの処理能力を使い果たし、一般的に望ましくないことである。
[04] データ圧縮技術により問題は若干緩和される。データ圧縮技術によりネットワーク上を送信されるデータを圧縮してネットワークのトラフィックを軽減し、処理能力の消費が軽減される。このストレージシステムの圧縮技術の例として、米国ミネソタ州のミネアポリスにあるCNTが販売しているUltraNet Edge Storage RouterTM、あるいはニュージャージ州ランバートンにあるInrange Technologies Corpが販売する9801SNS Storage Network SystemTMがあげられる。これらの製品により、送信されるデータ量が減る意味で、ネットワークの負荷は減少するが、送信及び受信する装置は圧縮及び復元する負荷が増大し、復元されたデータには依然として空白データが含まれており、ターゲットのストレージサブシステムに書きこまなければならない。
[05] 空白データの送信とコピーを排除して、ネットワークと送信及び受信システムの負荷を減らす手段と装置が求められている。
[06] 本発明は、ストレージネットワークにおいて、空白データをコピーする必要を排除する方法と装置を提供するものである。本発明により、コントローラのリモートコピー処理の負荷が減少し、空白データの送信の必要が排除され、ネットワークの負荷が減少する。本発明は多様な実現方法を有している。1つの実現方法では、プライマリストレージサブシステムのディスクコントローラが、ディスクからキャッシュメモリにデータを移動するときに空白データを検出する。コントローラはチャネルコントローラに空白データを報告し、空白データがネットワークを通って送られることはなくなる。他の実現方法では、ディスクコントローラがホ、ストチャネルからキャッシュメモリにデータを移動するときに空白データを検出し、空白データの存在をチャネルコントローラに報告し、これにより空白データが送信されることを排除する。
[07] 空白データが検出されれば、リモートコピーコマンドを処理する方法は多種存在する。1つの方法は、空白データを単純に受信側のストレージシステムに送信しないことで、イニシャルリモートコピーでは十分である。この方法では、リモートコピー処理が始まる前に、セカンダリストレージサブシステムのリモートペアを構成するディスクがフォーマットされる。次に、“良い”情報がセカンダリサブシステムのミラーディスクにネットワークを通して送られる。セカンダリシステムのディスクはフォーマットされているので、空白でないデータの記録された個所はすべて有効で、他の個所すべてには空白データが入る。リモートディスクへは、例えばオールゼロでもオール1でも他のどのような形式でも、当該ディスクのフォーマットされた形式にしたがって、空白データが記録される。
[08] 空白データを処理するもう1つの方法は、イニシャルリモートコピー処理時に、全ての良いデータのアドレスを順番通りに保持することである。良いデータをセカンダリストレージ装置に書きこむ際に、ストレージ装置が良いデータの間の省略された領域に自分で空白データの書きこみを行う。
[09] 第三の方法は、ホストの書き込みにもイニシャルコピーにも有効で、“省略”メッセージを発行する空白データの検出器を有している。プライマリストレージが空白データを検出すると、省略する空白データのアドレスと大きさとパターンを含む省略メッセージを発行する。ターゲットストレージがこれを受信すると、選択された領域へのデータの書き込みが停止されるか、あるいは所期の大きさとパターンのデータが書き込まれる。通常はディスクがフォーマット済であればデータは停止され、でなければ省略メッセージの指示があれば所期の空白データパターンが書き込まれる。
[10] 実施例では、プライマリストレージシステムからセカンダリストレージシステムへ情報をコピーする方法に、コピーする情報をプライマリストレージシステムにおいて分析して、コピーするべき情報で構成されているか、あるいはコピーする必要のない空白データで構成されているか判断し、セカンダリストレージシステムへ空白データは送信せず、コピーするべきデータのみを送信し、セカンダリストレージシステムではコピーするべき情報をセカンダリストレージシステムのストレージ装置に書き込む手順が含まれている。ある実施例では、データを書き込むステップを実行する前に、セカンダリストレージがフォーマットされる。他の実施例では、プライマリストレージ装置で空白データが検出されると、空白データのブロックがプライマリストレージシステムに存在し、セカンダリストレージシステムへは送信されないことを示す、省略メッセージがセカンダリストレージ装置へ送られる。他の実施例では、セカンダリストレージシステムはフォーマットされておらず、コピーするべき情報のみが送信され、セカンダリシステムのストレージコントローラが媒体上の他の位置全部に空白データの書き込みを行う。
[28] 図1は代表的な従来技術のストレージシステムであり、プライマリストレージサブシステム102がセカンダリストレージサブシステム103とネットワーク105経由で結合している。一般的にネットワーク105は従来技術のネットワークで、例えばATM,sonet、dark fibreあるいはインタネットプロトコルの通信である。さらに、図1は1台のプライマリストレージサブシステムと1台のセカンダリストレージサブシステムを示しているが、多数でも少数でも好きなだけの数の互いに離れた場所にあるストレージシステムを使用することができる。従来これらのストレージシステムを使用するのは大企業でデータの共有を進める、あるいはバックアップコピーを用意して信頼性を向上するなどのためである。
[29] プライマリストレージシステムは一般的にストレージサブシステム102とチャネル103で結合するホスト101の制御下で動作する。チャネル103はチャネルコントローラ111経由でストレージサブシステム102とインタフェース結合している。通常、別のチャネルコントローラ112がストレージサブシステム102をチャネル104経由でネットワーク105へインタフェース接続する。
[30] セカンダリストレージシステム103は同様に構成され、ホスト106がセカンダリシステム103をチャネル108とチャネルコントローラ122経由で制御している。別のチャネルコントローラ121はネットワーク105に結合しているチャネル109とセカンダリストレージサブシステム103とのインタフェースとなっている。通常、チャネル103、104、108及び109はfibre channel、 ESCON、 SCSIあるいはGEが使用される。チャネル104と109はネットワーク105に結合しており、ネットワーク105は公衆回線でも専用線でも良い。
[31] ストレージシステム102は説明済のチャネルコントローラに加えてコントロール表117の制御で動作するキャッシュメモリ110を有している。内部バス114によりキャッシュメモリ110はチャネルコントローラ111と112およびディスクコントローラ113と通信することができる。例えばfibre channel、 SCSIあるいは ATA busなどの別の内部バス115を介してディスクコントローラ113はストレージボリューム116と通信する。ストレージサブシステムは一般的に同様に構成されている。このようにして、一般的にセカンダリストレージサブシステム103の構成はプライマリストレージサブシステム102の構成と適合したものとなっている。
[32] 一般的にデータはチャネルコントローラとキャッシュメモリを経由してプライマリストレージサブシステムに入出力される。ストレージボリュームに書き込むデータが着信すると一時的にキャッシュメモリに記録され、次にディスクコントローラが読み出してボリュームに書き込む。同様にボリューム116からネットワーク経由で送信するデータが読み出されると、チャネルコントローラに大ブロックで送る前に一般的にキャッシュメモリに保存される。ストレージサブシステムは物理ディスクアドレスをホストから見える論理ディスクアドレスに変換する。
[33] 上記のように通常の動作ではプライマリストレージサブシステム102のボリューム116のデータをセカンダリストレージサブシステム103のボリューム126へ“ミラー”することが望ましい。同じく上記のように、図1などのシステムが通常有するかなりの記憶容量の故に、ボリューム116にはかなりの量の“空白”データがあり得る。この空白データはハードディスク上のフォーマットされ未書き込みの部分あるいはディレクトリ入力が無効の(消去表示されているなど)ファイルまたはファイルの一部の大きな部分を占めている。ストレージサブシステムの性能を改善し、チャネルコントローラとネットワークの負荷を減少させるには、この大量の空白データをプライマリストレージサブシステムからチャネル104、ネットワーク105を経由して、ディスクボリューム126へデータを書き込むチャネル109へ送信しないことが有利である。以下にこれを実現した方法を説明する。
[34] 図2は、例えば図1の111,112,121あるいは122のどれであっても良いが、チャネルコントローラのブロック構成図である。図2のチャネルコントローラ201は内部にチャネルインタフェース204、中央処理装置206、メモリ205、ダイレクトメモリアクセス回路207及び内部バス203へのインタフェース208を有している。インタフェース204は例えばネットワークあるいはホストのチャネルコントローラに対して高レベルの機能をもったインタフェースとして動作し、一方インタフェース208はチャネルコントローラ201に対してキャッシュメモリあるいはディスクコントローラなどのストレージサブシステムの内部機能へのインタフェースを実行する。CPU206はバス209上での通信を介してチャネル201のコンポーネントを制御する。
チャネルインタフェース204はチャネルプロトコルを制御し、チャネルとCPU206及びDMA207のデータの送受信を制御し、メモリ205とチャネルインタフェース204との間のデータ転送を制御する。内部インタフェース208は内部バス203上での通信プロトコルを制御し、DMAコントローラ207とメモリ205の動作に対応して該ライン上のデータを制御する。
[35] 図3はディスクコントローラ301の構成を図示する概略図である。コントローラ301は図1のディスクコントローラ113または123の処理を実行するために使用することができる。ディスクコントローラは2種類のインタフェースを有している。インタフェースの1つ、内部インタフェース304は内部バス302(または図2の203)へのインタフェースである。他のインタフェース308はディスクバス303へのインタフェースで、ディスクバス303に結合しているストレージボリュームとの通信を可能にしている。内部インタフェース304とディスクインタフェース308はバス309を介して接続している。ディスクコントローラはCPU306とメモリ305及びDMAコントローラ307を有している。これらのコンポーネントは内部バス302とディスクバス303との間の情報の流れを調整している。内部インタフェース304は内部バスプロトコルを制御し、DMAコントローラ307と共に内部バスとメモリ305の間でデータを通信する。
同様にディスクインタフェース308はディスクバス303のプロトコルを制御し、CPU306、DMAコントローラ307の制御の下でメモリ305とディスクバス303の間でデータを通信する。上記のように、実施例ではディスクコントローラ301はストレージボリューム中の空白データをディスクバス303と接続するストレージボリューム中の空白データを検出することができる。DMAコントローラ307は公知の技術をバス309のチェックに適用している。DMAコントローラ307が空白データを検出するとバス309に接続する他の機器に警告の信号をバス309に発信する。これについてはさらに以下説明する。
[36] 図4乃至6で、各プライマリ及びセカンダリストレージサブシステムでのイニシャルコピー処理の概要を図示する。図4は、イニシャルコピーを作成するときのプライマリストレージサブシステム102を図示する。最初の動作はディスクコントローラ113がディスク116bからディスクデータを読み取りキャッシュメモリ110に送付することである。内蔵CPU(図示せず)の制御の下で動作しているチャネルコントローラ112はトランザクションをモニターし、キャッシュメモリ110に適当な量のデータが保存され、あわせてディスクコントローラ113の関連エントリがコントロール表117に入力されると、転送を開始する。
所期の量のデータがキャッシュメモリ110に蓄積されると、チャネルコントローラ112は“書き込み”コマンド(あるいは以下に述べるある種のタイプのシステムの場合はベンダー固有のコマンド)を発行しイニシャルコピーの処理を開始する。チャネルコントローラ112は、イニシャルコピーデータをキャッシュメモリ110からチャネル104経由でネットワーク105へ送付する。データはネットワーク105に送られるとセカンダリストレージシステム(図示せず)へ送信される。
[37] 図5はリモートコピー処理時のプライマリストレージサブシステム102の動作を図示する。このプロセスはホスト101がシステム102に書き込みコマンドを発行することにより起動する。次にチャネルコントローラ111がコマンドを受信し解析する。このコマンドで、チャネルコントローラ111はホスト101から書き込みデータを受信しキャッシュメモリ110に保存する。コントローラ111はまた本リモートコピーに関する情報をコントロール表117に保存する。キャッシュメモリ110からのデータがリモートコピーペアの一方として最終的にディスクに保存されると、チャネルコントローラ112はリモートコピーコマンドをセカンダリストレージサブシステム(図示せず)に発行する。
[38] 図6はチャネル109経由でネットワークからイニシャルコピーまたはリモートコピーデータが着信した際のセカンダリストレージサブシステム103の動作を示す図である。このとき、チャネルコントローラ121は受信したコマンドを解析し、データをキャッシュメモリ120に保存し、コントロール表127に適切なエントリを作成する。ディスクコントローラ123は定期的にコントロール表127をチェックする。ディスクコントローラ123が、ディスクコントローラで実行すべき処理を発見すると、ディスクコントローラはキャッシュメモリ120からデータを読み取り、ターゲットディスク、この場合ディスク126bへデータを書き込む。
[39] 空白データを送る場合、図4の(2)、図5の(2)あるいは図6の(3)に示すステップでの負荷は、本発明の実施例では軽減されることに注目してください。言い換えると、図4乃至6に関する処理は、通常の(空白でない)データを処理する際の説明と同様に実行される。しかしながらこれらの処理は空白データを処理する際には必要のないものである。
[40] 図7は本発明による手段の実施例のフローチャートである。本フローチャートはプライマリストレージサブシステム102(図1参照)で実行されるイニシャルコピーの手順を示している。イニシャルコピー処理が開始する前にプライマリとセカンダリのシステムは同期されリモートコピーペア、すなわちプライマリストレージサブシステムとセカンダリストレージサブシステムのディスク間の対応、が形成される。本処理はシステムアドミニストレータが実行する。本公知の処理の後、図7のイニシャルコピー処理が実行される。
イニシャルコピー処理の実行の最初のステップはファイルシステム701のクリーニングである。本ステップではプライマリディスクの未使用部分とセカンダリディスクの全ては空白データで占められる。このステップは商用入手可能なソフトウェア、例えばフィンランドのタンペールのJeticoから入手可能なBC WipeTM を使用して実行される。クリーニングソフトウェアと空白データのコピーを省略することを合わせると、ここに述べるようにリモートコピー処理の負荷をかなり減少させることができる。以下の説明で明らかになるとおり、クリーニング処理は必須ではない。
[41] クリーニングが完了すると、ステップ702でイニシャルコピーの作成が開始し、ターゲットディスクからデータが読み出される。本処理ではディスクコントローラ113はディスクからデータを読み出しキャッシュメモリ110に送付する。キャッシュの読み出しと書き込みでは、転送に際して通常大量のデータを、例えば1MBのデータが処理される。転送自体はDMA308の制御下で実行される。
[42] 図7に示すようにデータが読み出されると、ステップ703でデータをチェックして空白データの存在を判定する。本処理はデータパターンを判定するためバストラフィックを監視しているDMA307により実行される。この処理を通常“snooping”と呼んでいる。DMA307がデータパターンが空白データで構成されていることを検出すると、当該情報がCPU306へもたらされる。データが空白であるか否かの判定はクリーニング処理に使われたソフトウェアまたはイニシャルコピー処理を実行する前にハードディスクをフォーマットするのに使用されたソフトウェアで実行される。
通常、空白データはオールゼロか、オール1あるいはゼロと1の繰り返し、例えば010101で構成されている。このパターンが現れたら、CPU306はコントロール表117を用いて空白データのコピーを省略するようにシステムに指示する。一方、データが1とゼロのランダムなパターンであったときは、CPU306はコントロール表117にエントリを行って通常処理を可能にする。
[43] データが転送されるとチャネルコントローラ112は定期的にコントロール表117をチェックする。チャネルコントローラが表117を用いて“正常な”データのコピー−イニシャルコピー−であると判断したらチャネルコントローラ112はデータ転送を行う。この転送でデータは最終的にプライマリストレージシステム102からセカンダリストレージシステム103にコピーされる。CPU206はDMA207にコマンドを送りキャッシュメモリ110からメモリ205へデータを移動させる。その後、CPU206はチャネルインタフェース装置112へコマンドを送り、イニシャルコピー(リモートコピー)コマンドをセカンダリストレージシステム103へネットワーク105を通して発行させる。リモートコピーコマンドの発行はステップ704に示されている。
[44] 空白データのコピーを省略要求のときはCPU206は省略メッセージを発行しデータ転送を行わない。省略メッセージ自体が1以上の量(1MBサイズ、上記参照)のデータがコピーされないことを示している。ディスクコントローラはディスク上のすべてのデータがセカンダリサブシステムに送られるか、空白データと判定されるまで、図7のステップ702−705を繰り返し続ける。これはステップ706に示されている。
[45] ステップ707に示されるように、ディスク上の全てのデータが転送されるか空白データと判定されるとディスクコントローラは次のディスクまたはボリュームを選択して処理を繰り返す。最後にステップ708に示すように、プライマリサイトのストレージの全ボリュームがセカンダリサイトのストレージにイニシャルコピーされるかリモートコピーされる。この時点でプライマリストレージサイト102のイニシャルコピー処理は完了する。
[46] 図8はセカンダリストレージシステム103のイニシャルコピー処理を示すフローチャートである。上記のごとく、管理者の最初のステップの選択肢はステップ801に示すようにセカンダリストレージのボリュームをフォーマットすることである。セカンダリストレージサイトでのイニシャルコピーの実行を指示するコマンドがステップ802で受信されると処理が開始される。このとき、チャネルコントローラ121はイニシャル(リモート)コピーコマンドをネットワーク105を介して受信する。CPU206はチャネルインタフェース204で受信したコマンドを解析する。コマンドが通常データのコピーを指示するものであったときはCPU206はチャネルインタフェース204にプライマリストレージシステム102からネットワーク105経由でデータを受信するように指示する。データが着信するとチャネルインタフェース204はデータをメモリ205に保存する。
[47] 次にCPU206の制御の下に、DMA装置207はデータをメモリ205からキャッシュメモリ120へ移動するよう指示を受ける。CPU206からの本要求はコントロール表127に保存される。ディスクコントローラ123は定期的にコントロール表127をチェックする。ディスクコントローラ123が要求を発見すると、ディスクインタフェース308はCPU306の指示を受け、書き込みコマンドを発行しディスクにデータを書き込む。これはフローチャートにステップ803,804及び806として示されている。以上は正常(空白でない)データの処理である。
[48] 一方、チャネルコントローラ121が受信したコマンドが空白データを意味する省略メッセージの場合、CPU206は省略処理を開始する。このようにステップ803で空白データが検出され、ステップ805で空白データの省略処理が実行される。この場合、セカンダリストレージシステム103は事前にディスクがクリーニングまたはフォーマットされており、すでに空白データが指定された位置に書き込まれているので、データをディスクに書き込むことは行わない。省略メッセージによりある種のパターンのデータを書き込むことを求められ、ディスクがクリーニングまたはフォーマットされておらず、そのパターンがセカンダリストレージに書き込まれていない場合はディスクコントローラ123は省略要求を検出すると指定されたパターンをディスクに書き込む。
本処理はCPU306が所期のパターンをメモリ305に生成し、ディスクインタフェース装置308にそのデータをディスクに書き込むようコマンドを発行することにより達成される。上記のプロセスはステップ807に示すようにセカンダリストレージサイト103のイニシャルコピーが完了するまで繰り返し実行される。
[49] 前に説明したように、セカンダリストレージサイトで読み出しと書き込みを実行中に空白データを省略する手段はいくつか存在する。空白データを省略する方法のうち2つを、図9bと9cに示している。図9aは空白データを省略しない場合の手順を示している。図9aを最初に説明する。図9aにてData0とData3は正常データで、Data1とData2は空白データである。
図9aに示すように、通常のイニシャルまたはリモートコピー処理では、プライマリストレージサブシステム102はデータセットData0、Data1、Data2、Data3及びData4の各々に計4つのコピーコマンドを発行する。これらのコマンドによりデータはプライマリストレージシステム102のメモリからセカンダリストレージシステム103のメモリへ転送される。
セカンダリストレージシステムではさらに4つのコマンドが解読され実行され、Data0、Data1、Data2及びData3がセカンダリストレージシステムのディスクに書き込まれる。上記の説明から明らかなように、Data1及びData2をプライマリストレージシステムの中からネットワークを介して送信しセカンダリストレージシステムに再度書き込みを行うために使用される時間と通信資源は不必要であり、無駄である。
[50] 図9bと9cに空白データを省略する2つの技術を図示している。図9bはセカンダリストレージサブシステムのボリュームが、プライマリストレージシステムの空白データのフォーマットと一致するようにフォーマットされている場合の空白データを省略する処理を示す図である。図9bの場合、上記図7と8を用いて説明した技術により、プライマリストレージシステムがData1及びData2が空白データであり、これらをセカンダリストレージシステムに送信する必要がないことを検出する。
セカンダリストレージシステムは既に適切にフォーマットされているのが分かっているので、プライマリストレージシステムはData1またはData2を送信することも、あるいはData1またはData2の存在を通知する必要もない。Data0及びData3がセカンダリストレージサブシステムボリュームにコピーされるとこれらのボリュームの内容はプライマリストレージシステム102の対応するボリュームの内容と一致(ミラー)する。
[51] セカンダリストレージシステム103がフォーマットされていない場合、他の代替手段が実行される。この場合、プライマリストレージシステムがイニシャルコピーコマンドを順番に発行すると、セカンダリストレージシステムはData1とData2のアドレスが省略されたことが分かる。この場合、空白のData1とData2はネットワークを介して送信されることはないが、セカンダリストレージシステムはData1とData2の省略されたアドレスを検出できるので、ストレージボリュームに適切な形式で空白データの書き込みを行う。
[52] 図9cは本発明の他の実施例を示す。図9cでは空白データを省略したことが、プライマリストレージサブシステム102からセカンダリストレージシステム103へ空白データが省略されたことを示すメッセージの送信により連絡される。この場合、セカンダリストレージサブシステムのボリュームを前もってフォーマットしておく必要はない。図に示すようにData1とData2から構成される空白データの存在はプライマリストレージサブシステムにより、例えばDMA装置がデータの得られるバスをチェックしているなどにより検出される。データのあるものが、例えばData1とData2が、空白データであると判定されると、プライマリサブシステム102は1つのメッセージにそれらをまとめてセカンダリストレージサブシステム103へその情報を送る。セカンダリストレージサブシステムはプライマリストレージサブシステム102から送られてきた省略メッセージを解析して、ストレージボリュームの中の省略メッセージで指定されたData1とData2の位置に空白データの書き込みを実行する。
省略メッセージの送信によりセカンダリストレージシステムでの該当するデータの書き込みの必要性はなくならないが、ネットワークのトラフィックは軽減し、セカンダリサイトでの負荷が軽減し、“真の”データをプライマリとセカンダリのサブシステム間で送信することに資源をあてることが可能になる。
[53] 図9dは他の観点から空白データの省略処理を説明する図である。図の上側はデータ(空白および非空白)及びデータをセカンダリシステムに書き込みを行う通常コマンドが示されている。コマンド(Cmd)は指定されたサイズとアドレス(Adr)のデータブロックの書き込み指示する。例えば、最初のコマンドはサイズ0x0010でアドレス0x0030にデータの書き込みを行うものである。図の下側の部分は非空白データのみをセカンダリサブシステムに送る方法を示している。
[54] 図10aは省略メッセージを示す図である。図10aの左側の、プライマリとセカンダリストレージシステム間で空白データを転送するための、データ転送の数に注目して欲しい。図10aの右側は、指定されたデータの“塊”が省略されたことを示すために省略メッセージが使われている。データ(FCP_DATA)を送信するステップが全て削除されている。
[55] 図10bは図10aと同様の図である。図10bの左側に示すように、空白データが送信されると膨大な量の空白データがプライマリからセカンダリストレージシステムへ送信される。逆に図10bの右側では本発明の方法が適用され両ストレージサブシステム間で全空白データの送信の必要がなくなっている。空白データの転送は図10aで説明したのと同じコマンドで示されている。
[56] 図11は省略メッセージの1例である。メッセージは9バイト(行で表す)で構成され、9バイトの各ビットの状態は列で表されている。オペレーションコードはコピーを省略することを示しており、バイト2−5に開始論理ブロックアドレスがバイト7−8に転送長が示されている。
[57] 図12は省略メッセージの例で、セカンダリストレージサブシステムサイトで書き込むべきデータパターンが含まれている。省略メッセージは図11と同じフォーマットであるがストレージボリュームに書き込むべきデータパターンがメッセージのバイト6に表示されている。図11と図12に示すメッセージフォーマットは代表例である。メーカー固有のメッセージを使用することができ、特定のメッセージあるいはコマンドに基づいて、多様なサイズの空白データを省略することができる。例えば、次の10バイト、次の100バイトのコピーを省略するなど個々のメッセージを送ることができる。
[58] 図13はチャネルコントローラを使用してプライマリストレージサブシステムにホストが書き込みを行う場合の手順を示すフローチャートである。この場合、書き込み処理で空白データが検出されるとプライマリシステムでの最初のデータ保存を加速することができる。チャネルコントローラ111のCPU206がホストの入出力動作を処理し、これはステップ1301及び1303に示されている。チャネルコントローラ112のCPU206はリモートコピーを処理し、これはステップ1303,1304及び1305に示されている。
[59] ホスト101が“書き込み”コマンドを発行すると、チャネルインタフェース204がコマンドを受信しCPU206に報告し、場合によりメモリ205にコマンドを保存する。CPU206はコマンドを解析し有効であれば実行を開始する。無効であればCPU206は“no good”ステータスをチャネルインタフェース204経由でホスト101に返す。これらの動作は例えばSCSI仕様に従って処理される。
[60] コマンドが有効であると仮定して、CPU206はホスト101からのデータ転送の開始をインタフェース装置204に指示する。インタフェース装置204はチャネル103からメモリ205へデータを転送する。CPU206はメモリ205へ指定された量のデータが転送されるのを待ち、次いでDMA207にコマンドを発行する。DMA207は内部インタフェース208と内部バス203を使用してメモリ205からキャッシュメモリ110へデータを転送するよう指示を受ける。CPU206はインタフェース208を制御してチャネルインタフェース204を追い越すことを防止している。
すべてのデータがキャッシュメモリ110に転送されるとCPU206はチャネルインタフェース204とチャネル103を経由してホスト101に”good”ステータス報告を返す。これらの処理の実行にともないCPU206は定期的にコントロール表117を更新する。これらの動作すべては図13の書き込みコマンドステップ1301に含まれている。
[61] 上記のように転送が行われている間DMA207はデータパターンをチェックしている。データが空白データであった場合、DMA207はCPU206に省略メッセージをコントロール表117に書きこませる。ディスクコントローラ113のCPU306はデータ書き込み中に定期的にコントロール表117をチェックしている。CPU306が、ディスクコントローラ113で処理される省略メッセージを検出すると、CPU306はデータの書き込み処理を開始する。処理のために必要な情報はここに全てコントロール表117に含まれている。
DMA307はCPU306の指示を受け、チャネルコントローラ111がコントロール表117をチェックする速度を追い越さない速度でデータをキャッシュメモリ110からメモリ305に転送する。データ転送の間DMA307はまた空白データを検出することができる。CPU306は指定された量のデータがメモリ305に転送されるまで待つ。データが空白データであった場合、CPU306は省略メッセージをコントロール表117に入力する。CPU306は次にディスクインタフェース装置308とディスクバス303経由でメモリ305からディスク115にデータの転送を開始する。
CPU306はディスクインタフェース308を制御し、内部インタフェース304を追い越すことがないことを保証している。全てのデータがディスク115に書き込まれると、これもステップ1302に示すように、CPU306はリモートコピー情報をコントロール表117に発行する。
[62] チャネルコントローラ112は定期的にコントロール表117をチェックしている。チャネルコントローラ112がリモートコピー要求を検出するとリモートコピー処理を開始する。2件の連続したリモートコピー処理であれば、CPU206は1つのリモートコピーコマンドに結合することができ、これは標準コマンドでもベンダー固有コマンドであっても良い。リモートコピーコマンドを発行する前にCPU206はコントロール表117をチェックする。省略メッセージがあれば、CPU206はステップ1305に示すように省略メッセージを発行する。CPU206が省略メッセージを発見しなかった場合、リモートコピーコマンドを発行しセカンダリストレージサブシステム103にデータを転送する。セカンダリストレージサブシステム103でのリモートコピー処理は図8のステップ802−806で説明したのと同様である。
[63] 図14は上記の方法と装置とは異なる処理の概要を示す図である。図14の第一列は個別のアプリケーションを、言い換えると空白データはセカンダリサイトでイニシャルコピーを作成中か、もっと前にプライマリストレージサイトで書き込み中に検出されるのかを示している。図14の次の列はプライマリストレージサイトで空白データを検出するコンポーネントを示している。プライマリストレージサブシステムからセカンダリストレージサブシステムへのイニシャルコピーの場合、空白データはディスクコントローラにより検出される。一方、プライマリストレージシステムにホストから初めてデータが書き込まれるときはチャネルコントローラが空白データを検出する。
[64] 図表の次の列に空白データの検出に対しての対処が要約されている。ディスクコントローラで検出された場合、すなわちイニシャルコピー処理の場合、省略メッセージが生成されるか、データが無視されるかである。これら2つの処理は図9bと9cを用いてそれぞれ説明されている。ホストから空白データが着信したことをチャネルコントローラが検出した場合、データの書き込みを省略するべきことを下流のディスクに伝えるため省略メッセージが使われる。本処理については図9cを用いて説明した。
[65] 図14の右側の列はターゲットサブシステムで生ずる事項を述べている。イニシャルコピー時の場合は、ターゲットサブシステムの対応は全てセカンダリシステムで発生する。省略メッセージの場合、ディスクがすでに適切にフォーマットしてあれば、セカンダリサブシステムでは対応する必要がない。前にフォーマットしてなければ、右側のブロックに示すようにデータの書き込みを行う必要がない。同様にイニシャルコピー処理で、空白データは単に省略する場合、ディスクが以前にフォーマットされていればセカンダリサブシステムでは対応する必要がない。
ディスクが以前にフォーマットされていないかクリーニングされていなければ空白データを書き込まなければならない。図14の最下段の行にホストの書き込み処理について示す。この場合は省略メッセージによりプライマリサブシステムに空白データが書き込まれる結果になる。
[66] 以上は発明の実施例の説明である。以下の請求項の範囲を逸脱することなく発明の実施において変更を加えることが可能であることは容易に分かることである。
図1は、ネットワーク経由で通信するプライマリストレージサブシステムとセカンダリストレージサブシステムを有するストレージシステムを示す図である。 図2は、図1にブロック形式で示すチャネルコントローラの構成を示す図である。 図3は、同じく図1のブロックに示すディスクコントローラの構成を示す図である。 図4は、プライマリストレージシステムのイニシャルコピー処理を示す図である。 図5は、この処理を詳細に示す図である。 図6は、プライマリストレージシステムからのコマンドに応じたセカンダリストレージシステムの動作を示す図である。 図7は、プライマリストレージシステムのイニシャルコピー処理の手順を示すフローチャートである。 図8は、セカンダリストレージサブシステムのイニシャルコピーの手順を図示する図である。 図9aは、空白データを省略することなくコピーする従来技術の処理を図示する図である。 図9bは、空白データを省略するリモートコピー処理を図示しする図である。 図9cは、空白データを省略するメッセージを使用して空白データを省略したリモートコピー処理を図示しする図である。 図9dは、空白データの送信とコピーの省略を行う処理を図示する図である。 図10aは、本発明の1実施例におけるプライマリストレージシステムとセカンダリストレージシステムの関係を図示する図である。 図10bは、本発明の1実施例におけるプライマリストレージシステムとセカンダリストレージシステムの関係を図示しする図である。 図11は、ベンダー固有のコマンドを使用した“省略”メッセージの例を示す図である。 図12は、省略メッセージの他の例であるがデータパターンを図示しする図である。 図13は、プライマリストレージシステムとダイレクトメモリアクセス装置の空白データを検出する動作のフローチャートである。 図14は、ストレージシステムの動作の多様な様式を示す図である。
符号の説明
101・・・ホスト、105・・・ネットワーク、106・・・ホスト、110…キャッシュメモリ、111・112・・・チャネルコントローラ、113・・・ディスクコントローラ、115・・・ボリューム、120・・・キャッシュメモリ、121・122・・・チャネルコントローラ、123・・・ディスクコントローラ、125・・・ボリューム、204・・・チャネルインタフェース、205・・・ メモリ、206・・・CPU、207・・・DMA、208・・・内部インタフェース、203・・・ 内部バス、304・・・内部インタフェース、305・・・メモリ、306・・・CPU、307・・・DMA、308・・・ディスクインタフェース、303・・・ディスクバス

Claims (26)

  1. プライマリストレージシステムからセカンダリストレージシステムへ情報をコピーする方法において、
    コピーされる情報をプライマリストレージシステムで解析し、情報がコピーされるべきデータで構成されているか、コピーする必要のない空白データで構成されているかを判断すること、
    セカンダリストレージシステムへコピーするべきデータを転送し、空白データは転送しないこと、
    セカンダリストレージシステムではコピーするべき情報をセカンダリストレージシステムのストレージ装置に書き込みを行うことを有することを特徴とする方法。
  2. 請求項1に記載の方法において、
    セカンダリストレージシステムがストレージ装置にコピーを行うステップの前に、ストレージ装置が空白データを有するようフォーマットするステップを有することを特徴とする方法。
  3. 請求項1に記載の方法において、
    空白データがプライマリストレージシステムに存在しセカンダリストレージシステムへは転送されないことを示す省略メッセージをセカンダリストレージシステムに送信することをさらに有することを特徴とする方法。
  4. 請求項3に記載の方法において、
    省略メッセージを受信後、セカンダリストレージシステムがストレージ装置に空白データを書き込むことを特徴とする方法。
  5. 請求項1に記載の方法において、
    転送ステップが、セカンダリストレージシステムへ空白データが転送されたならば前記空白データが保存されたはずのセカンダリストレージシステムの場所に書き込むべき空白データのパターンをセカンダリストレージシステムへ転送するステップを、さらに有していることを特徴とする方法。
  6. 請求項3に記載の方法において、
    省略メッセージが、セカンダリストレージシステムへ空白データが転送されたならば前記空白データが保存されたはずのセカンダリストレージシステムの場所に書き込むべき空白データのパターンを、さらに有していることを特徴とする方法。
  7. 請求項1に記載の方法において、
    プライマリストレージシステムがディスクコントローラを有し、前記ディスクコントローラがコピーする情報を解析して前記情報がコピーするべきデータから構成されているかあるいは空白データであるかを判断するステップを実行することを特徴とする方法。
  8. 請求項1に記載の方法において、
    コピーするべきデータがプライマリストレージからセカンダリストレージシステムへ順番に送られ、そして
    セカンダリストレージシステムは前記順番にギャップがあった場合空白データを書き込むことを特徴とする方法。
  9. 請求項1に記載の方法において、情報解析のステップが、前記情報がプライマリストレージシステムのバスを転送されている間に実行されることを特徴とする方法。
  10. 請求項9に記載の方法において、DMAコントローラがバスをチェックし情報を解析することを特徴とする方法。
  11. ホストと前記ホストに接続するストレージシステムを有し、前記ストレージシステムは前記ホストに接続するチャネルコントローラとデータを保存する装置を有するシステムにおいて、前記装置にデータを書き込む方法であって、
    ストレージシステムへデータが転送される際にモニターすること、
    データブロックが空白データのみからなる場合、前記装置に省略メッセージを送って前記装置が空白データの書き込みを行うのを抑止すること、及び
    データブロックが空白でないデータで構成されている場合、前記データを前記装置に送って前記データの書き込みを行うことを有することを特徴とする方法。
  12. 請求項11に記載の方法において
    非空白データを書き込む前に前記装置をフォーマットして空白データを保持させるステップが実行されることを特徴とする方法。
  13. 請求項11に記載の方法において
    省略メッセージが空白データのアドレスを示していることを特徴とする方法。
  14. 請求項13に記載の方法において省略メッセージが空白データの量も示していることを特徴とする方法。
  15. 請求項13に記載の方法において、省略メッセージを受信後、空白データのアドレスに前記装置が空白データを書き込むことを特徴とする方法。
  16. 請求項11に記載の方法において、省略メッセージがさらに空白データのパターンと空白データのアドレスを有していることを特徴とする方法。
  17. 請求項16に記載の方法において、省略メッセージを受信後、前記装置が空白データのパターンを空白データのアドレスに書き込むことを特徴とする方法。
  18. 請求項11に記載の方法において、ストレージサブシステムはディスクコントローラを有しており、前記ディスクコントローラがコピーする情報を解析し空白データで構成されているか否かを判定するステップを実行することを特徴とする方法。
  19. コンピュータの制御下で動作しており、保存する情報と、前記情報を保存する指定されたアドレスを受信するために接続しており、前記情報は空白データと非空白データを有している、ストレージシステムにおいて、受信したアドレスに欠落の有無を判定するため指定されたアドレスをモニターすること、及び、欠落しているアドレスには空白データを書き込むことを有する方法。
  20. 請求項19に記載の方法において、指定されたアドレスには非空白データを書き込むことをさらに含むことを特徴とする方法。
  21. プライマリストレージシステムにおいて、プライマリストレージシステムからセカンダリストレージシステムへ送るデータを保存されたデータから選択する方法において、
    保存されているデータから選択された量のデータを読み取ること、
    保存されているデータが空白データか非空白かを判定すること、
    保存されているデータが非空白データであれば、前記データをセカンダリストレージシステムへコマンドとともに送付し、セカンダリストレージシステムで前記データを保存させること、
    保存されているデータが空白データであれば、前記データはセカンダリストレージシステムへは送付しないこと、及び
    保存されているデータが全てセカンダリストレージシステムへ送付されるかあるいは空白データと判定されるまで先行のステップを繰り返すことを有することを特徴とする方法。
  22. 請求項21に記載の方法において、
    保存されているデータが空白データであった場合に前記データをセカンダリストレージシステムへは送付しないステップが、セカンダリストレージシステムへ空白データが送付されなかったことを表示するメッセージを送ることを含むことを特徴とする方法。
  23. 請求項22に記載の方法において、メッセージが空白データのアドレスと量を表示していることを特徴とする方法。
  24. プライマリストレージシステムから送信されたデータを受信するために接続しているセカンダリストレージシステムにおいて、プライマリシステムから送信されたデータを保存する方法であって、
    プライマリストレージシステムから送信されるデータを保存することを指示するコマンドをプライマリストレージシステムから受信すること、
    プライマリストレージシステムから送信されたデータを受信すること、
    送付された選択された量の各データの一連のアドレスを受信すること、
    一連のアドレスを解析して、アドレスの順番にアドレスの欠落の有無を判定すること、
    アドレスで指定された場所にデータを保存すること、
    アドレスの順番にて欠落しているアドレスに空白データを保存すること、及び 送付されたデータが全て保存されるまで以上のステップを繰り返すことを有する方法。
  25. 請求項24に記載の方法において、
    アドレスの順番にて欠落しているアドレスに空白データを保存するステップが、アドレスに指定された場所にデータを保存するステップより以前にセカンダリストレージシステムをフォーマットすることで実行されることを特徴とする方法。
  26. 請求項24に記載の方法において、
    アドレスの順番にて欠落しているアドレスに空白データを保存するステップが、選択されたデータパターンをアドレスの順番にて欠落しているアドレスに書き込むことで実行されることを特徴とする方法。
JP2003358734A 2002-10-31 2003-10-20 ストレージシステムのリモートコピーに於いて空白データを省略する方法と装置 Pending JP2004280779A (ja)

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
US10/286,513 US7024526B2 (en) 2002-10-31 2002-10-31 Apparatus and method of null data skip remote copy

Publications (2)

Publication Number Publication Date
JP2004280779A true JP2004280779A (ja) 2004-10-07
JP2004280779A5 JP2004280779A5 (ja) 2006-10-12

Family

ID=32175475

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2003358734A Pending JP2004280779A (ja) 2002-10-31 2003-10-20 ストレージシステムのリモートコピーに於いて空白データを省略する方法と装置

Country Status (2)

Country Link
US (1) US7024526B2 (ja)
JP (1) JP2004280779A (ja)

Cited By (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2008130080A (ja) * 2006-11-22 2008-06-05 Hitachi Ltd 動的チャンク割付けストレージシステムにおけるバックアップおよび復元のための方法および装置
JP2008234355A (ja) * 2007-03-20 2008-10-02 Toshiba Corp ディスクコピー装置及びプログラム
JP2010541060A (ja) * 2007-10-01 2010-12-24 インターナショナル・ビジネス・マシーンズ・コーポレーション シン・プロビジョニングの移行および取り消しのための方法および装置
JP2013073388A (ja) * 2011-09-27 2013-04-22 Fujitsu Ltd ストレージ装置、ストレージ装置の制御方法及びストレージシステム
JP2020107243A (ja) * 2018-12-28 2020-07-09 キヤノン株式会社 情報処理装置及び情報処理装置の制御方法

Families Citing this family (26)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7900017B2 (en) 2002-12-27 2011-03-01 Intel Corporation Mechanism for remapping post virtual machine memory pages
US9489150B2 (en) 2003-08-14 2016-11-08 Dell International L.L.C. System and method for transferring data between different raid data storage types for current data and replay data
CN101566931B (zh) 2003-08-14 2011-05-18 克姆佩棱特科技公司 虚拟磁盘驱动系统和方法
JP2005166016A (ja) * 2003-11-11 2005-06-23 Nec Corp ディスクアレイ装置
EP2021903A2 (en) * 2006-05-24 2009-02-11 Compellent Technologies Data progression disk locality optimization system and method
CN102880424B (zh) 2006-05-24 2015-10-28 克姆佩棱特科技公司 用于raid管理、重新分配以及重新分段的系统和方法
US7962499B2 (en) * 2006-08-18 2011-06-14 Falconstor, Inc. System and method for identifying and mitigating redundancies in stored data
US7949847B2 (en) * 2006-11-29 2011-05-24 Hitachi, Ltd. Storage extent allocation method for thin provisioning storage
JP4331220B2 (ja) * 2007-03-07 2009-09-16 株式会社東芝 未使用物理領域自律管理機能を持つストレージ装置
US9619171B2 (en) * 2007-10-05 2017-04-11 Hitachi, Ltd. Storage system and virtualization method
US9003054B2 (en) * 2007-10-25 2015-04-07 Microsoft Technology Licensing, Llc Compressing null columns in rows of the tabular data stream protocol
US8108634B1 (en) * 2008-06-27 2012-01-31 Emc B.V., S.A.R.L. Replicating a thin logical unit
JP4762289B2 (ja) * 2008-10-01 2011-08-31 株式会社日立製作所 特定パターンデータが格納される仮想ボリュームへの記憶領域の割り当てを制御するストレージシステム
US8892676B2 (en) * 2008-11-07 2014-11-18 Compellent Technologies Thin import for a data storage system
US20100174850A1 (en) * 2009-01-08 2010-07-08 Chin-Huo Chu Data moving method and system utilizing the same
US20110246731A1 (en) * 2009-03-18 2011-10-06 Hitachi, Ltd. Backup system and backup method
JP4818395B2 (ja) * 2009-05-20 2011-11-16 富士通株式会社 ストレージ装置及びデータコピー方法
US8468292B2 (en) * 2009-07-13 2013-06-18 Compellent Technologies Solid state drive data storage system and method
US9146851B2 (en) 2012-03-26 2015-09-29 Compellent Technologies Single-level cell and multi-level cell hybrid solid state drive
JP5586718B2 (ja) * 2012-06-19 2014-09-10 株式会社東芝 制御プログラム、ホスト装置の制御方法、情報処理装置およびホスト装置
US10423354B2 (en) * 2015-09-23 2019-09-24 Advanced Micro Devices, Inc. Selective data copying between memory modules
TWI662473B (zh) * 2016-03-28 2019-06-11 慧榮科技股份有限公司 資料儲存裝置的映像檔製作方法
US10007561B1 (en) 2016-08-08 2018-06-26 Bitmicro Networks, Inc. Multi-mode device for flexible acceleration and storage provisioning
US10216596B1 (en) * 2016-12-31 2019-02-26 Bitmicro Networks, Inc. Fast consistent write in a distributed system
US11042530B2 (en) * 2018-01-17 2021-06-22 International Business Machines Corporation Data processing with nullable schema information
US20240028241A1 (en) * 2022-07-22 2024-01-25 Arm Limited Memcpy micro-operation reduction

Family Cites Families (14)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4803651A (en) 1986-02-10 1989-02-07 Ibm Corporation Method for encoding and decoding acyclic, linked-list data structures for efficient storage, retrieval and searching
US5226161A (en) 1987-08-21 1993-07-06 Wang Laboratories, Inc. Integration of data between typed data structures by mutual direct invocation between data managers corresponding to data types
US5031218A (en) 1988-03-30 1991-07-09 International Business Machines Corporation Redundant message processing and storage
EP0428021B1 (en) 1989-11-03 1998-09-02 Compaq Computer Corporation Method for data distribution in a disk array
US5249279A (en) 1989-11-03 1993-09-28 Compaq Computer Corporation Method for controlling disk array operations by receiving logical disk requests and translating the requests to multiple physical disk specific commands
US5761676A (en) * 1994-09-19 1998-06-02 Bmc Software, Inc. Method of removing unneeded data from DB2 logs and other data sets having displacement-dependent data
US5796735A (en) 1995-08-28 1998-08-18 Integrated Device Technology, Inc. System and method for transmission rate control in a segmentation and reassembly (SAR) circuit under ATM protocol
US5758062A (en) 1996-04-30 1998-05-26 Oracle Corporation Method and apparatus for regression testing of application logic
US6094443A (en) 1997-10-30 2000-07-25 Advanced Micro Devices, Inc. Apparatus and method for detecting a prescribed pattern in a data stream by selectively skipping groups of nonrelevant data bytes
JP4467791B2 (ja) 1997-11-24 2010-05-26 ブリティッシュ・テレコミュニケーションズ・パブリック・リミテッド・カンパニー 情報管理及び検索
US6073221A (en) * 1998-01-05 2000-06-06 International Business Machines Corporation Synchronization of shared data stores through use of non-empty track copy procedure
US6282207B1 (en) 1999-03-30 2001-08-28 Diva Systems Corporation Method and apparatus for storing and accessing multiple constant bit rate data
JP2001285234A (ja) * 2000-04-04 2001-10-12 Sony Corp データ多重化装置およびデータ多重化方法、並びに記録媒体
US6745305B2 (en) * 2000-12-13 2004-06-01 Ncr Corporation Zeroed block optimization in disk mirroring applications

Cited By (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2008130080A (ja) * 2006-11-22 2008-06-05 Hitachi Ltd 動的チャンク割付けストレージシステムにおけるバックアップおよび復元のための方法および装置
US8904129B2 (en) 2006-11-22 2014-12-02 Hitachi, Ltd. Method and apparatus for backup and restore in a dynamic chunk allocation storage system
JP2008234355A (ja) * 2007-03-20 2008-10-02 Toshiba Corp ディスクコピー装置及びプログラム
JP2010541060A (ja) * 2007-10-01 2010-12-24 インターナショナル・ビジネス・マシーンズ・コーポレーション シン・プロビジョニングの移行および取り消しのための方法および装置
US8386744B2 (en) 2007-10-01 2013-02-26 International Business Machines Corporation Thin provisioning migration and scrubbing
JP2013073388A (ja) * 2011-09-27 2013-04-22 Fujitsu Ltd ストレージ装置、ストレージ装置の制御方法及びストレージシステム
US8793455B2 (en) 2011-09-27 2014-07-29 Fujitsu Limited Storage apparatus, control method for storage apparatus, and storage system
JP2020107243A (ja) * 2018-12-28 2020-07-09 キヤノン株式会社 情報処理装置及び情報処理装置の制御方法
JP7208000B2 (ja) 2018-12-28 2023-01-18 キヤノン株式会社 情報処理装置及び情報処理装置の制御方法

Also Published As

Publication number Publication date
US20040088505A1 (en) 2004-05-06
US7024526B2 (en) 2006-04-04

Similar Documents

Publication Publication Date Title
JP2004280779A (ja) ストレージシステムのリモートコピーに於いて空白データを省略する方法と装置
JP2004280779A5 (ja)
US7028216B2 (en) Disk array system and a method of avoiding failure of the disk array system
US6457109B1 (en) Method and apparatus for copying data from one storage system to another storage system
US7225294B2 (en) Storage system control method, storage system, information processing system, managing computer and program
JP4646526B2 (ja) 記憶制御システム及び同システムの制御方法
JP4897387B2 (ja) ストレージ装置およびこれを用いたデータの管理方法
US7930474B2 (en) Automated on-line capacity expansion method for storage device
US7426588B2 (en) Storage apparatus
EP1783595A2 (en) Information processing system, control method for information processing system, and storage system
US8433862B2 (en) Storage system for adjusting asynchronous copy load based on cache activity rate
US7257675B2 (en) Disk array device having snapshot simulation function
JP2005242555A (ja) 記憶制御システム及び記憶制御システムが有するディスク型記憶装置にファームウェアを搭載する方法
JP2002304258A (ja) 冗長バックアップ装置
JP2005202495A (ja) データ移行方法
US6105076A (en) Method, system, and program for performing data transfer operations on user data
JP2007265403A (ja) 階層型ストレージシステム間でのリモートミラー方式
JP2006004408A (ja) ディスクアレイシステムにおけるデータ保護の方法
JP2002278704A (ja) 処理最適化方法、コンピュータ、及び記憶装置
JP2008269050A (ja) 圧縮制御装置及び方法
JP4311532B2 (ja) 記憶システム及び同システムにおけるスナップショット管理方法
JP2011505033A (ja) ストレージ・コピー・サービス・システムを管理する装置および方法
JP2006031446A (ja) データ記憶装置、データ記憶方法およびデータ記憶プログラム
US20070226547A1 (en) Disk controller and controlling method of the same
US20030169527A1 (en) Magnetic tape apparatus, control method therefor, and magnetic tape apparatus control program

Legal Events

Date Code Title Description
RD01 Notification of change of attorney

Free format text: JAPANESE INTERMEDIATE CODE: A7421

Effective date: 20060421

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20060824

Free format text: JAPANESE INTERMEDIATE CODE: A821

Effective date: 20060824

A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20060824

RD02 Notification of acceptance of power of attorney

Free format text: JAPANESE INTERMEDIATE CODE: A7422

Effective date: 20060824

RD04 Notification of resignation of power of attorney

Free format text: JAPANESE INTERMEDIATE CODE: A7424

Effective date: 20071012

RD04 Notification of resignation of power of attorney

Free format text: JAPANESE INTERMEDIATE CODE: A7424

Effective date: 20090206

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20090709

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20090825

A02 Decision of refusal

Free format text: JAPANESE INTERMEDIATE CODE: A02

Effective date: 20100126