JP6346937B2 - データベースエンジンを備えたデータベースシステム及び別個の分散型ストレージサービス - Google Patents

データベースエンジンを備えたデータベースシステム及び別個の分散型ストレージサービス Download PDF

Info

Publication number
JP6346937B2
JP6346937B2 JP2016501278A JP2016501278A JP6346937B2 JP 6346937 B2 JP6346937 B2 JP 6346937B2 JP 2016501278 A JP2016501278 A JP 2016501278A JP 2016501278 A JP2016501278 A JP 2016501278A JP 6346937 B2 JP6346937 B2 JP 6346937B2
Authority
JP
Japan
Prior art keywords
database
data
record
page
node
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Active
Application number
JP2016501278A
Other languages
English (en)
Other versions
JP2016511486A (ja
Inventor
グプタ,アヌラグ・ウィンドラス
ファハン,ニール
マッケルヴィー,サミュエル・ジェームズ
バーチャル,ローリオン・ダレル
ニューコンビ,クリストファー・リチャード
マダヴァラプ,プラディープ・ジュニャーナ
トブラー,ベンジャミン
コリー,ジェームズ・マクレラン
Original Assignee
アマゾン・テクノロジーズ・インコーポレーテッド
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by アマゾン・テクノロジーズ・インコーポレーテッド filed Critical アマゾン・テクノロジーズ・インコーポレーテッド
Publication of JP2016511486A publication Critical patent/JP2016511486A/ja
Application granted granted Critical
Publication of JP6346937B2 publication Critical patent/JP6346937B2/ja
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • 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/14Error detection or correction of the data by redundancy in operation
    • G06F11/1402Saving, restoring, recovering or retrying
    • G06F11/1446Point-in-time backing up or restoration of persistent data
    • G06F11/1458Management of the backup or restore process
    • G06F11/1464Management of the backup or restore process for networked environments
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/20Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
    • G06F16/23Updating
    • G06F16/2365Ensuring data consistency and integrity
    • 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/14Error detection or correction of the data by redundancy in operation
    • G06F11/1402Saving, restoring, recovering or retrying
    • G06F11/1446Point-in-time backing up or restoration of persistent data
    • G06F11/1448Management of the data involved in backup or backup restore
    • G06F11/1451Management of the data involved in backup or backup restore by selection of backup contents
    • 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/14Error detection or correction of the data by redundancy in operation
    • G06F11/1402Saving, restoring, recovering or retrying
    • G06F11/1471Saving, restoring, recovering or retrying involving logging of persistent data for recovery
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/20Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
    • G06F16/22Indexing; Data structures therefor; Storage structures
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/20Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
    • G06F16/23Updating
    • 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/2094Redundant storage or storage space
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2201/00Indexing scheme relating to error detection, to error correction, and to monitoring
    • G06F2201/80Database-specific techniques

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Quality & Reliability (AREA)
  • Data Mining & Analysis (AREA)
  • Databases & Information Systems (AREA)
  • Computer Security & Cryptography (AREA)
  • Software Systems (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)

Description

ソフトウェアスタックの多様な構成要素の分散は、いくつかの場合、(例えば複製によって)フォルトトレランス、より高い耐久性、及び(例えば、より少ない大型の高価な構成要素よりむしろ、多くのより小型でより安価な構成要素を使用することにより)より安価な解決策を提供する(または支援する)ことができる。ただし、データベースは、従来、分散の影響を最も受けにくいソフトウェアスタックの構成要素の中にある。例えば、データベースが提供すると期待されているいわゆるACIDプロパティ(例えば、原子性、一貫性、独立性、及び永続性)を保証しつつもデータベースを分散することは困難であることがある。
大部分の既存のリレーショナルデータベースは分散化されていないが、いくつかの既存のデータベースは、2つの共通モデル、つまり「シェアードナッシング」モデル及び「シェアードディスク」モデルの内の1つを使用して(より大型のモノリシックシステムを単に利用することによって「スケールアップ」されることと対照的に)「スケールアウト」される。一般的に、「シェアードナッシング」モデルでは、受信されたクエリーは(それぞれがクエリーの構成要素を含む)データベースシャードに分解され、これらのシャードはクエリー処理のために異なる計算ノードに送られ、結果は、結果が返される前に収集され、統合される。一般的に「シェアードディスク」モデルでは、クラスタのあらゆる計算ノードは同じ基礎的データにアクセスできる。このモデルを利用するシステムでは、キャッシュコヒーレンシーを管理するために細心の注意を払う必要がある。これらのモデルの両方において、大型のモノリシックデータベースは(スタンドアロンデータベースインスタンスの機能性のすべてを含んだ)複数のノードで複製され、それらを縫い合わせるために「グルー」ロジックが追加される。例えば、「シェアードナッシング」モデルでは、グルーロジックは、クエリーを再分割し、クエリーを複数の計算ノードに送信し、次いで結果を結合するディスパッチャーの機能性を提供してよい。「シェアードディスク」モデルでは、グルーロジックが(例えば、キャッシング層でコヒーレンシーを管理するために)複数のノードのキャッシュをともに融合させるのに役立ってよい。これらの「シェアードナッシング」データベースシステム及び「シェアードディスク」データベースシステムは配備するのが高価であり、維持するのが複雑であり、多くのデータベース使用ケースにサービスを提供しすぎる(over−serve)ことがある。
従来のデータベースシステムでは、データベースシステムによって管理されるデータは、直接的にアタッチされたディスクに記憶される。ディスクが故障すると、ディスクは交換され、次いで適切なデータをリロードされる必要がある。例えば、多くのシステムでは、クラッシュ回復は、バックアップシステムからの最も最近のスナップショットを復元し、次いで前回のスナップショット以降、その点から先に行われるあらゆる変更をリプレイすることを含む。ただし、この手法は大型データベースまで十分にスケーリングしない。
実施形態は、いくつかの実施形態及び例示的な図面について一例として本明細書に説明されているが、当業者は実施形態が説明されている実施形態または図面に制限されないことを認識する。図面及び図面に対する詳細な説明は、開示されている特定の形式に実施形態を制限することを目的とするのではなく、逆に、添付の特許請求の範囲によって定められる精神及び範囲に入るすべての修正形態、同等物、及び変更形態を対象とすることを目的とすることが理解されるべきである。本明細書に使用される見出しは編成のためだけであり、明細書または特許請求項の範囲を制限するために使用されることを意図していない。本願を通して使用されるように、単語「してよい」は、強制の意味(つまり、しなければならないを意味する)よりむしろ、許可の意味(つまり、する可能性を有することを意味する)で使用される。同様に、単語「含む」、「含んだ」、及び「含む」は、含むが、これに限定されるものではないことを意味する。
一実施形態に係るデータベースソフトウェアスタックの多様な構成要素を示すブロック図である。 いくつかの実施形態に従って、ウェブサービスベースのデータベースサービスを実装するように構成されてよいサービスシステムアーキテクチャを示すブロック図である。 一実施形態に係る、データベースエンジン、及び別個の分散型データベースストレージサービスを含むデータベースシステムの多様な構成要素を示すブロック図である。 一実施形態に係る、分散型データベース最適化ストレージシステムを示すブロック図である。 データベースエンジン、及び別個の分散型データベースストレージサービスを含むデータベースシステムでデータにアクセスするための方法の一実施形態を示す流れ図である。 一実施形態に係る、データベースシステムでの別個の分散型データベース最適化ストレージシステムの使用を示すブロック図である。 データベースエンジンの視点から、データベースシステムで書込み動作を実行するための方法の一実施形態を示す流れ図である。 分散型データベース最適化ストレージシステムの視点から、データベースシステムで書込み動作を実行するための方法の一実施形態を示す流れ図である。 一実施形態に係る、分散型データベース最適化ストレージシステムの所与のノードにデータ及びメタデータがどのように記憶されてよいのかを示すブロック図である。 一実施形態に係る、データベースボリュームの例の構成を示すブロック図である。 データベースエンジンの視点から、データベースシステムで読取り動作を実行するための方法の一実施形態を示す流れ図である。 分散型データベース最適化ストレージシステムの視点から、データベースシステムで読取り動作を実行するための方法の一実施形態を示す流れ図である。 保護グループを含む分散型データベース最適化ストレージシステムで読取り動作及び書込み動作を実行するための方法の一実施形態を示す流れ図である。 多様な実施形態に従って、データベースエンジン、及び別個の分散型データベースストレージサービスを含むデータベースシステムの少なくとも一部を実装するように構成されるコンピュータシステムを示すブロック図である。
本明細書に説明されるシステムは、いくつかの実施形態では、クライアント(例えば、加入者)がクラウドコンピューティング環境でデータストレージシステムを操作できるようにするウェブサービスを実装してよい。いくつかの実施形態では、データストレージシステムは、高度にスケーラブル且つ拡張可能である企業クラスのデータベースシステムであってよい。いくつかの実施形態では、クエリーは複数の物理リソース全体で分散されるデータベースストレージに向けられてよく、データベースシステムは必要に応じてスケールアップ、またはスケールダウンされてよい。データベースシステムは、異なる実施形態で、多様なタイプ及び/または編成のデータベーススキーマと効果的に機能してよい。いくつかの実施形態では、クライアント/加入者は、例えばSQLインタフェースを介してデータベースシステムに対話的に等、いくつかの方法でクエリーを提出してよい。他の実施形態では、外部アプリケーション及びプログラムは、データベースシステムにオープンデータベースコネクティビティ(ODBC)ドライバインタフェース及び/またはJava(登録商標)データベースコネクティビティ(JDBC)ドライバインタフェースを使用してクエリーを提出してよい。
すなわち、本明細書に説明されるシステムは、いくつかの実施形態では、単一のデータベースシステムの多様な機能構成要素が本質的に分散されるサービス指向型データベースアーキテクチャを実装してよい。これらのシステムは、例えば、(それぞれが、アプリケーションサーバ、サーチ機能性、またはデータベースのコア機能を提供するために必要とされる機能性を超える他の機能性等の外来の機能性を含んでよい)複数の完全でモノリシックなデータベースインスタンスを束ねるよりむしろ、データベースの基本的な動作(例えば、クエリー処理、トランザクション管理、キャッシング、及び記憶)を、個々に且つ無関係にスケーラブルであってよい階層に編成してよい。例えば、いくつかの実施形態では、本明細書に説明されるシステムの各データベースインスタンスは、(単一のデータベースエンジンヘッドノード及びクライアント側ストレージシステムドライバを含んでよい)データベース階層、及び(既存のシステムのデータベース階層で従来実行される動作のいくつかを集合的に実行する複数のストレージノードを含んでよい)別個の分散されたストレージシステムを含んでよい。
本明細書により詳細に説明されるように、いくつかの実施形態では、データベースの最低レベルの動作(例えば、バックアップ動作、復元動作、スナップショット動作、回復動作、及び/または多様なスペース管理動作)のいくつかは、データベースエンジンからストレージ層にオフロードされ、複数のノード及びストレージデバイス全体で分散されてよい。例えば、いくつかの実施形態では、データベースエンジンがデータベーステーブル(またはデータベーステーブルのデータページ)に変更を適用し、次いで修正されたデータページをストレージ層に送信するよりむしろ、記憶されているデータベーステーブル(及びデータベーステーブルのデータページ)に対する変更の適用は、ストレージ層自体の責任であってよい。係る実施形態では、修正されたデータページよりむしろ、リドゥログレコードがストレージ層に送信されてよく、その後リドゥ処理(例えば、リドゥログレコードの適用)はいくぶんゆったりと且つ(例えば、バックグラウンドプロセスによって等)分散された方法で実行されてよい。いくつかの実施形態では、クラッシュ回復(例えば、記憶されているリドゥログレコードからのデータページの再構築)は、ストレージ層によって実行されてもよく、分散された(及び、いくつかの場合、ゆったりとした)バックグラウンドプロセスによって実行されてもよい。
いくつかの実施形態では、リドゥログだけ(及び修正されたデータページではない)がストレージ層に送信されるため、データベース階層とストレージ層との間にあるネットワークトラフィックは、既存のデータベースシステムにおいてよりもはるかに少なくてよい。いくつかの実施形態では、各リドゥログは、各リドゥログが変更を指定する対応するデータページのサイズのほぼ10分の1であってよい。データベース階層及び分散型ストレージシステムから送信される要求が非同期であってよいこと、及び複数の係る要求が一度に送信中であってよいことに留意されたい。
上述されたように、典型的な大型データベースシステムでは、データベースシステムがシステムの故障に続いて再起動できる前に、データセット全体が復元される必要がある。これらのデータベースシステムでは、クラッシュに続いて、システムは、データページのすべてがディスク(例えば、チェックポイント)にフラッシュされたことがわかった最後の点を決定しなければならず、その点から先へのあらゆる変更ログをリプレイしなければならない。例えば、クライアントプロセスからの入信クエリーを処理するためにデータベースを使用できるようになる前に、システムプロセスは、決定されたチェックポイントの後に変更されたデータページのすべてを読み込み、それらのデータページにすでに適用されていない適用可能な変更ログレコードのそれぞれを適用しなければならない。
いくつかの実施形態では、本明細書に説明されるデータベースシステムは、回復されるデータセット全体を待機する必要なく、データベースクラッシュ後にほぼ即時に(例えば、クエリーを受け入れ、サービスを提供するためにデータベースを利用できるようにするために)故障に続いてデータベースエンジンを再起動できてよい。代わりに、クエリーは、クラッシュ回復が1つまたは複数のバックグラウンドスレッドによってゆったりと実行される間に、受信され、サービスを受けることができる。例えば、クラッシュに続いて、複数のバックグラウンドスレッドが異なるストレージノード上で並列で動作して、対応するリドゥログからデータページを再構築してよい。その一方で、入信クエリーがまだ再構築されていないデータページをターゲットとしている場合、ストレージ層は適切なリドゥログからオンザフライでそのデータページを作成し直すように構成されてよい。
一般的に、1個のデータを与えられた後、データベースの主要な要件は、最終的のその1個のデータを返すことができることである。これを行うために、データベースはそれぞれが異なる機能を実行するいくつかの異なる構成要素(または階層)含んでよい。例えば、従来のデータベースは3つの階層、つまりクエリーパーシング、最適化、及び実行を実行するための第1の階層、トランザクション性(transactionality)、回復、及び耐久性を提供するための第2の階層、及びローカルでアタッチされたディスクでまたはネットワークでアタッチされたストレージのどちらかでストレージを提供する第3の階層を有すると見なされてよい。上述されたように、従来のデータベースをスケーリングしようとする以前の試みは、通常、データベースの3つすべての階層を複製し、それらの複製されたデータベースインスタンスを複数のマシン全体で分散することを伴っていた。
いくつかの実施形態では、本明細書に説明されるシステムは、従来のデータベースにおいてとは異なってデータベースシステムの機能性を仕切ってよく、スケーリングを実装するために複数のマシン全体で(完全なデータベースインスタンスよりもむしろ)機能構成要素のサブセットだけを分散してよい。例えば、いくつかの実施形態では、クライアントが面する階層は、どのデータが記憶されるべきなのか、または取り出されるべきなのかを指定するが、どのようにしてデータを記憶するのか、または取り出すのかは指定しない要求を受信するように構成されてよい。この階層は、要求のパーシング及び/または最適化(例えば、SQLのパーシング及び要求)を実行してよい。一方、別の階層が、クエリーの実行に責任を負ってよい。いくつかの実施形態では、第3の階層が結果のトランザクション性及び一貫性を提供することに責任を負ってよい。例えば、この階層は、いわゆるACIDプロパティのいくらか、特にデータベースをターゲットとするトランザクションの原子性を強化するよう構成されてよく、データベースの中で一貫性を維持し、データベースをターゲットとするトランザクション間で独立性を保証する。いくつかの実施形態では、第4の階層が次いで多様な種類の障害が存在する場合に記憶されているデータの耐久性を提供することに責任を負ってよい。例えば、この階層は、ロギングの変更、データベースクラッシュからの回復、基礎的な記憶ボリュームに対するアクセスの管理、及び/または基礎的な記憶ボリュームにおけるスペース管理に責任を負ってよい。
図1は、一実施形態に係る、データベースソフトウェアスタックの多様な構成要素を示すブロック図である。この例に示されるように、データベースインスタンスは、それぞれがデータベースインスタンスの機能性の一部を提供する、複数の機能構成要素(または層)を含んでよい。この例では、データベースインスタンス100は、(110として示される)クエリーパーシング及びクエリー最適化層、(120として示される)クエリー実行層、(130として示される)トランザクション性及び一貫性管理層、並びに(140として示される)耐久性及びスペース管理層を含む。上述されたように、いくつかの既存のデータベースシステムでは、データベースインスタンスのスケーリングは、(図1に示される層のすべてを含んだ)データベースインスタンス全体を1回または複数回複製して、次いで層を互いに縫い合わせるためにグルーロジックを追加することを含んでよい。いくつかの実施形態では、本明細書に説明されるシステムは、代わりにデータベース階層から別個のストレージ層に耐久性及びスペース管理層140の機能性をオフロードしてよく、その機能性をストレージ層の複数のストレージノード全体で分散してよい。
いくつかの実施形態では、本明細書に説明されるデータベースシステムは、図1に示されるデータベースインスタンスの上半分の構造の多くを保持してよいが、バックアップ動作、復元動作、スナップショット動作、回復動作、及び/または多様なスペース管理動作の少なくとも部分に対する責任を記憶階層に再配分してよい。このようにして機能性を再配分し、データベース階層と記憶階層との間でログ処理をしっかりと結合することは、スケーラブルデータベースを提供する以前の手法と比較されるときに性能を改善し、可用性を高め、コストを削減してよい。例えば、(実際のデータページよりもサイズがはるかに小さい)リドゥログレコードだけがノード全体で送り出される、または書込み動作のレーテンシパスの中で持続してよいので、ネットワーク及び入出力帯域幅の要件が削減されてよい。さらに、データページの生成は、入信書込み動作を遮ることなく、(フォアグラウンド処理が許すので)各ストレージノードでバックグラウンドで独立して実行できる。いくつかの実施形態では、ログ構造化された非上書きストレージの使用が、例えばデータページの移動またはコピーよりむしろメタデータ操作だけを使用することによって、バックアップ動作、復元動作、スナップショット動作、ポイントインタイムリカバリ動作、及びボリューム増大動作をより効率的に実行できるようにしてよい。いくつかの実施形態では、ストレージ層は、複数のストレージノード全体でクライアントの代わりに記憶されたデータの複製(及び/またはリドゥログレコード等の、そのデータと関連付けられたメタデータ)に対する責任を負ってもよい。例えば、データ(及び/またはメタデータ)は、(例えば、ストレージノードの集合体が独自の物理的に別個の独立したインフラストラクチャで実行する単一の「可用性ゾーン」の中で等)ローカルに、及び/または単一の領域のもしくは異なる領域の可用性ゾーン全体で複製されてよい。
多様な実施形態では、本明細書に説明されるデータベースシステムは、さまざまなデータベース動作のために標準的なまたはカスタムのアプリケーションプログラミングインタフェース(API)をサポートしてよい。例えば、APIは、データベースの作成、テーブルの作成、テーブルの改変、ユーザーの作成、ユーザーの削除、テーブルでの1行または複数行の挿入、値のコピー、テーブルの中からのデータの選択(例えば、テーブルの問合せ)、クエリーの取消しまたはアボートのための動作、及び/または他の動作をサポートしてよい。
いくつかの実施形態では、データベースインスタンスのデータベース階層は、多様なクライアントプログラム(例えば、アプリケーション)及び/または加入者(ユーザー)からの読取り要求及び/または書込み要求を受信し、次いで要求をパースし、関連付けられたデータベース動作(複数の場合がある)実施するための実行計画を作成するデータベースエンジンヘッドノードサーバを含んでよい。例えば、データベースエンジンヘッドノードは、複雑なクエリー及び接合の結果を得るために必要な一連のステップを作成してよい。いくつかの実施形態では、データベースエンジンヘッドノードは、データベース階層と別個の分散型データベース最適化ストレージシステムとの間の通信だけではなく、データベースシステムのデータベース階層とクライアント/加入者との間の通信も管理してよい。
いくつかの実施形態では、データベースエンジンヘッドノードは、JDBCインタフェースまたはODBCインタフェースを通してエンドクライアントからSQL要求を受信すること、及びローカルでSQL処理及び(ロッキングを含んでよい)トランザクション管理を実行することに責任を負ってよい。ただし、データベースエンジンヘッドノード(またはデータベースエンジンヘッドノードの多様な構成要素)は、データページをローカルで生成するよりむしろ、リドゥログレコードを生成してよく、リドゥログレコードを別個の分散型ストレージシステムの適切なノードに送り出してよい。いくつかの実施形態では、分散型ストレージシステムのためのクライアント側ドライバは、データベースエンジンヘッドノードでホストされてよく、それらのリドゥログレコードが向けられるセグメント(またはセグメントのデータページ)を記憶する1つのストレージシステムノード(または複数のストレージシステムノード)にリドゥログレコードを送ることに責任を負ってよい。例えば、いくつかの実施形態では、各セグメントは保護グループを形成する複数のストレージシステムノードでミラーリングされてよい(またはそれ以外の場合、耐久的にされてよい)。係る実施形態では、クライアント側ドライバは、各セグメントが記憶されるノードを追跡調査してよく、クライアント要求が受信されるときに(例えば非同期で、及び実質的にほぼ同時に並列で)セグメントが記憶されるノードのすべてにリドゥログを送ってよい。クライアント側ドライバが(リドゥログレコードがストレージノードに書き込まれていることを示すことがある)保護グループのストレージノードの書込み選抜グループ(quorum)から肯定応答を受信するとすぐに、クライアント側ドライバはデータベース階層に(例えば、データベースエンジンヘッドノードに)要求された変更の肯定応答を送信してよい。例えば、データが保護グループを使用することによって耐久的にされる実施形態では、データベースエンジンヘッドノードは、クライアント側ドライバが書込み選抜グループを構成するために十分なストレージノードインスタンスから回答を受信するまで及び受信しない限り、トランザクションをコミットできないことがある。同様に、特定のセグメントに向けられる読取り要求の場合、クライアント側ドライバは、(例えば非同期で、及び実質的に同時に並列で)セグメントが記憶されるノードのすべてに読取り要求を送ってよい。クライアント側ドライバは保護グループのストレージノードの読取り選抜グループから要求されたデータを受信するとすぐに、クライアント側ドライバはデータベース階層に(例えば、データベースエンジンヘッドノードに)要求されたデータを返してよい。
いくつかの実施形態では、データベース階層(またはより詳細には、データベースエンジンヘッドノード)は、最近アクセスされたデータページが一時的に保持されるキャッシュを含んでよい。係る実施形態では、係るキャッシュに保持されるデータページをターゲットとする書込み要求が受信されると、対応するリドゥログレコードをストレージ層に送り出すことに加えて、データベースエンジンはそのキャッシュに保持されているデータページのコピーに変更を適用してよい。ただし、他のデータベースシステムにおいてとは異なり、このキャッシュに保持されるデータページはストレージ層にフラッシュされることはなく、該データページはいつでも(例えば、キャッシュに入れられたコピーに最も最近に適用された書込み要求のリドゥログレコードがストレージ層に送信され、肯定応答された後のいつでも)廃棄されてよい。キャッシュは、異なる実施形態で、一度に多くても一人の書込み者(または複数の読取り者)によるキャッシュへのアクセスを制御するための多様なロッキング機構のいずれかを実装してよい。ただし、係るキャッシュを含む実施形態では、キャッシュは複数のノード全体で分散れるのではなく、所与のデータベースインスタンスのためにデータベースエンジンヘッドノードだけに存在してよいことに留意されたい。したがって、管理するキャッシュコヒーレンシーまたは一貫性問題がないことがある。
いくつかの実施形態では、データベース階層は、例えば、読取り要求を送ることができるデータベース階層の異なるノードでのデータの読取り専用コピー等、システムでの同期または非同期の読取りレプリカの使用をサポートしてよい。係る実施形態では、所与のデータベーステーブルのデータベースエンジンヘッドノードが特定のデータページに向けられる読取り要求を受信すると、データベースエンジンヘッドノードはこれらの読取り専用コピーの内のいずれか1つ(または特定の1つ)に要求を送ってよい。いくつかの実施形態では、データベースエンジンヘッドノードのクライアント側ドライバは、(例えば、これらの他のノードにそのキャッシュを無効にするように促すために)キャッシュに入れられたデータページに対する更新及び/または失効についてこれらの他のノードに通知するように構成されてよい(その後これらの他のノードはストレージ層から更新されたデータページの更新済みのコピーを要求してよい)。
いくつかの実施形態では、データベースエンジンヘッドノードで実行中のクライアント側ドライバは、記憶階層にプライベートインタフェースを曝露してよい。いくつかの実施形態では、クライアント側ドライバは従来のiSCSIインタフェースを1つまたは複数の他の構成要素(例えば、他のデータベースエンジンまたは仮想コンピューティングサービス構成要素)に曝露してもよい。いくつかの実施形態では、記憶階層でのデータベースインスタンスのためのストレージは、制限なくサイズを増大することがあり、それと関連付けられた、制限されない数のIOPSを有することがある単一のボリュームとしてモデル化されてよい。ボリュームが作成されるとき、ボリュームは特定のサイズで、(例えば、ボリュームがどのように複製されるのかを指定する)特定の可用性/耐久性特徴で、及び/またはボリュームと関連付けられたIOPSレートで(例えば、ピークと持続の両方)作成されてよい。例えば、いくつかの実施形態では、さまざまな異なる耐久性モデルがサポートされてよく、ユーザー/加入者は自らのデータベーステーブルのために、複製コピー、ゾーン、もしくは領域の数、及び/またはその耐久性、性能、及びコストの目的に基づいて複製が同期であるのか、それとも非同期であるのかを指定できてよい。
いくつかの実施形態では、クライアント側ドライバはボリュームについてのメタデータを維持してよく、ストレージノード間で追加のホップを必要とすることなく、読取り要求及び書込み要求を実行するために必要なストレージノードのそれぞれに非同期要求を直接的に送信してよい。例えば、いくつかの実施形態で、データベーステーブルに対する変更を行う要求に応えて、クライアント側ドライバは、ターゲットとされたデータページのストレージを実装している1つまたは複数のノードを決定し、それらのストレージノードに対するその変更を指定するリドゥログレコード(複数の場合がある)を送るように構成されてよい。ストレージノードは、次いで、リドゥログレコードに指定される変更を将来のある時点でターゲットとされたデータページに適用することに責任を負ってよい。書込みはクライアント側ドライバに肯定応答されるので、クライアント側ドライバは、ボリュームが耐久的となる点を先に進めてよく、データベース階層に対してコミットを肯定応答してよい。上述されたように、いくつかの実施形態では、クライアント側ドライバはストレージノードサーバにデータページを絶対に送信しないことがある。これは、ネットワークトラフィックを削減するだけではなく、チェックポイントまたは以前のデータベースシステムでのフォアグラウンド処理スループットを制約するバックグラウンド書込み者スレッドの必要性を削除してもよい。
いくつかの実施形態では、多くの読取り要求がデータベースエンジンヘッドノードキャッシュによって提供されてよい。ただし、大規模故障イベントは一般的すぎて、メモリ内複製だけを許可できないので、書込み要求は耐久性を必要としてよい。したがって、本明細書に説明されるシステムは、記憶階層内のデータストレージを2つの領域、つまりリドゥログレコードがデータベース階層から受信されるときにリドゥログレコードが書き込まれる小さなアペンド専用ログ構造化領域、及びバックグラウンドでデータページの新しいバージョンを作成するために、ログレコードがともに合体するより大きな領域として実装することによって、フォアグラウンドレーテンシパス内にあるリドゥログレコード書込み動作のコストを最小限に抑えるように構成されてよい。いくつかの実施形態では、メモリ内構造は、インスタンス化されたデータブロックが参照されるまで連鎖ログレコード後方へ、データページの前回のリドゥログレコードを指すデータページごとに維持される。この手法は、読取りがおもにキャッシュに入れられるアプリケーション内を含んで、混合した読取り‐書込みワークロードに優れた性能を提供してよい。
いくつかの実施形態では、リドゥログレコードのためのログ構造化データストレージへのアクセスは、(ランダム入出力動作よりむしろ)一連の順次入出力動作から構成されてよいため、行われている変更は互いに密接にパックされてよい。データページに変更するたびに、永続データストレージに対する2つの入出力動作(リドゥログのための動作及び修正されたデータページ自体のための動作)が生じる既存のシステムとは対照的に、いくつかの実施形態では、本明細書に説明されるシステムはリドゥログレコードの受信に基づいて分散型ストレージシステムのストレージノードでデータページを合体させることによってこの「書込み増幅」を回避してよい。
上述されたように、いくつかの実施形態では、データベースシステムの記憶階層はデータベーススナップショットを撮ることに責任を負ってよい。ただし、記憶階層はログ構造化ストレージを実装するため、データページ(例えば、データブロック)のスナップショットを撮ることはデータページ/ブロックに最も最近適用されたリドゥログレコードと関連付けられたタイムスタンプ(またはデータページ/ブロックの新しいバージョンを作成するために複数のリドゥログレコードを合体させるための最も最近の動作と関連付けられたタイムスタンプ)を記録すること、及びページ/ブロックの以前のバージョン及び時間内に記録された点までのあらゆる以後のログエントリのガベージコレクションを妨げることを含んでよい。例えば、データベーススナップショットを撮ることは、オフボリュームバックアップ戦略を利用するときに必要とされるだろう、データブロックの読取り、コピー、または書込みを必要としないことがある。いくつかの実施形態では、ユーザー/加入者はアクティブデータセットに加えてオンボリュームスナップショットのためにどれほど多くの追加スペースを保つことを希望するのかを選ぶことができることがあるが、修正されたデータだけが追加のスペースを必要とするので、スナップショットのスペース要件は最小であってよい。異なる実施形態では、スナップショットは、不連続(例えば、各スナップショットは時間の特定の時点でのデータページ内のデータのすべてに対するアクセスを提供してよい)または連続(例えば、各スナップショットは2つの時点の間のデータページに存在するデータのすべてのバージョンに対するアクセスを提供してよい)であってよい。いくつかの実施形態では、以前のスナップショットに戻ることは、そのスナップショット以降のすべてのリドゥログレコード及びデータページが無効であり、ガベージコレクション可能であることを示すためにログレコードを記録すること、及びスナップショット点後のすべてのデータベースキャッシュエントリを廃棄することを含んでよい。係る実施形態では、ストレージシステムは、ストレージシステムが通常の順方向読取り/書込み処理で行うのと同様に、要求されるように、及びすべてのノード全体でバックグラウンドで、ブロック単位でリドゥログレコードをデータブロックに適用するので、前進復帰は必要とされないことがある。クラッシュ回復は、それによってノード全体で並列且つ分散型にされてよい。
ウェブサービスベースのデータベースサービスを実装するように構成されてよいサービスシステムアーキテクチャの一実施形態が図2に示される。示されている実施形態では、(データベースクライアント250aから250nとして示される)多くのクライアントがネットワーク260を介してウェブサービスプラットホーム200と対話するように構成されてよい。ウェブサービスプラットホーム200は、データベースサービス210、分散型データベース最適化ストレージサービス220、及び/または1つまたは複数の他の仮想コンピューティングサービス230の1つまたは複数のインスタンスとインタフェースをとるように構成されてよい。所与の構成要素の1つまたは複数が存在してよい場合、本明細書でのその構成要素に対する参照は単数形または複数形のどちらかで行われてよいことが留意される。ただしどちらの形の使用も他方を排除することを目的としていない。
多様な実施形態では、図2に示される構成要素は、コンピュータハードウェア(例えば、マイクロプロセッサもしくはコンピュータシステム)によって直接的にまたは間接的に実行可能な命令として、またはこれらの技法の組合せを使用してコンピュータハードウェアの中で直接的に実装されてよい。例えば、図2の構成要素はそれぞれが図14に示され、以下に説明されるコンピュータシステム実施形態に類似してよい、いくつかのコンピューティングノード(つまり、単にノード)を含むシステムによって実装されてよい。多様な実装形態では、所与のサービスシステム構成要素(例えば、データベースサービスの構成要素またはストレージサービスの構成要素)の機能性は、特定のノードによって実装されてよい、またはいくつかのノード全体で分散されてよい。いくつかの実施形態では、所与のノードは複数のサービスシステム構成要素(例えば、複数のデータベースサービスシステム構成要素)の機能性を実装してよい。
一般的に言えば、クライアント250は、データベースサービスに対する要求を含むウェブサービス要求を、ネットワーク260を介してウェブサービスプラットホーム200に提出するように構成可能な任意のタイプのクライアントを包含してよい。例えば、所与のクライアント250は、ウェブブラウザの適切なバージョンを含んでよい、またはウェブブラウザによって提供される実行環境に対する拡張部として、またはウェブブラウザによって提供される実行環境の中で実行するように構成されるプラグインモジュールまたは他のタイプのコードモジュールを含んでよい。代わりに、クライアント250(例えば、データベースサービスクライアント)は、データベースアプリケーション(もしくはデータベースアプリケーションのユーザーインタフェース)、メディアアプリケーション、オフィスアプリケーション、または1つまたは複数のデータベーステーブルを記憶する、及び/または1つまたは複数のデータベーステーブルにアクセスするために永続記憶装置リソースを利用してよい任意の他のアプリケーション等のアプリケーションを包含してよい。いくつかの実施形態では、係るアプリケーションは、必ずしもすべてのタイプのウェブベースのデータに対する完全なブラウザサポートを実装しなくてもウェブサービス要求を生成し、処理するための(例えば、ハイパテキスト転送プロトコル(HTTP)の適切なバージョンのための)十分なプロトコルサポートを含んでよい。すなわち、クライアント250は、ウェブサービスプラットホーム200と直接的に対話するように構成されるアプリケーションであってよい。いくつかの実施形態では、クライアント250は、表象状態転送(Representational State Transfer)(REST)様式ウェブサービスアーキテクチャ、ドキュメントベースもしくはメッセージベースのウェブサービスアーキテクチャ、または別の適切なウェブサービスアーキテクチャに従ってウェブサービス要求を生成するよう構成されてよい。
いくつかの実施形態では、クライアント250(例えば、データベースサービスクライアント)は、データベーステーブルのウェブサービスベースのストレージへのアクセスを、他のアプリケーションに、それらのアプリケーションにはトランスペアレントな方法で提供するように構成されてよい。例えば、クライアント250は、オペレーティングシステムまたはファイルシステムと統合して、本明細書に説明されるストレージモデルの適切な変形に従ってストレージを提供するように構成されてよい。ただし、オペレーティングシステムまたはファイルシステムは、ファイル、ディレクトリ、及び/またはフォルダの従来のファイルシステム階層等の、アプリケーションに異なるストレージインタフェースを提示してよい。係る実施形態では、アプリケーションは図1のストレージシステムサービスモデルを利用するために修正される必要はないことがある。代わりに、ウェブサービスプラットホーム200へのインタフェースをとることの詳細は、オペレーティングシステム環境の中で実行するアプリケーションの代わりに、クライアント250及びオペレーティングシステムまたはファイルシステムによって調整されてよい。
クライアント250は、ネットワーク260を介してウェブサービスプラットホーム200にウェブサービス要求を伝達し、ウェブサービスプラットホーム200から応答を受信してよい。多様な実施形態では、ネットワーク260は、クライアント250とプラットホーム200との間でウェブベースの通信を確立するために必要なネットワーキングハードウェア及びプロトコルの任意の適切な組合せを包含してよい。例えば、ネットワーク260は、集合的にインターネットを実装する多様な電気通信ネットワーク及びサービスプロバイダを概して包含してよい。また、ネットワーク260は、公衆無線ネットワークまたは構内無線ネットワークだけではなく、ローカルエリアネットワーク(LAN)または広域ネットワーク(WAN)等の構内ネットワークも含んでよい。例えば、所与のクライアント250とウェブサービスプラットホーム200の両方とも、独自の内部ネットワークを有する企業の中でそれぞれプロビジョニングされてよい。係る実施形態では、ネットワーク260は、インターネットとウェブサービスプラットホーム200との間だけではなく、所与のクライアント250とインターネットとの間にネットワーキングリンクを確立するために必要なハードウェア(例えば、モデム、ルータ、開閉器、ロードバランサ、プロキシサーバ等)及びソフトウェア(例えば、プロトコルスタック、財務会計ソフト、ファイアウォール/セキュリティソフトウェア等)を含んでよい。いくつかの実施形態では、クライアント250は、公衆インターネットよりむしろ構内ネットワークを使用してウェブサービスプラットホーム200と通信してよい。例えば、クライアント250は、データベースサービスシステム(例えば、データベースサービス210及び/または分散型データベース最適化ストレージサービス220を実装するシステム)と同じ企業の中でプロビジョニングされてよい。係る場合、クライアント250は、構内ネットワーク260(例えば、インターネットベースの通信プロトコルを使用してよいが、公にアクセス可能ではないLANまたはWAN)を通して完全にプラットホーム200と通信してよい。
一般的に言えば、ウェブサービスプラットホーム200は、データページ(またはデータページのレコード)にアクセスする要求等のウェブサービス要求を受信し、処理するように構成される1つまたは複数のサービスエンドポイントを実装するように構成されてよい。例えば、ウェブサービスプラットホーム200は、特定のエンドポイントを実装するように構成されるハードウェア及び/またはソフトウェアを含んでよく、したがってそのエンドポイントに向けられたHTTPベースのウェブサービス要求は適切に受信され、処理される。一実施形態では、ウェブサービスプラットホーム200は、クライアント250からウェブサービス要求を受信し、ウェブサービス要求を、処理のためにデータベースサービス210、分散型データベース最適化ストレージサービス220、及び/または別の仮想コンピューティングサービス230を実装するシステムの構成要素に転送するように構成されるサーバシステムとして実装されてよい。他の実施形態では、ウェブサービスプラットホーム200は、大規模なウェブサービス要求処理ロードを動的に管理するように構成されるロードバランス機能及び他の要求管理機能を実装する(例えば、クラスタトポロジの)いくつかの別個のシステムとして構成されてよい。多様な実施形態では、ウェブサービスプラットホーム200は、REST様式またはドキュメントベースの(例えば、SOAPベースの)タイプのウェブサービス要求をサポートするように構成されてよい。
いくつかの実施形態では、ウェブサービスプラットホーム200は、クライアントのウェブサービス要求に対するアドレス可能なエンドポイントとして機能することに加えて、多様なクライアント管理機能を実装してよい。例えば、プラットホーム200は、例えば要求側クライアント250のアイデンティティ、クライアント要求の数及び/または頻度、クライアント250の代わりに記憶されているまたは取り出されるデータテーブル(またはデータテーブルのレコード)のサイズ、クライアント250によって使用される全体的な記憶帯域幅、クライアント250によって要求されるストレージのクラス、または任意の他の測定可能なクライアント使用パラメータを追跡調査することによって、ストレージリソースを含むウェブサービスのクライアント使用の計量及びアカウンティングを調整してよい。プラットホーム200は、財務会計システム及び請求書作成システムを実装してもよい、またはクライアント使用活動の報告及び請求書作成のために外部システムによって照会され、処理されてよい使用データのデータベースを維持してもよい。特定の実施形態では、プラットホーム200は、クライアント250から受け取られる要求の割合及びタイプ、係る要求によって活用される帯域幅、係る要求のためのシステム処理レーテンシ、システム構成要素活用(例えば、ストレージサービスシステムの中のネットワーク帯域幅及び/またはストレージ活用)、要求から生じるエラーの割合及びタイプ、記憶され、要求されるデータページもしくはそのレコードの特徴(例えば、サイズ、データタイプ等)を反映する測定基準、または任意の他の適切な測定基準等、さまざまなストレージサービスシステム操作測定基準を収集する、監視する、及び/または統合するよう構成されてよい。いくつかの実施形態では、係る測定基準はシステム構成要素を調整し、維持するためにシステム管理者によって使用されてよい。一方、他の実施形態では、係る測定基準(または係る測定基準の関連性のある部分)は、係るクライアントがデータベースサービス210、分散型データベース最適化ストレージサービス220、及び/または別の仮想コンピューティングサービス230(またはそれらのサービスを実装する基礎的なシステム)の使用を監視できるようにするためにクライアント250に曝露されてよい。
いくつかの実施形態では、プラットホーム200は、ユーザー認証手順及びアクセス制御手順も実装してよい。例えば、特定のデータベーステーブルにアクセスする所与のウェブサービス要求の場合、プラットホーム200は、要求と関連付けられるクライアント250が特定のデータベーステーブルにアクセスする権限を与えられているかどうかを確かめるように構成されてよい。プラットホーム200は、例えばアイデンティティ、パスワード、もしくは他の信用証明書を特定のデータベーステーブルと関連付けられた信用証明書に対して評価する、または特定のデータベーステーブルに対する要求されたアクセスを、特定のデータベーステーブルに対するアクセス制御リストに対して評価することによって係る権限付与を決定してよい。例えば、クライアント250が特定のデータベーステーブルにアクセスするほど十分な信用証明書を有していない場合、プラットホーム200は、例えばエラー状態を示す応答を要求側クライアント250に返すことによって対応するウェブサービス要求を拒絶してよい。多様なアクセス制御方針は、データベースサービス210、分散型データベース最適化ストレージサービス220、及び/または他の仮想コンピューティングサービス230によってアクセス制御情報のレコードまたはリストとして記憶されてよい。
ウェブサービスプラットホーム200が、クライアント250がデータベースサービス210を実装するデータベースシステムの特徴にそれを通してアクセスしてよい一次インタフェースを表してよいが、ウェブサービスプラットホーム200が係る特徴に対する単独のインタフェースを表す必要がないことが留意される。例えば、ウェブサービスインタフェースとは別個であってよい代替のAPIは、データベースシステムを提供する企業にとって内部のクライアントがウェブサービスプラットホーム200を迂回できるようにするために使用されてよい。本明細書に説明される例の多くで、分散型データベース最適化ストレージサービス220が、クライアント250にデータベースサービスを提供するコンピューティングシステムまたは企業システムにとって内部であってよく、外部クライアント(例えば、ユーザーまたはクライアントアプリケーション)に曝露されないことがあることに留意されたい。係る実施形態では、内部「クライアント」(例えば、データベースサービス210)は、(例えば、これらのサービスを実装するシステムの間で直接的にAPIを通して)分散型データベース最適化ストレージサービス220とデータベースサービス210との間の実線として示されるローカルネットワークまたは構内ネットワーク上で分散型データベース最適化ストレージサービス220にアクセスしてよい。係る実施形態では、クライアント250の代わりにデータベーステーブルを記憶する上での分散型データベース最適化ストレージサービス220の使用はそれらのクライアントにとってトランスペアレントであってよい。他の実施形態では、分散型データベース最適化ストレージサービス220は、データベース管理のためにデータベースサービス210に依存するアプリケーション以外のアプリケーションに、データベーステーブルまたは他の情報のストレージを提供するために、ウェブサービスプラットホーム200を通してクライアント250に曝露されてよい。これは、ウェブサービスプラットホーム200と分散型データベース最適化ストレージサービス220の間の破線によって図2に示される。係る実施形態では、分散型データベース最適化ストレージサービス220のクライアントは、ネットワーク260を介して(例えば、インターネット上で)分散型データベース最適化ストレージサービス220にアクセスしてよい。いくつかの実施形態では、仮想コンピューティングサービス230は、クライアント250の代わりにコンピューティングサービス230を実行する上で使用されるオブジェクトを記憶するために(例えば、仮想コンピューティングサービス230と分散型データベース最適化ストレージサービス220との間で直接的にAPIを通して)分散型データベース最適化ストレージサービス220からストレージサービスを受信するように構成されてよい。これは、仮想コンピューティングサービス230と分散型データベース最適化ストレージサービス220との間の破線によって図2に示される。いくつかのケースでは、プラットホーム200のアカウンティングサービス及び/または信用証明書発行(credentialing)サービスは、管理クライアント等の内部クライアントにとって、または同じ企業の中のサービス構成要素間では不必要となってよい。
多様な実施形態では、異なる記憶方針が、データベースサービス210及び/または分散型データベース最適化ストレージサービス220によって実装されてよいことに留意されたい。係る記憶方針の例は、耐久性方針(例えば、記憶されるデータベーステーブル(またはデータベーステーブルのデータページ)のインスタンスの数、及びデータベーステーブルが記憶される異なるノードの数を示す方針)、及び/または(要求トラフィックを一様にしようとしてデータベーステーブルまたはデータベーステーブルのデータページを、異なるノード、ボリューム、及び/またはディスク全体で分散してよい)ロードバランシング方針を含んでよい。さらに、異なる記憶方針は、サービスの多様な1つによって異なるタイプの記憶された項目に適用されてよい。例えば、いくつかの実施形態では、分散型データベース最適化ストレージサービス220は、データページに対するよりもリドゥログレコードに対してより高い耐久性を実装してよい。
図3は、一実施形態に従って、データベースエンジン、及び別個の分散型データベースストレージサービスを含むデータベースシステムの多様な構成要素を示すブロック図である。この例では、データベースシステム300は、いくつかのデータベーステーブルのそれぞれのためのそれぞれのデータベースエンジンヘッドノード320、及び(データベースクライアント350aから350nとして示されるデータベースシステムのクライアントにとって可視であってよい、または可視でないことがある)分散型データベース最適化ストレージサービス310を含む。この例で示されるように、データベースクライアント350aから350nの内の1つまたは複数は、データベースヘッドノード320(例えば、それぞれがそれぞれのデータベースインスタンスの構成要素である、ヘッドノード320a、ヘッドノード320b、またはヘッドノード320c)に、ネットワーク360を介してアクセスしてよい(例えば、これらの構成要素はネットワークアドレス指定可能且つデータベースクライアント350aから350nにアクセス可能であってよい)。ただし、データベースクライアント350aから350nの代わりに、1つまたは複数のデータベーステーブルのデータページ(及びリドゥログレコードおよび/またはそれと関連付けられた他のメタデータ)を記憶し、本明細書に説明されるようにデータベースシステムの他の機能を実行するためにデータベースシステムによって利用されてよい分散型データベース最適化ストレージサービス310は、異なる実施形態では、ネットワークアドレス指定可能且つストレージクライアント350aから350nにアクセス可能であってよい、またはアクセス可能でないことがある。例えば、いくつかの実施形態では、分散型データベース最適化ストレージサービス310は、ストレージクライアント350aから350nに非可視である方法で多様な記憶動作、アクセス動作、ロギング変更動作、回復動作、及び/またはスペース管理動作を実行してよい。
上述されたように、各データベースインスタンスは、多様なクライアントプログラム(例えばアプリケーション)及び/または加入者(ユーザー)から要求を受信し、次いで要求をパースし、要求を最適化し、関連付けられたデータベース動作(複数の場合がある)を実施するための実行計画を作成する単一のデータベースエンジンヘッドノード320を含んでよい。図3に示される例では、データベースエンジンヘッドノード320aのクエリーパーシング、最適化、及び実行構成要素305は、データベースクライアント350aから受信され、データベースエンジンヘッドノード320aがその構成要素であるデータベースインスタンスをターゲットとするクエリーのためにこれらの機能を実行してよい。いくつかの実施形態では、クエリーパーシング、最適化、及び実行構成要素305はデータベースクライアント350aに、書込み肯定応答、要求されたデータページ(及びデータページの部分)、エラーメッセージ、及びまたは他の応答を適宜に含んでよいクエリー応答を返してよい。この例に示されるように、データベースエンジンヘッドノード320aは、分散型データベース最適化ストレージサービス310の中で多様なストレージノードに読取り要求及び/またはリドゥログレコードを送り、分散型データベース最適化ストレージサービス310から書込み肯定応答を受信し、分散型データベース最適化ストレージサービス310から要求されたデータページを受信し、及び/またはデータページ、エラーメッセージ、または他の応答を(同様にそれらをデータベースクライアント350aに返してよい)クエリーパーシング、最適化、及び実行構成要素305に返してよい、クライアント側ストレージサービスドライバ325も含んでよい。
この例では、データベースエンジンヘッドノード320aは、最近アクセスされたデータページが一時的に保持されてよいデータページキャッシュ335を含む。図3に示されるように、データベースエンジンヘッドノード320aは、データベースエンジンヘッドノード320aが構成要素であるデータベースインスタンスでトランザクション性及び一貫性を提供することに責任を負ってよいトランザクション及び一貫性管理構成要素330も含んでよい。例えば、この構成要素は、データベースインスタンス及び該データベースインスタンスに向けられるトランザクションの原子性、一貫性、及び独立性のプロパティを保証することに責任を負ってよい。図3に示されるように、データベースエンジンヘッドノード320aは、多様なトランザクションのステータスを追跡調査し、コミットしないトランザクションのあらゆるローカルでキャッシュに入れられた結果をロールバックするためにトランザクション及び一貫性管理構成要素330によって利用されてよいトランザクションログ340及びアンドゥログ345も含んでよい。
図3に示される他のデータベースエンジンヘッドノード320(例えば、320b及び320c)のそれぞれが類似する構成要素を含んでよく、データベースクライアント350aから350nの内の1つまたは複数によって受信され、それが構成要素であるそれぞれのデータベースインスタンスに向けられるクエリーのために類似する機能を実行してよいことに留意されたい。
いくつかの実施形態では、本明細書に説明される分散型データベース最適化ストレージシステムは、1つまたは複数のストレージノードでの記憶のために多様な論理ボリューム、セグメント、及びページでデータを編成してよい。例えば、いくつかの実施形態では、各データベーステーブルは論理ボリュームによって表され、各論理ボリュームはストレージノードの集合体上でセグメント化される。ストレージノード内の特定のストレージノード上で生きる各セグメントは、隣接ブロックアドレスのセットを含む。いくつかの実施形態では、各データページはセグメントに記憶され、したがって各セグメントは1つまたは複数のデータページの集合体及びそれが記憶する各データページの変更ログ(リドゥログとも呼ばれる)を記憶する。本明細書に詳細に説明されるように、ストレージノードは(本明細書でULRとも呼ばれてよい)リドゥログレコードを受信し、リドゥログレコードを合体させて、(例えば、ゆったりと及び/またはデータページもしくはデータベースクラッシュに対する要求に応えて)対応するデータページ及び/または追加のもしくは代替のログレコードの新しいバージョンを作成するように構成されてよい。いくつかの実施形態では、データページ及び/または変更ログは(クライアントによって指定されてよく、クライアントの代わりにデータベースシステムでデータベーステーブルが維持されている)可変構成に従って複数のストレージノード全体でミラーリングされてよい。例えば、異なる実施形態では、データログまたは変更ログの1つのコピー、2つのコピー、または3つのコピーがデフォルト構成、アプリケーションに特有の耐久性優先度、またはクライアントによって指定される耐久性優先度に従って、1つ、2つ、または3つの異なる可用性ゾーンもしくは領域のそれぞれに記憶されてよい。
本明細書に使用されるように、以下の用語は、多様な実施形態に従って分散型データベース最適化ストレージシステムによってデータの編成を説明するために使用されてよい。
ボリューム:ボリュームは、ストレージシステムのユーザー/クライアント/アプリケーションが理解するストレージのきわめて耐久性のある単位を表す論理概念である。すなわち、ボリュームはデータベーステーブルの多様なユーザーページに対する書込み動作の単一の一貫性がある順序付けられたログとしてユーザー/クライアント/アプリケーションに見える分散型ストアである。各書込み動作は、ボリュームの中で単一のユーザーページのコンテンツに対する論理的な順序付けられた変形を表すユーザーログレコード(ULR)で符号化されてよい。上述されたように、ULRは、本明細書でリドゥログレコードと呼ばれてもよい。各ULRは、一意のLSN、つまり論理シーケンス番号を含んでよい。各ULRは、ULRに高い耐久性及び可用性を提供するために、保護グループ(PG)を形成する、分散型ストア内の1つまたは複数の同期セグメントに持続してよい。ボリュームは、バイトの可変サイズの連続範囲にLSN型の読取り/書込みインタフェースを提供してよい。
いくつかの実施形態では、ボリュームはそれぞれが保護グループを通して耐久的にされた複数のエクステントから構成されてよい。係る実施形態では、ボリュームはボリュームエクステントの変わりやすい連続シーケンスから構成されるストレージの単位を表してよい。ボリュームに向けられる読取り及び書込みは、構成するボリュームエクステントに対する対応する読取り及び書込みにマッピングされてよい。いくつかの実施形態では、ボリュームのサイズは、ボリュームエクステントを追加することにより、又は、ボリュームの端部からボリュームエクステントを除去することにより変更されてもよい。
セグメント:セグメントは、単一ストレージノードに割り当てられるストレージの制限される耐久性の単位である。すなわち、セグメントは、特有の固定サイズバイト範囲のデータに、限られたベストエフォート型の耐久性(例えば、ストレージノードである、故障の永続的であるが冗長ではない単一点)を提供する。多様な実施形態では、このデータは、いくつかの場合では、ユーザーアドレス指定可能なデータのミラーであってよい、またはこのデータはボリュームメタデータまたはイレイジャーコーディングされたビット等の他のデータであってよい。所与のセグメントは、正確に1つのストレージノード上で生きてよい。ストレージノードの中で、複数のセグメントが各SSD上で生きてよく、各セグメントは1つのSSDに制限されてよい(例えば、セグメントは複数のSSDに及ばないことがある)。いくつかの実施形態では、セグメントはSSD上で連続領域を占有するように要求されないことがある。むしろ、各SSDにセグメントのそれぞれによって所有される領域を記述する割当てマップがあってよい。上述されたように、保護グループは複数のストレージノードに渡って拡散される複数のセグメントから構成されてよい。いくつかの実施形態では、セグメントは、(サイズが作成時に定義される)バイトの固定サイズの隣接範囲に、LSN型読取り/書込みインタフェースを提供してよい。いくつかの実施形態では、各セグメントはセグメントUUID(例えば、セグメントの汎用一意識別子)によって識別されてよい。
記憶ページ:記憶ページは、概して固定サイズのメモリのブロックである。いくつかの実施形態では、各ページは、オペレーティングシステムによって定義されるサイズのメモリの(例えば、バーチャルメモリ、ディスク、または他の物理メモリの)ブロックであり、本明細書では用語「データブロック」によって参照されてもよい。すなわち、記憶ページは隣接セクタのセットであってよい。記憶ページは、ヘッダ及びメタデータがあるログページでの単位だけではなく、SSDでの割当ての単位としても役立ってよい。いくつかの実施形態では、及び本明細書に説明されるデータベースシステムの文脈では、用語「ページ」または「記憶ページ」は、通常、4096バイト、8192バイト、16384バイト、または32768バイト等の2の倍数であってよいデータベース構成によって定義されるサイズの類似したブロックを指してよい。
ログページ:ログページは、ログレコード(例えば、リドゥログレコードまたはアンドゥログレコード)を記憶するために使用される記憶ページのタイプである。いくつかの実施形態では、ログページは、サイズが記憶ページと同一であってよい。各ログページは、例えばそれが属するセグメントを識別するメタデータ等、そのログページについてのメタデータを含むヘッダを含んでよい。ログページが編成の単位であり、必ずしも書込み動作に含まれるデータの単位ではないことがあることに留意されたい。例えば、いくつかの実施形態では、標準的な転送処理の間、書込み動作は、一度の1つのセクタをログの末尾に書き込んでよい。
ログレコード:ログレコード(例えば、ログページの個々の要素)はいくつかの異なるクラスであってよい。例えば、ストレージシステムのユーザー/クライアント/アプリケーションによって作成され、理解されるユーザーログレコード(ULR)は、ボリューム内のユーザーデータに対する変更を示すために使用されてよい。ストレージシステムによって生成される制御ログレコード(CLR)は、現在の無条件ボリューム耐久性(unconditional volume durable)LSN(VDL)等のメタデータを追跡調査するために使用される制御情報を含んでよい。ヌルログレコード(NLR)は、いくつかの実施形態では、ログセクタまたはログページの未使用のスペースを充填するためのパディングとして使用されてよい。いくつかの実施形態では、これらのクラスのそれぞれの中に多様なタイプのログレコードがあってよく、ログレコードのタイプはログレコードを解釈するために呼び出される必要がある関数に対応してよい。例えば、1つのタイプは特定の圧縮フォーマットを使用する圧縮フォーマットのユーザーページのすべてのデータを表してよく、第2のタイプは、ユーザーページの中のバイト範囲の新しい値を表してよく、第3のタイプは、整数として解釈されるバイトのシーケンスに対する増分動作を表してよく、第4のタイプはページの中の別の場所に1バイト範囲をコピーすることを表してよい。いくつかの実施形態では、特にULRの場合、ログレコードタイプは、(整数または列挙型によってよりむしろ)バージョニング及び開発を簡略化してよいGUIDによって識別されてよい。
ペイロード:ログレコードのペイロードは、ログレコードに、または特定のタイプのログレコードに特有であるデータまたはパラメータ値である。例えば、いくつかの実施形態では、大部分(またはすべての)ログレコードが含み、ストレージシステム自体が理解するパラメータまたは属性のセットがあってよい。これらの属性は、セクタサイズに比較して相対的に小さくてよい共通のログレコードヘッダ/構造の部分であってよい。さらに、大部分のログレコードは、そのログレコードタイプに特有の追加のパラメータまたはデータを含んでよく、この追加情報はそのログレコードのペイロードと見なされてよい。いくつかの実施形態では、特定のULRのペイロードがユーザーページサイズよりも大きい場合、ペイロードは、そのペイロードがユーザーページのためのすべてのデータを含む絶対ULR(AULR)によって置き換えられてよい。これは、ストレージシステムがユーザーページのサイズに等しいULRのペイロードのサイズに対する上限を課すことができるようにしてよい。
セグメントログでログレコードを記憶する際に、いくつかの実施形態では、ペイロードはログヘッダとともに記憶されてよいことに留意されたい。他の実施形態では、ペイロードは別の場所に記憶されてよく、そのペイロードが記憶される場所に対するポインタはログヘッダとともに記憶されてよい。さらに他の実施形態では、ペイロードの一部はヘッダに記憶されてよく、ペイロードの残りは別個の場所に記憶されてよい。ペイロード全体がログヘッダとともに記憶される場合、これは帯域内ストレージと呼ばれてよい。それ以外の場合、ストレージは帯域外であると呼ばれてよい。いくつかの実施形態では、大部分の大きなAULRのペイロードは(以下に説明される)ログのコールドゾーンで帯域外で記憶されてよい。
ユーザーページ:ユーザーページは、(固定サイズの)バイト範囲、及びストレージシステムのユーザー/クライアントに可視である特定のボリュームのためのそのアラインメントである。ユーザーページは論理概念であり、特定のユーザーページのバイトは任意の記憶ページにそのまま記憶されてよい、または記憶されないことがある。特定のボリュームのユーザーページのサイズは、そのボリュームの記憶ページサイズとは無関係であってよい。いくつかの実施形態では、ユーザーページサイズはボリュームごとに設定可能であってよく、ストレージノード上の異なるセグメントは異なるユーザーページサイズを有してよい。いくつかの実施形態では、ユーザーページサイズは、セクタサイズ(例えば、4KB)の倍数となるように制約されてよく、上限(例えば、64KB)を有してよい。他方、記憶ページサイズは、ストレージノード全体にとって固定であってよく、基礎的なハードウェアに対する変更がない限り変化しないことがある。
データページ:データページは、圧縮された形式でユーザーページデータを記憶するために使用される記憶ページのタイプである。いくつかの実施形態では、データページに記憶されるあらゆる1個のデータがログレコードと関連付けられ、各ログレコードは(データセクタとも呼ばれる)データページの中のセクタに対するポインタを含んでよい。いくつかの実施形態では、データページは各セクタによって提供されるメタデータ以外の任意の埋込みメタデータを含まないことがある。データページ内のセクタ間には関係性がなくてよい。代わりに、ページへの編成は、セグメントへのデータの割当ての粒度の表現としてのみ存在してよい。
ストレージノード:ストレージノードは、ストレージノードサーバコードが配備される単一のバーチャルマシンである。各ストレージノードは、複数のローカルにアタッチされたSSDを含んでよく、1つまたは複数のセグメントへのアクセスにネットワークAPIを提供してよい。いくつかの実施形態では、多様なノードはアクティブリスト上または(例えば、ノードが応答するには低速である、またはそれ以外の場合、正常に機能しないが、完全に使用不可ではない場合等)劣化したリスト上にあってよい。いくつかの実施形態では、クライアント側ドライバは、ノードが交換されるべきかどうか、及びいつノードが交換されるべきかを判断するため、及び/または観察された性能に基づいて、いつ及びどのようにして多様なノードの間でデータを再配分するのかを決定するために、ノードをアクティブまたは劣化として分類するのを支援してよい(または、分類するのに責任を負ってよい)
SSD:本明細書において参照されるように、用語「SSD」は、例えばディスク、ソリッドステートドライブ、電池によって支援されるRAM、NVMRAMデバイス(例えば、1つまたは複数のNVDIMM)、または別のタイプの永続ストレージデバイス等の、その記憶ボリュームによって利用されるストレージのタイプに関わりなく、ストレージノードによって見られるローカルブロック記憶ボリュームを指してよい。SSDは、必ずしも直接的にハードウェアにマッピングされない。例えば、異なる実施形態では、単一のソリッドステートストレージデバイスは、各ボリュームが複数のセグメントに分割され、複数のセグメントに渡ってストライピングされる複数のローカルボリュームに分けられる可能性がある、及び/または単一ドライブは単に管理の容易さのために複数のボリュームに分割されてよい。いくつかの実施形態では、各SSDは単一の固定場所で割当てマップを記憶してよい。このマップは、特定のセグメントによってどの記憶ページが所有されているのか、及び(データページと対照的に)これらのページの内のどれがログページであるのかを示してよい。いくつかの実施形態では、記憶ページは、転送処理が割当てを待機する必要がなくてよいように各セグメントに事前に割り当てられてよい。割当てマップに対するあらゆる変更は、新規に割り当てられた記憶ページがセグメントによって使用される前に耐久的にされる必要があることがある。
分散型データベース最適化ストレージシステムの一実施形態は、図4のブロック図によって示される。この例では、データベースシステム400は、相互接続460上でデータベースエンジンヘッドノード420と通信する分散型データベース最適化ストレージシステム410を含む。図3に示される例でのように、データベースエンジンヘッドノード420は、クライアント側ストレージサービスドライバ425を含んでよい。この例では、分散型データベース最適化ストレージシステム410は(430、440、及び450として示されるストレージシステムサーバノードを含んだ)複数のストレージシステムサーバノードを含み、複数のストレージシステムサーバノードのそれぞれは、それが記憶するセグメント(複数の場合がある)のためのデータページ及びリドゥログのストレージ、多様なセグメント管理機能を実行するように構成されるハードウェア及び/またはソフトウェアを含む。例えば、各ストレージシステムサーバノードは以下の動作、つまり、複製(例えば、ストレージノードの中で等ローカルに)、データページを生成するためのリドゥログの合体、クラッシュ回復、及び/または(例えば、セグメントの)スペース管理の内のいずれかまたはすべての少なくとも一部を実行するように構成されるハードウェア及び/またはソフトウェアを含んでよい。各ストレージシステムサーバノードは、データブロックがクライアント(例えば、ユーザー、クライアントアプリケーション、及び/またはデータベースサービス加入者)の代わりに記憶されてよい(例えば、SSD等の)複数のアタッチされたストレージデバイスも有してよい。
図4に示される例では、ストレージシステムサーバノード430は、データページ(複数の場合がある)433、セグメントリドゥログ(複数の場合がある)435、セグメント管理機能437、及びアタッチされたSSD471から478を含む。再び、ラベル「SSD」はソリッドステートドライブを指してよい、または指さないこともあるが、基礎的なハードウェアに関わりなく、より概してローカルブロック記憶ボリュームを指してよいことに留意されたい。同様に、ストレージシステムサーバノード440は、データページ(複数の場合がある)443、セグメントリドゥログ(複数の場合がある)445、セグメント管理機能447、及びアタッチされたSSD481から488を含み、ストレージシステムサーバノード450は、データページ(複数の場合がある)453、セグメントリドゥログ(複数の場合がある)455、セグメント管理機能457、及びアタッチされたSSD491から498を含む。
上述されたように、いくつかの実施形態では、セクタは、SSDでのアラインメントの単位であり、書込みが部分的だけに完了されるリスクなしに書き込むことができるSSDでの最大サイズであってよい。例えば、多様なソリッドステートドライブ及びスピニングメディアのセクタサイズは4KBであってよい。本明細書に説明される分散型データベース最適化ストレージシステムのいくつかの実施形態では、ありとあらゆるセクタは、セクタがその一部であるより高レベルのエンティティに関わりなく、セクタの始まりに64ビット(8バイト)のCRCを含んで有してよい。係る実施形態では、(セクタがSSDから読み取られるたびに確証されてよい)このCRCは破損を検出する際に使用されてよい。いくつかの実施形態では、ありとあらゆるセクタは、その値がセクタをログセクタ、データセクタ、または初期化されていないセクタとして該セクタを識別する「セクタタイプ」バイトを含んでもよい。例えば、いくつかの実施形態では、0のセクタタイプバイト値は、セクタが初期化されていないことを示してよい。
本明細書に説明されるデータベースエンジン及び分散型データベースストレージサービス等の、データベースエンジン及び別個の分散型データベースストレージサービスを含むデータベースシステムでデータにアクセスするための方法の一実施形態が、図5の流れ図によって示される。510で示されるように、この例では、方法は、データベースエンジンヘッドノードが、データベーステーブルのデータレコードに向けられた書込み要求を(例えば、データベースクライアントから)受信することを含んでよい。例えば、書込み要求は、新しいデータレコードがデータベーステーブルに(またはデータベーステーブルの特定のデータページに)追加される必要があることを指定してよい、またはデータベーステーブルの特定のデータページの既存のデータレコードに対する修正を指定してよい。方法は、データベースエンジンヘッドノードが、520でのように、要求された書込みを指定するリドゥログレコードを生成し、530でのように、特定のデータページを記憶する分散型データベース最適化ストレージシステムのノードにリドゥログレコードを送信する(が、要求が向けられる特定のデータページを送信しない)ことを含んでよい。
この例に示されるように、方法は、リドゥログレコードを受け取ることに応えて、540でのように、ストレージシステムノードがディスクに(または別のタイプの永続記憶媒体に)リドゥログレコードを書き込み、データベースエンジンヘッドノードに書込み肯定応答を返すことを含んでよい。いくつかの実施形態では、書込み肯定応答を受信することに応えて、データベースエンジンヘッドノードは、そこから書込み要求が受信されたクライアント(不図示)に対応する書込み肯定応答を返してよい。この例で示されるように、時間のある点で(例えば、リドゥログレコードを受信し、書込み肯定応答を返すことの後の時点で)、方法は、ストレージシステムノードが、ステップ550でのように、(例えば、ステップ540でディスクに書き込まれたリドゥログレコードを含んだ)特定のデータページのための複数のリドゥログレコードを合体させて、その現在の状態で特定のデータページのインスタンス化を生成することを含んでよい。例えば、リドゥログを合体させることは、特定のデータページのためにストレージシステムによって受信されたが、特定のデータページの最新のバージョンを提供するために特定のデータページのインスタンスにまだ適用されていないリドゥログのすべてを、特定のデータページの以前にインスタンス化されたバージョンに適用することを含んでよい。いくつかの実施形態では、特定のデータページの最新のバージョンが、1つまたは複数のリドゥログから、例えば該リドゥログを特定のデータページの以前に記憶されたバージョンに適用することなく、直接的に生成されてよいことに留意されたい。
図5に示されるように、方法は、(例えば、特定のデータページの最新のバージョンを作成するためにリドゥログを合体させることの後のなんらかの点で)データベースエンジンヘッドノードが、560でのように、特定のデータページに向けられた読取り要求を受信することも含んでよい。それに応じて、データベースエンジンヘッドノードは、570でのように、特定のデータページを記憶するストレージノードに対応する読取り要求を送信してよい。この例では、データベースエンジンヘッドノードがそのキャッシュに特定のデータページのカレントバージョンを記憶しないことが仮定されることに留意されたい。それ以外の場合、方法は、データベースエンジンヘッドノードが、対応する読取り要求をストレージシステムノードに送信することよりむしろ(例えば、そのキャッシュから要求されたデータを返すことによって)読取り要求自体に応答することを含んでよい。この例で示されるように、方法は、ストレージシステムノードが、580でのように、データベースエンジンヘッドノードに特定のデータページをその現在の状態で返すことを含んでよく、ステップ580の後、データベースエンジンヘッドノードは、590でのように、そこから読取り要求が受信されたクライアントに要求されたデータを返してよい。
多様な実施形態では、(例えば、ステップ580でのように)データベースエンジンヘッドノードに返される特定のデータページのバージョンは、ステップ550で合体動作によって生成されたのと同じバージョンであってよい、または後の合体動作(例えば、ステップ550での合体動作の後であった追加のリドゥログレコードを適用した動作)によって作成されたより最近のバージョンであってよい。例えば、異なる実施形態では、追加の合体動作は、データベースクラッシュ回復動作の一部として、または別のタイプのトリガに応えて、データベースエンジンヘッドノードからの読取り要求の受信に応えて、ストレージシステムノードで実行された可能性がある。いくつかの実施形態では、データベースエンジン及び別個の分散型データベースストレージサービスを含むデータベースシステムでデータにアクセスするための図5に示される動作は、データにアクセスする要求を受信することに応えて自動的に(例えば、ユーザー介入なしに)データベースシステムで実行されてよいことに留意されたい。
いくつかの実施形態では、分散型データベース最適化ストレージシステムのストレージシステムサーバノードのそれぞれは、例えばリドゥログを受信し、データページ等を送り返すために、データベースエンジンヘッドノードとの通信を管理するノードサーバのオペレーティングシステムで実行中のプロセスのセットを実装してよい。いくつかの実施形態では、分散型データベース最適化ストレージシステムに書き込まれるすべてのデータブロックは、(例えば、リモートキー値耐久性バックアップストレージシステムで)長期の及び/またはアーカイブのストレージにバックアップされてよい。
図6は、一実施形態に係る、データベースシステムでの別個の分散型データベース最適化ストレージシステムの使用を示すブロック図である。この例では、1つまたは複数のクライアントプロセス610が、データベースエンジン620及び分散型データベース最適化ストレージシステム630を含むデータベースシステムによって維持される1つまたは複数のデータベーステーブルにデータを記憶してよい。図6に示される例では、データベースエンジン620がデータベース階層構成要素660、及び(分散型データベース最適化ストレージシステム630とデータベース階層構成要素660との間のインタフェースとして働く)クライアント側ドライバ640を含む。いくつかの実施形態では、データベース階層構成要素660は、図3のクエリーパーシング、最適化、及び実行構成要素305、並びにトランザクション及び一貫性管理構成要素330によって実行される機能等の機能を実行してよい、及び/またはデータページ、トランザクションログ、及び/またはアンドゥログ(例えば、図3のデータページキャッシュ335、トランザクションログ340、及びアンドゥログ345によって記憶されるもの)を記憶してよい。
この例では、1つまたは複数のクライアントプロセス610は、データベース階層構成要素660に(ストレージノード635aから635nの内の1つまたは複数に記憶されるデータをターゲットとする読取り要求及び/または書込み要求を含んでよい)データベースクエリー要求615を送信してよく、データベース階層構成要素660からデータベースクエリー応答617(例えば、書込み肯定応答及び/または要求されたデータを含む応答)を受信してよい。データページに書き込む要求を含む各データベースクエリー要求615は、分散型データベース最適化ストレージシステム630への以後のルーティングのためにクライアント側ドライバ640に送信されてよい、1つまたは複数のレコード書込み要求641を生成するためにパースされ、最適化されてよい。この例では、クライアント側ドライバ640は、それぞれのレコード書込み要求641に対応する1つまたは複数のリドゥログレコード631を生成してよく、リドゥログレコード631を分散型データベース最適化ストレージシステム630のストレージノード635の特定のストレージノードに送信してよい。分散型データベース最適化ストレージシステム630は、データベースエンジン620に(具体的には、クライアント側ドライバ640に)各リドゥログレコード631の対応する書込み肯定応答632を返してよい。クライアント側ドライバ640は、これらの書込み肯定応答をデータベース階層構成要素660に(書込み応答642として)渡してよく、データベース階層構成要素660は次いで、データベースクエリー応答617の内の1つとして1つまたは複数のクライアントプロセス610に対応する応答(例えば、書込み肯定応答)を送信してよい。
この例では、データページを読み込む要求を含む各データベースクエリー要求615は、1つまたは複数のレコード読取り要求643を生成するためにパースされ、最適化されてよく、レコード読取り要求643は分散型データベース最適化ストレージシステム630への以後のルーティングのためにクライアント側ドライバ640に送信されてよい。この例では、クライアント側ドライバ640は、分散型データベース最適化ストレージシステム630のストレージノード635の特定のストレージノードにこれらの要求を送信してよく、分散型データベース最適化ストレージシステム630はデータベースエンジン620に(具体的には、クライアント側ドライバ640に)要求されたデータページ633を返してよい。クライアント側ドライバ640は、戻りデータレコード644としてデータベース階層構成要素660に返されたデータページを送信してよく、データベース階層構成要素660は次いでデータベースクエリー応答617として1つまたは複数のクライアントプロセス610にデータページを送信してよい。
いくつかの実施形態では、多様なエラーメッセージ及び/またはデータ損失メッセージ634が、分散型データベース最適化ストレージシステム630からデータベースエンジン620に(具体的には、クライアント側ドライバ640に)送信されてよい。これらのメッセージは、クライアント側ドライバ640から、エラー報告メッセージ及び/または損失報告メッセージ645として、データベース階層構成要素660に、及び次いで1つまたは複数のクライアントプロセス610に、データベースクエリー応答617とともに(または代わりに)渡されてよい。
いくつかの実施形態では、分散型データベース最適化ストレージシステム630のAPI631から634、及びクライアント側ドライバ640のAPI641から645は、データベースエンジン620が分散型データベース最適化ストレージシステム630のクライアントであるかのように、分散型データベース最適化ストレージシステム630の機能性をデータベースエンジン620に曝露してよい。例えば、データベースエンジン620は、データベースエンジン620及び分散型データベース最適化ストレージシステム630の組合せによって実装されるデータベースシステムの多様な動作(例えば、記憶動作、アクセス動作、ロギング変更動作、回復動作、及び/またはスペース管理動作)を実行するために(またはそれらの実行を容易にするために)(クライアント側ドライバ640を通して)リドゥログレコードまたは要求データページをこれらのAPIを通して書き込んでよい。図6に示されるように、分散型データベース最適化ストレージシステム630は、それぞれが複数のアタッチされたSSDを有してよいストレージノード635aから635nにデータブロックを記憶してよい。いくつかの実施形態では、分散型データベース最適化ストレージシステム630は、多様なタイプの冗長性方式の適用によって、記憶されているデータブロックに高い耐久性を提供してよい。
多様な実施形態では、図6のデータベースエンジン620と分散型データベース最適化ストレージシステム630との間のAPI呼出し及び応答(例えば、API631から634)、及び/またはクライアント側ドライバ640とデータベース階層構成要素660との間のAPI呼出し及び応答(例えば、API641から645)は、(例えば、ゲートウェイ制御プレーンによって管理される)安全なプロキシ接続上で実行されてよい、または公衆ネットワーク上でもしくは代わりにバーチャルプライベートネットワーク(VPN)接続等のプライベートチャネル上で実行されてよいことに留意されたい。本明細書に説明されるデータベースシステムの構成要素への、及びデータベースシステムの構成要素の間のこれらの及び他のAPIは、シンプルオブジェクトアクセスプロトコル(SOAP)技術及び表象状態転送(REST)技術を含むが、これに限定されるものではない異なる技術に従って実装されてよい。例えば、これらのAPIは、SOAP APIまたはRESTful APIとして実装されてよいが、必ずしも実装されない。SOAPは、ウェブベースのサービスとの関連で情報を交換するためのプロトコルである。RESTは分散型ハイパーメディアシステム用のアーキテクチャスタイルである。(RESTfulウェブサービスとも呼ばれてよい)RESTful APIは、HTTP及びREST技術を使用して実装されるウェブサービスAPIである。本明細書に説明されるAPIは、いくつかの実施形態では、データベースエンジン620及び/または分散型データベース最適化ストレージシステム630との統合をサポートするために、C、C++、Java、C#、及びPerlを含むが、これに限定されるものではない多様な言語でクライアントライブラリでラップされてよい。
上述されたように、いくつかの実施形態では、データベースシステムの機能構成要素は、データベースエンジンによって実行される構成要素と、別個の分散されたデータベース最適化ストレージシステムで実行される構成要素との間で仕切られてよい。1つの特定の例では、(例えば、単一のデータブロックを、そのデータブロックにレコードを追加することによって更新するために)何かをデータベーステーブルに挿入する要求をクライアントプロセス(またはクライアントプロセスのスレッド)から受信することに応えて、データベースエンジンヘッドノードの1つまたは複数の構成要素は、クエリーパーシング、最適化、及び実行を実行してよく、クエリーの各部分をトランザクション及び一貫性管理構成要素に送信してよい。トランザクション及び一貫性管理構成要素は、他のクライアントプロセス(またはクライアントプロセスのスレッド)が同時に同じ行を修正しようとしていないことを保証してよい。例えば、トランザクション及び一貫性管理構成要素は、この変更がデータベースにおいて原子的に、一貫して、耐久的に、及び独立して実行されることを保証することに責任を負ってよい。例えば、トランザクション及び一貫性管理構成要素は、分散型データベース最適化ストレージサービスのノードの1つに送信されるリドゥログレコードを生成し、ACIDプロパティがこのトランザクションについて満たされていることを保証する順序で及び/またはタイミングでリドゥログレコードを(他のクライアント要求に応えて生成される他のリドゥログとともに)分散型データベース最適化ストレージサービスに送信するために、データベースエンジンヘッドノードのクライアント側ストレージサービスドライバとともに機能してよい。対応するストレージノードは、(ストレージサービスによって「更新レコード」と見なされてよい)リドゥログレコードを受信すると、データブロックを更新し、データブロックのリドゥログを更新してよい(例えば、データブロックに向けられるすべての変更のレコード)。いくつかの実施形態では、データベースエンジンは、この変更のためにアンドゥログレコードを生成することに責任を負ってよく、アンドゥログのためのリドゥログレコードを生成することにも責任を負ってよく、この両方ともトランザクション性を保証するために(データベース階層で)ローカルに使用されてよい。ただし、従来のデータベースシステムにおいてとは異なり、本明細書に説明されるシステムは、(変更をデータベース階層で適用し、修正されたデータブロックをストレージシステムに送るよりむしろ)データブロックに変更を適用するための責任をストレージシステムに移してよい。
データベースエンジンの視点から、データベースシステムで書込み動作を実行するための方法の一実施形態が、図7の流れ図に示されている。710に示されるように、この例では、方法は、データベースエンジンヘッドノードがデータベーステーブルのデータレコードに向けられた書込み要求を(例えば、データベースクライアントから)受信することを含んでよい。例えば、書込み要求は、新しいデータレコードがデータベーステーブルに(またはデータベーステーブルの特定のデータページに)追加される必要があることを指定してよい、またはデータベーステーブルの特定のデータページの既存のデータレコードに対する修正を指定してよい。また、方法は、データベースエンジンヘッドノード(またはデータベースエンジンヘッドノードの特定の構成要素)が、720でのように、書込み要求をパースする及び/または最適化することを含んでもよい。例えば、いくつかの実施形態では、データベースエンジンヘッドノードは、クエリー実行計画を生成することに責任を負ってよい。図7に示されるように、方法は、データベースエンジンヘッドノードが、730でのように、要求された書込みを指定するリドゥログレコードを生成すること、及びデータベースエンジンヘッドノード(またはより詳細にはデータベースエンジンヘッドノード上のクライアント側ストレージサービスドライバ)が、740でのように、書込み要求が向けられる特定のデータページを記憶する分散型データベース最適化ストレージシステムのノードを決定することを含んでよい。
この例に示されるように、方法は、データエンジンヘッドノード(またはより詳細にはデータベースエンジンヘッドノード上のクライアント側ストレージサービスドライバ)が、750でのように、ストレージシステムの決定されたノードに、リドゥログレコードを送信するが、特定のデータページの任意のバージョンを送信しないことを含んでよい。図7に示されるように、データベースエンジンヘッドノード(またはより詳細にはデータベースエンジンヘッドノード上のクライアント側ストレージサービスドライバ)が、ストレージシステムからの書込みの肯定応答を受信するまで(及び受信しない限り)書込み要求に関してデータベースエンジンヘッドノードによって取られる他のアクションがないことがある。いったんこの肯定応答が受信されると(760からの肯定の終了として示される)、方法は、データベースエンジンヘッドノードが、770でのように、要求者に(例えば、そこから書込み要求が受信されたクライアントに)対応する書込み肯定応答を返すことを含んでよい。いくつかの実施形態では、書込み肯定応答が所定の期間内にストレージシステムから受信されない場合、データベースエンジンヘッドノード(またはより詳細にはデータベースエンジンヘッドノード上のクライアント側ストレージサービスドライバ)は、決定されたストレージノードが故障した(もしくは劣化している)、またはなんらかの他のエラー状態がストレージシステムに存在すると決定するように構成されてよいことに留意されたい。また、書込み動作を実行するための図7に示される動作が、書込み要求を受信することに応えて自動的に(例えば、ユーザー介入なしに)データベースシステムで実行されてよいことにも留意されたい。
分散型データベース最適化ストレージシステムの視点から、データベースシステムで書込み動作を実行するための方法の一実施形態が、図8の流れ図によって示される。810に示されるように、この例では、方法は、分散型データベース最適化ストレージシステムのノードが、ノードが記憶する特定のデータページ(であるが、特定のデータページ自体の任意のバージョンではない)に向けられるリドゥログレコードを、データベースエンジンから(例えば、データベースヘッドノードのクライアント側ストレージサービスドライバから)またはストレージシステムの別のクライアントから受信することを含んでよい。リドゥログレコードを受信することに応えて、方法は、ストレージシステムノードが、820でのように、ページのリドゥログレコードを1つまたは複数のディスクに(または別のタイプの永続記憶媒体に)書き込むことを含んでよい。例えば、異なる実施形態では、ストレージシステムノードは、特定のディスクに記憶される特定のデータページのリドゥログに、または同じ可用性ゾーンのもしくは2つ以上の異なる可用性ゾーンのそれぞれの1つまたは複数のディスクに記憶される係るリドゥログのいくつかのレプリカの内のいずれかにリドゥログレコードをアペンドしてよい。いったんリドゥログレコードの1つまたは複数のコピーが(システム全体の耐久性方針、アプリケーションに固有の耐久性方針、またはクライアントにより指定された耐久性方針に従って)無事に書き込まれると、方法は、ストレージシステムノードが、830でのように、データベースエンジンに(またはストレージシステムの他のクライアントに)書込み肯定応答を返すことを含んでもよい。リドゥログレコードが、それがストレージシステムノード上で向けられる特定のデータページの以前にインスタンス化されたバージョンに適用されているのか、それともまだ適用されていないのかに関係なく、リドゥログレコードを無事に書き込んだ後の任意の時点で、ストレージシステムノードがデータベースエンジンに書込み肯定応答を返してよいことに留意されたい。
この例に示されるように、ストレージシステムノードが、特定のデータページの最新のバージョンを作成するために特定のデータページの1つまたは複数のリドゥログレコードを合体させるべきときである場合(840からの肯定の終了として示される)、方法は、ストレージシステムノードが、(850でのように)特定のデータページの新しいバージョンをその現在の状態で生成するために特定のデータページの最も最近に記憶されたバージョンに1つまたは複数のリドゥログレコードを適用し、特定のデータページのその新しいバージョンを1つまたは複数のディスクに書き込むことを含んでよい。例えば、合体動作は、特定のデータページの最も最近にインスタンス化されたバージョンに対する、前回の合体動作以降に受信された(及び/または特定のデータページのいずれのバージョンにもまだ適用されていない)すべてのリドゥログレコードの適用を含んでよい。他の実施形態では、特定のデータページのカレントバージョンは、例えば特定のデータページの以前に記憶されたバージョンにそれらを適用することなく、1つまたは複数のリドゥログから直接的に生成されてよい。本明細書に説明されるように、異なる実施形態では、所与のデータページの未決のリドゥログレコードをいつ合体させるべきかを決定するさまざまな方法があってよい。例えば、合体動作は、データページをターゲットとする単一のリドゥログを受信することに応えて、データページをターゲットとする所定数のリドゥログレコードまたは所与の期間内にデータページをターゲットとする所定数のリドゥログレコードを受信したことに応えて、データページをターゲットとする読取り要求を受信することに応えて、クラッシュ回復動作の開始に応えて、または任意の他の適切な方針に従って定期的な(例えば周期的な)時間間隔でデータページに対してトリガされてよい。
図8に示されるように、ストレージシステムノードが特定のデータページのリドゥログレコードを合体させるべきではないが(840からの否定の終了として示される)、特定のデータページをターゲットとする別のリドゥログレコードが受信される場合(860からの肯定の終了として示される)、方法は、追加のリドゥログレコードのために820から860に示される動作を繰り返すことを含んでよい。この例では、特定のデータページをターゲットとするより多くのリドゥログレコードがストレージシステムによって受信されるにつれ、ストレージシステムノードは追加のリドゥログレコードごとに820から860に示される動作を繰り返してよく、ストレージシステムノードは1つまたは複数の適用可能なトリガ及び/または方針に従ってときどき特定のデータページのためにリドゥログレコードを合体させてよい。これは、860から820への肯定の終了のフィードバック、及び860から840への否定の終了からのフィードバックによって図8に示される。書込み動作を実行するための図8に示される動作が、リドゥログレコードを受信することに応えて自動的に(例えば、ユーザー介入なしに)ストレージシステムで実行されてよいことに留意されたい。
いくつかの実施形態では、いくつかのデータページ(例えば、仮にあるとしても、めったにアクセスされないデータページ)は(例えば、合体動作によって)絶対に生成されることがない場合がある、及び/またはメモリで持続されることがない場合があることに留意されたい。例えば、いくつかの実施形態では、係るデータページに向けられるあらゆるリドゥログレコードは、1つまたは複数のストレージシステムノードによって記憶されてよい(例えば、メモリで持続されてよい)が、これらのリドゥログレコードは、それらを読み取る要求が受信されるまで、または受信されない限り、それらのデータページの完全なバージョンを生成するために使用されないことがある。係る実施形態では、たとえ(例えば、読取り要求に応えて)係るデータページのバージョンが生成されても、(例えばそれがすぐに再びアクセスされる、頻繁にアクセスされる、または絶対にアクセスされる可能性が低い場合)それはメモリで持続されないが、代わりにそれが要求者に返された後の任意の時点で廃棄されてよい。
異なる実施形態で、さまざまな割当てモデルがSSDのために実装されてよい。例えば、いくつかの実施形態では、ログエントリページ及び物理アプリケーションページが、SSDデバイスと関連付けられたページの単一のヒープから割り当てられてよい。この手法は、未指定のままとなるために、および自動的に使用に適合するためにログページ及びデータページによって消費される相対的な記憶量を残すという優位点を有してよい。また、手法は、ページが使用され、準備なしに随意に転用されるまでページを準備されないままにできるという優位点も有してよい。他の実施形態では、割当てモデルはストレージデバイスをログエントリ及びデータページのための別々のスペースに仕切ってよい。一度係る割当てモデルが図9のブロック図に示され、以下に説明される。
図9は、一実施形態に係る、分散型データベース最適化ストレージシステムの所与のストレージノード(または永続ストレージデバイス)にデータ及びメタデータがどのように記憶されてよいのかを示すブロック図である。この例では、SSDストレージスペース900は、910と名前が付けられたスペースの部分にSSDヘッダ及び他の固定メタデータを記憶する。SSDストレージスペース900は、920と名前が付けられたスペースの部分にログページを記憶し、追加のログページのために初期化され、確保される、930と名前が付けられたスペースを含む。(940として示される)SSDストレージスペース900の一部分は初期化されているが、割り当てられておらず、(950として示される)スペースの別の部分は初期化されておらず、割り当てられていない。最後に、960と名前が付けられたSSDストレージスペース900の部分はデータページを記憶する。
この例では、最初の使用可能なログページスロットは915として示され、最後の使用されたログページスロット(一時的)は925として示される。最後の確保されたログページスロットは935として示され、最後の使用可能なログページスロットは945として示される。この例では、最初の使用されたデータページスロット(一時的)は965として示される。いくつかの実施形態では、SSDストレージスペース900の中でのこれらの要素(915、925、935、945、及び965)のそれぞれの位置は、それぞれのポインタによって識別されてよい。
図9に示される割当て手法では、有効なログページはフラットストレージスペースの始まりにパックされてよい。ログページが解放されるために開く穴は、アドレススペースのさらに先に入る追加のログページスロットが使用される前に再使用されてよい。例えば、最悪の場合、最初のn個のログページスロットが有効なログデータを含み、この場合、nは今まで同時に存在した有効なログページの最大数である。この例では、有効データページはフラットストレージスペースの最後にパックされてよい。データページが解放されることにより開く穴は、アドレススペースでより下方の追加のデータページスロットが使用される前に再使用されてよい。例えば、最悪の場合、最後のmのデータページが有効なデータを含み、この場合mは今まで同時に存在した有効なデータページの最大数である。
いくつかの実施形態では、ログページスロットが有効なログページエントリの潜在的なセットの部分になることができる前に、ログページスロットは有効な将来のログエントリページのために混同できない値に初期化される必要がある。廃棄されたログページは新しい有効なログページについて絶対に混同されることがないほど十分なメタデータを有するので、これは、リサイクルされるログページスロットに暗黙に当てはまる。ただし、ストレージデバイスが最初に初期化されるとき、またはアプリケーションデータページを記憶するために潜在的に使用されたスペースが再利用されるとき、ログページスロットは、ログページスロットがログページスロットプールに加えられる前に初期化される必要がある。いくつかの実施形態では、ログスペースのバランスを取り戻す/再利用することは、バックグラウンドタスクとして実行されてよい。
図9に示される例では、カレントログページスロットプールは(915で)最初の使用可能なログページスロットと最後の確保されたログページスロット(925)との間に領域を含む。いくつかの実施形態では、このプールは、(例えば、最後の確保されたログページスロット935を識別するポインタに対する更新を持続させることによって)新しいログページスロットの再初期化なしに最後の使用可能なログページスロット(925)まで安全に増大してよい。この例では、(ポインタ945によって識別される)最後の使用可能なログページスロットを超えて、プールは、初期化されたログページスロットを持続し、最後の使用可能なログページスロット(945)のためのポインタを持続的に更新することによって、(ポインタ965によって識別される)最初の使用されたデータページスロットまで成長してよい。この例では、950として示される、SSDストレージスペース900の以前に初期化されておらず、割り当てられていない部分は、ログページを記憶するためにとりあえず利用されてよい。いくつかの実施形態では、カレントログページスロットプールは、最後の確保されたログページスロット(935)のポインタに対する更新を持続することによって(ポインタによって識別される)最後の使用されたログページスロットの位置まで縮小されてよい。
図9に示される例では、カレントデータページスロットプールは、(ポインタ945によって識別される)最後の使用可能なログページスロットと、SSDストレージスペース900の最後との間に領域を含む。いくつかの実施形態では、データページプールは、最後の使用可能なログページスロット(945)のポインタに対する更新を持続するによって、最後の確保されたログページスロット(935)に対するポインタによって識別される位置まで安全に成長してよい。この例では、940として示される、SSDストレージスペース900の以前に初期化されたが、割り当てられていない部分は、データページを記憶するためにとりあえず利用されてよい。これを超えて、プールは、最後の確保されたログページスロット(935)及び最後の使用可能なログページスロット(945)のポインタに対する更新を持続し、ログページよりむしろデータページを記憶するために、930及び940として示されるSSDストレージスペース900の部分を効果的に割り当てし直すことによって、最後の使用されたログページスロット(925)のポインタによって識別される位置まで安全に成長してよい。いくつかの実施形態では、データページスロットプールは、追加のログページスロットを初期化し、最後の使用可能なログページスロット(945)のポインタに対する更新を持続することによって、最初の使用されたデータページスロット(965)のポインタによって識別される位置まで安全に縮小されてよい。
図9に示される割当て手法を利用する実施形態では、ログページプール及びデータページプールのページサイズは、優れたパッキング挙動を容易にしつつも、独立して選択されてよい。係る実施形態では、有効なログページが、アプリケーションデータによって形成されるスプーフィングされたログページにリンクする可能性はないことがあり、壊れたログと依然として書き込まれていない次のページにリンクする有効なログテールとを区別することが可能なことがある。図9に示される割当て手法を利用する実施形態では、起動時、最後の確保されたログページスロット(935)に対するポインタによって識別される位置までのログページスロットのすべてが迅速に且つ連続して読み取られてよく、(推論されるリンキング/順序付けを含む)ログインデックス全体が再構築されてよい。係る実施形態では、すべてはLSN順序制御制約から推論できるので、ログページ間の明示的なリンキングの必要性がないことがある。
いくつかの実施形態では、セグメントは3つの主要な部分(またはゾーン)、つまり、ホットログを含む部分、コールドログを含む部分、及びユーザーページデータを含む部分から構成されてよい。ゾーンは、必ずしもSSDの隣接領域ではない。むしろ、ゾーンは、記憶ページの粒度で点在することがある。さらに、セグメント及びそのプロパティについてのメタデータを記憶するセグメントごとにルートページがあってよい。例えば、セグメントのルートページはセグメントのためのユーザーページサイズ、セグメント内のユーザーページの数、(フラッシュ番号(flush number)の形で記録されてよい)ホットログゾーンの現在の始まり/ヘッド、ボリュームエポック、及び/またはアクセス制御メタデータを記憶してよい。
いくつかの実施形態では、ホットログゾーンは、それらがストレージノードによって受信されるにつれ、クライアントからの新しい書込みを受け入れてよい。ページの以前のバージョンからのデルタの形をとるユーザーページに対する変更を指定するデルタユーザーログレコード(DULR)及び完全なユーザーページのコンテンツを指定する絶対ユーザーログレコード(AULR)の両方とも、ログに完全に書き込まれてよい。ログレコードは、ほぼ、ログレコードが受信され(つまり、ログレコードがLSNによってソートされるのではない)、それらがログページに渡って広がることがある順序でこのゾーンに追加されてよい。例えばログレコードは独自のサイズの表示を含んでよい等、ログレコードは自己記述的である必要がある。いくつかの実施形態では、ガベージコレクションはこのゾーンで実行されない。代わりに、スペースは、すべての必要とされるログレコードがコールドログにコピーされた後にログの始まりから切り詰めることによって再利用されてよい。ホットゾーンのログセクタは、セクタが作成されるたびに最も最近の既知の無条件VDLで注釈されてよい。条件付きのVDL CLRは、それらが受信されるにつれホットゾーンに書き込まれてよいが、最も最近に書き込まれたVDL CLRだけが意味を持ってよい。
いくつかの実施形態では、新しいログページが書き込まれるたびに、新しいログページにはフラッシュ番号が割り当てられる。フラッシュ番号は、各ログページの中のあらゆるセクタの部分として書き込まれてよい。フラッシュ番号は、2つのログページを比較するときに、どのログページが後に書き込まれたのかを決定するために使用されてよい。フラッシュ番号は単調に増加し、SSD(またはストレージノード)に対して調べられて(scoped)よい。例えば、単調に増加するフラッシュ番号のセットは、SSD上のすべてのセグメント(またはストレージノード上のすべてのセグメント)の間で共有される。
いくつかの実施形態では、コールドログゾーンで、ログレコードはそのLSNの昇順で記憶されてよい。このゾーンでは、AULRはそのサイズに応じて必ずしもデータをインラインで記憶しないことがある。例えば、AULRが大きなペイロードを有する場合、ペイロードのすべてまたは一部がデータゾーンに記憶されてよく、AULRはそのデータがデータゾーンのどこに記憶されているのかを指してよい。いくつかの実施形態では、コールドログゾーンのログページは、セクタ単位でよりむしろ、一度に1全ページ、書き込まれてよい。コールドゾーンのログページは一度に全ページ書き込まれるため、全セクタ内のフラッシュ番号が同一ではないコールドゾーンのどのようなログページも不完全に書き込まれたページと見なされてよく、無視されてよい。いくつかの実施形態では、コールドログゾーンでは、DULRは(最大2ログページまで)複数のログページに及ぶことができることがある。しかし、AULRは、例えば合体動作が単一の原子的な書込みでDULRをAULRで置き換えることができるように、複数のログセクタに及ぶことができないことがある。
いくつかの実施形態では、コールドログゾーンは、ホットログゾーンからログレコードをコピーすることによってポピュレートされる。係る実施形態では、LSNが現在の無条件ボリューム耐久性LSN(VDL)以下であるログレコードだけがコールドログゾーンにコピーされる資格があってよい。ホットログゾーンからコールドログゾーンにログレコードを移動するとき、(多くのCLR等の)いくつかのログレコードは、それらがもはや必要ではないため、コピーされる必要がないことがある。さらにユーザーページのなんらかの追加の合体がこの点で実行されてよく、このことが必要とされるコピーの量を削減してよい。いくつかの実施形態では、いったん所与のホットゾーンログページが完全に書き込まれ、もはや最新のホットゾーンログページではなく、ホットゾーンログページ上のすべてのULRがコールドログゾーンに無事にコピーされると、ホットゾーンログページは解放され、再使用されてよい。
いくつかの実施形態では、例えば記憶階層のSSDにもはや記憶される必要のないログレコード等、もはやサポートされていないログレコードによって占められているスペースを再利用するために、ガベージコレクションがコールドログゾーンで行われてよい。例えば、ログレコードは同じユーザーページに対する以後のAULRがあるときにサポートされなくなってよく、ログレコードによって表されるユーザーページのバージョンはSSDでの保持に必要とされない。いくつかの実施形態では、ガベージコレクションプロセスは、2つ以上の隣接するログページをマージし、2つ以上の隣接するログページをそれらのページが置き換えているログページからの旧式ではないログレコードのすべてを含むより少ない新しいログページで置き換えることによってスペースを再利用してよい。新しいログページには、それらが置き換えているログページのフラッシュ番号よりも大きい新しいフラッシュ番号が割り当てられてよい。これらの新しいログページの書込みが完了した後に、置き換えられたログページが空きページプールに加えられてよい。いくつかの実施形態では、あらゆるポインタを使用するログページの明示的な連鎖がないことがあることに留意されたい。代わりに、ログページのシーケンスはそれらのページに対するフラッシュ番号によって暗黙に決定されてよい。ログレコードの複数のコピーが検出されるたびに、最高のフラッシュ番号のログページに存在するログレコードが有効であると見なされてよく、他はもはやサポートされないと見なされてよい。
いくつかの実施形態では、例えば、データゾーン(セクタ)の中で管理されるスペースの粒度がデータゾーン(記憶ページ)の外の粒度とは異なってよいため、なんらかのフラグメンテーションがあってよい。いくつかの実施形態では、このフラグメンテーションを管理するために、システムは各データページによって使用されるセクタの数を追跡調査してよく、ほぼ全データページから優先的に割り当ててよく、(データを新しい場所に、それが依然として関連している場合に移動することを必要としてよい)ほぼ空のデータページのガベージコレクションを優先的に行ってよい。セグメントに割り当てられるページが、いくつかの実施形態では3つのゾーンの間で転用されてよいことに留意されたい。例えば、セグメントに割り当てられていたページが解放されると、ページはある期間そのセグメントと関連付けられたままとなってよく、後にそのセグメントの3つのゾーンのいずれかで使用されてよい。あらゆるセクタのセクタヘッダは、セクタが属するゾーンを示してよい。いったんページ内のすべてのセクタが空くと、ページは、ゾーンに渡って共有される共通の空き記憶ページプールに返されてよい。この空き記憶ページの共有は、いくつかの実施形態では、フラグメンテーションを削減(または回避)してよい。
いくつかの実施形態では、本明細書に説明される分散型データベース最適化ストレージシステムは、メモリ内に多様なデータ構造を維持してよい。例えば、セグメントに存在するユーザーページごとに、ユーザーページテーブルが、このユーザーページが「クリアされる」かどうか(つまり、このユーザーページがすべてのゼロを含んでいるかどうか)、該ページのためのコールドログゾーンからの最新のログレコードのLSN、及びページのホットログゾーンからのすべてのログレコードの場所のアレイ/リストを示すビットを記憶してよい。ログレコードごとに、ユーザーページテーブルはセクタ番号、そのセクタの中のログレコードのオフセット、そのログページの中で読み取るセクタの数、(ログレコードが複数のログページに及ぶ場合)第2のログページのセクタ番号、及びそのログページの中で読み取るセクタの数を記憶してよい。いくつかの実施形態では、ユーザーページテーブルは、コールドログゾーンからのあらゆるログレコードのLSN、及び/またはAULRがコールドログゾーンにある場合、最新のAULRのペイロードのセクタ番号のアレイを記憶してもよい。
本明細書に説明される分散型データベース最適化ストレージシステムのいくつかの実施形態では、LSNインデックスはメモリに記憶されてよい。LSNインデックスは、コールドログゾーンの中のログページにLSNをマッピングしてよい。コールドログゾーンのログレコードがソートされていることを考えれば、それはログページあたり1つのエントリを含むためであってよい。ただし、いくつかの実施形態では、あらゆる旧式ではないLSNがインデックスに記憶され、対応するセクタ番号、オフセット、及びログレコードごとのセクタの数にマッピングされてよい。
本明細書に説明される分散型データベース最適化ストレージシステムのいくつかの実施形態では、ログページテーブルはメモリに記憶されてよく、ログページテーブルはコールドログゾーンのガベージコレクションの間に使用されてよい。例えば、ログページテーブルはどのログレコードがもはやサポートされていないのか(例えば、どのログレコードのガベージコレクションを行うことができるのか)、及び各ログページでどれほど多くの空きスペースが使用できるのかを識別してよい。
本明細書に説明されるストレージシステムでは、エクステントは、ボリュームを表すために他のエクステントと結合できる(連結できる、またはストライピングできるのかのどちらか)ストレージの高度に耐久性の単位を表す論理概念であってよい。各エクステントは、単一の保護グループでのメンバーシップによって耐久的にされてよい。エクステントは、LSN型の読取り/書込みインタフェースを、作成時に定義される固定サイズを有する隣接バイトサブレンジに提供してよい。エクステントに対する読取り/書込み動作は、含む側の保護グループによって1つまたは複数の適切なセグメント読取り/書込み動作にマッピングされてよい。本明細書に使用されるように、用語「ボリュームエクステント」は、ボリュームの中のバイトの特有のサブレンジを表すために使用されるエクステントを指してよい。
上述されたように、ボリュームは、それぞれが1つまたは複数のセグメントから構成される保護グループによって表される複数のエクステントから構成されてよい。いくつかの実施形態では、異なるエクステントに向けられるログレコードはインタリーブされたLSNを有してよい。ボリュームに対する変更が特定のLSNまで耐久的となるためには、そのLSNまでのすべてのログレコードが、それらが属しているエクステントに関わりなく耐久的である必要があってよい。いくつかの実施形態では、クライアントは、まだ耐久的にされていない未決ログレコードを追跡調査してよく、いったん特定のLSNまでのすべてのULRが耐久的にされると、クライアントはボリュームの保護グループの内の1つにボリューム耐久性LSN(VDL)メッセージを送信してよい。VDLは、保護グループのすべての同期ミラーセグメントに書き込まれてよい。これは「無条件VDL」と呼ばれることがあり、それはセグメントで起こる書込み活動とともに多様なセグメントに(またはより詳細には、多様な保護グループに)周期的に持続されてよい。いくつかの実施形態では、無条件VDLはログセクタヘッダに記憶されてよい。
多様な実施形態では、セグメントで実行されてよい動作は、(ホットログゾーンの末尾にDULRまたはAULRを書き込み、次いでユーザーページテーブルを更新することを含んでよい)クライアントから受信されたDULRまたはAULRを書き込むこと、(ユーザーページのデータセクタの位置を突き止め、あらゆる追加のDULRを適用する必要なしにデータセクタを返すことを含んでよい)コールドユーザーページを読み取ること、(ユーザーページの最も最新のAULRのデータセクタの位置を突き止めることを含み、ユーザーページに、それを返す前にあらゆる以後のDULRを適用してよい)ホットユーザーページを読み取ること、及び(適用された最後のDULRを置き換えるAULRを作成するためにユーザーページのDULRを合体させることを含んでよい)DULRをAULRで置き換えることを含んでよい。本明細書に説明されるように、合体は、ユーザーページのより最近のバージョンを作成するためにユーザーページの初期のバージョンにDULRを適用するプロセスである。(別のDULRが書き込まれるまで)合体の前に書き込まれたすべてのDULRは要求に応じて読み取られ、適用される必要はないことがあるため、ユーザーページを合体させることは読取りレーテンシを削減するのに役立ってよい。また、合体は、(ログレコードが存在することを必要とするスナップショットがないならば)旧いAULR及びDULRをもはやサポートされなくすることによってストレージスペースを再利用するのに役立ってよい。いくつかの実施形態では、合体動作は、最も最新のAULRを場所を見つけ、DULRのいずれも省略することなく、あらゆる以後のDULRを順番に適用することを含んでよい。上述されたように、いくつかの実施形態では、合体はホットログゾーンの中で実行されないことがある。代わりに、合体はコールドログゾーンの中で実行されてよい。いくつかの実施形態では、合体は、ログレコードがホットログゾーンからコールドログゾーンにコピーされるにつれて実行されてもよい。
いくつかの実施形態では、ユーザーページを合体させる決定は、(例えば、DULRチェーンの長さが合体動作の所定の閾値を超える場合、システム全体での方針、アプリケーション特有の方針、またはクライアントによって指定される方針に従って))、またはクライアントに読み取られているユーザーページごとに、ページの未決のDULRチェーンのサイズによってトリガされてよい。
図10は、一実施形態に係る、データベースボリューム1010の例の構成を示すブロック図である。この例では、(アドレス範囲1015aから1015eとして示される)多様なアドレス範囲1015のそれぞれに対応するデータが(セグメント1045aから1045nとして示される)異なるセグメント1045として記憶される。すなわち、多様なアドレス範囲1015のそれぞれに対応するデータは(エクステント1025aから1025b、及びエクステント1035aから1035hとして示される)異なるエクステントに編成されてよく、これらのエクステントの多様なエクステントが、(ストライプセット1020a及びストライプセット1020bとして示されるもの等の)ストライピングを行って、または行わないで(1030aから1030fとして示される)異なる保護グループ1030に含まれてよい。この例では、保護グループ1はイレイジャーコーディングの使用を示す。この例では、保護グループ2及び3、並びに保護グループ6及び7は互いのミラーリングされたデータセットを表す。一方、保護グループ4は単一インスタンス(非冗長)データセットを表す。この例では、保護グループ8は、他の保護グループを結合する複数階層保護グループを表す(例えば、これは複数領域保護グループを表してよい)。この例では、ストライプセット1(1020a)及びストライプセット2(1020b)は、いくつかの実施形態で、エクステント(例えば、エクステント1025a及び1025b)がどのようにしてボリュームの中にストライピングされてよいのかを示す。
すなわち、この例では、保護グループ1(1030a)は、それぞれ範囲1から3(1015aから1015c)のデータを含むエクステントaからc(1035aから1035c)を含み、これらのエクステントはセグメント1から4(1045aから1045d)にマッピングされる。保護グループ2(1030b)は、範囲4(1015d)からストライピングされたデータを含むエクステントd(1035d)を含み、このエクステントはセグメント5から7(1045eから1045g)にマッピングされる。同様に、保護グループ3(1030c)は、範囲4(1015d)からストライピングされたデータを含むエクステントe(1035e)を含み、セグメント8から9(1045hから1045i)にマッピングされ、保護グループ4(1030d)は、範囲4(1015d)からストライピングされたデータを含むエクステントf(1035f)を含み、セグメント10(1045j)にマッピングされる。この例では、保護グループ6(1030e)は、範囲5(1015e)からストライピングされたデータを含むエクステントg(1035g)を含み、セグメント11から12(1045kから1045l)にマッピングされ、保護グループ7(1030f)は、やはり範囲5(1050e)からストライピングされたデータを含むエクステントh(1035h)を含み、セグメント13−14(1045mから1045n)にマッピングされる。
データベースシステムで読取り動作を実行するための方法の一実施形態は、データベースエンジンの視点から、図11の流れ図によって示される。1110で示されるように、この例では、方法は、データベースエンジンヘッドノードが(例えば、データベースクライアントから)特定のデータページに向けられる読取り要求を受信することを含んでよい。また、方法は、データベースエンジンヘッドノード(またはデータベースエンジンヘッドノードの特定の構成要素)が、1120でのように、読取り要求をパースする、及び/または最適化することを含んでもよい。例えば、いくつかの実施形態では、データベースエンジンヘッドノードは、クエリー実行計画を生成することに責任を負ってよい。図11に示されるように、特定のデータページが、1130からの肯定の終了として示される、データベースエンジンヘッドノードのキャッシュに常駐する場合、方法は、データベースエンジンヘッドノードが、1135でのように、そのキャッシュで検出される特定のデータページのバージョンから要求されたデータを返すことを含んでよい。例えば、いくつかの実施形態では、データベースエンジンヘッドノードはそのキャッシュの中に最も最近アクセスされたデータページのコピーを一時的に保持してよく、(例えば、それらの書込み要求のためのリドゥログレコードを生成し、分散型データベース最適化ストレージシステムに渡すことに加えて)それらに向けられる書込み要求を受信することに応えてそれらのコピーを更新してよい。いくつかの係る実施形態では、読取り動作がターゲットとする特定のデータページがキャッシュに常駐する場合、特定のデータページは特定のデータページの最新のバージョンであると見なされてよい(例えば、データページをターゲットとするすべてのリドゥログレコードが、キャッシュに記憶される特定のデータページのバージョンにすでに適用されていると仮定されてよい)。
図11に示されるように、特定のデータページが、1130からの否定の終了として示される、データベースエンジンヘッドノードのキャッシュに常駐しない場合、方法は、データベースエンジンヘッドノード(またはより詳細にはデータベースエンジンヘッドノード上のクライアント側ストレージサービスドライバ)が、1140でのように、特定のデータページを記憶する分散型データベース最適化ストレージシステムのノードを決定し、決定されたストレージシステムノードに対応する読取り要求を送信することを含んでよい。図11に示されるように、データベースエンジンヘッドノード(またはより詳細にはデータベースエンジンヘッドノード上のクライアント側ストレージサービスドライバ)が、ストレージシステムから特定のデータページを(その現在の状態で)受信するまで(及び受信しない限り)、読取り要求に関してデータベースエンジンヘッドノードによって講じられる他のアクションはないことがある。いったんデータベースエンジンヘッドノード(またはより詳細にはデータベースエンジンヘッドノード上のクライアント側ストレージサービスドライバ)が、決定されたストレージシステムノードから特定のデータページをその現在の状態で受信すると(1150からの肯定の終了で示される)、方法は、データベースエンジンヘッドノードが、1160でのように、要求されたデータを要求者(例えば、そこから読取り要求が受信されたクライアント)に返すことを含んでよい。例えば、決定されたストレージシステムノードから受信された特定のデータページのバージョンが、今まで特定のデータページをターゲットとしたすべてのリドゥログレコードが適用される(またはデータベースシステムのトランザクション性及び一貫性を維持しつつ適用できたリドゥログレコードの内の少なくともすべて)の特定のデータページのバージョンである場合、データベースエンジンヘッドノードは、決定されたストレージシステムノードから受信される特定のデータページのバージョンから要求されたデータを返してよい。いくつかの実施形態では、特定のデータページのカレントコピーが所定の期間内にストレージシステムから受信されない場合、データベースエンジンヘッドノード(またはより詳細にはデータベースエンジンヘッドノード上のクライアント側ストレージサービスドライバ)は、決定されたストレージノードが故障した(もしくは劣化している)、またはなんらかの他のエラー状態がストレージシステムに存在すると決定するように構成されてよいことに留意されたい。また、読取り動作を実行するための図11に示される動作が、読取り要求を受信することに応えて自動的に(例えば、ユーザー介入なしに)データベースシステムで実行されてよいことも留意されたい。
分散型データベース最適化ストレージシステムの視点から、データベースシステムで読取り動作を実行するための方法の一実施形態が、図12の流れ図によって示される。1210で示されるように、この例では、方法は、分散型データベース最適化ストレージシステム内のノードが、ストレージシステムノードによって記憶される特定のデータページに向けられる読取り要求を受信することを含んでよい。異なる実施形態では、ストレージシステムは、データベースエンジンから(例えば、データベースヘッドノードのクライアント側ストレージサービスドライバから)、または別のストレージサービスクライアントから読取り要求を受信してよい。この例に示されるように、ストレージシステムノードがデータページの最新のコピーを記憶する場合(1220からの肯定の終了として示される)、方法は、ストレージシステムノードが、1250でのように、それがすでに記憶しているデータページの最新のコピーを返すことを含んでよい。例えば、今までストレージシステムノードによって受信された特定のブロックをターゲットとするリドゥログレコードのすべて(またはデータベースシステムのトランザクション性及び一貫性のプロパティを維持しつつ適用できたリドゥログレコードの少なくともすべて)が特定のデータページに適用された場合(例えば、それらが特定のデータページのカレントバージョンを作成するために合体した場合)、ストレージシステムノードは、応答を返す前に特定のデータページのリドゥログレコードに対して追加の合体動作を実行する必要がないことがある。
他方、ストレージシステムノードがデータページの最新のコピーを記憶しない場合(1220からの否定の終了として示される)、方法は、ストレージシステムノードが、1230でのように、ディスクからまたは別の永続ストレージデバイスから最も最近に記憶されたコピーを取り出し、次いで1240でのように、特定のデータページの取り出されたコピーに特定のデータページの1つまたは複数のリドゥログレコードで指定された変更を適用して、特定のデータページの最新のコピーを生成することを含んでよい。例えば、ストレージシステムノードは、特定のデータページの取り出されたコピーに、今までストレージシステムノードによって受信されたが、特定のデータページにまだ適用されていない特定のデータページをターゲットとするありとあらゆるリドゥログレコードを適用してよい。いったんストレージシステムノードが特定のデータページの最新のコピーを作成すると、ストレージシステムノードは、(1250でのように)データページの最新のコピーとして、データベースエンジン(または他のストレージシステムクライアント)に特定のデータページの新規に作成されたコピーを返してよい。読取り動作を実行するための図12に示される動作が、読取り要求を受信することに応えて自動的に(例えば、ユーザー介入なしに)ストレージシステムで実行されてよいことに留意されたい。
上述されたように、保護グループ(PG)は、セグメントの集合体によって形成される耐久性の単位を表す抽象分散エンティティである。いくつかの実施形態では、保護グループは、ボリュームの中の1つまたは複数のエクステントを表してよい。保護グループは、1つまたは複数のエクステントのためのインタフェースを曝露してよく、1つまたは複数のセグメント及び関連付けられたメタデータをカプセル化し(隠して)よい。保護グループは、保護グループ向けに構成される耐久性方針に従って、保護グループが暴露するエクステントの耐久性を維持することに責任を負ってよい。いくつかの実施形態では、保護グループは永続エクステントデータに冗長なセグメントを使用することによって、及び係る冗長性を積極的に維持することによって、その構成するエクステントすべての耐久性を達成してよい。保護グループが基礎的なセグメントの上にエクステント読取り動作/書込み動作をマッピングする方法は、エクステントのユーザーにとって不透明であってよい。異なる冗長性戦略が、エクステントミラーリング、エクステントイレージャコーディング、及び/またはレイジーレプリケーション(lazy replication)を含むが、これに限定されるものではない異なる実施形態で利用されてよい。
「ミラーリングされた保護グループ」とは、構成するセグメントのそれぞれが単一のエクステントの同期ミラーリングコピーである保護グループである。このモデルでは、変更が保護グループの中の影響を受けるすべての同期ミラーリングセグメントで耐久的にされると、変更は耐久的と見なされる。保護グループは、単一の可用性ゾーンの中で、または複数の可用性ゾーンに渡って形成されてよい。例えば、ある特定の可用性ゾーンの中のセグメントだけをカプセル化する保護グループの場合、保護グループの可用性は関連付けられた可用性ゾーンの可用性に直接的に結び付けられてよい。いくつかの実施形態では、領域保護グループは複数の可用性ゾーンに渡ってセグメントをカプセル化してよい。いくつかの係る実施形態では、領域保護グループは、各AZから1つ、対応するAZ保護グループの集合体として実装されてよい。
保護グループを含む分散型データベース最適化ストレージシステムで読取り動作及び書込み動作を実行するための方法の一実施形態が、図13の流れ図によって示される。1310で示されるように、この例では、方法は、データベース階層のデータベースエンジンヘッドノードが(例えば、データベースクライアントから)データベーステーブルのデータレコードに向けられた書込み要求を受信することを含んでよい。例えば、書込み要求は、新しいデータレコードがデータベーステーブルに(またはデータベーステーブルの特定のデータページに)追加されるべきであることを指定してよい、またはデータベーステーブルの特定のデータページの既存のデータレコードに対する修正を指定してよい。書込み要求を受信することに応えて、方法は、データベースエンジンヘッドノード(またはより詳細にはデータベースエンジンヘッドノード上のクライアント側ストレージサービスドライバ)が、1320でのように、要求が向けられる特定のデータページを記憶する分散型データベース最適化ストレージシステムの保護グループの2つ以上のストレージノードに、リドゥログレコードを送信する(が、書込み要求が向けられる特定のデータページのコピーを送信しない)ことを含んでよい。
この例に示されるように、データベースエンジンヘッドノード(またはより詳細にはデータベースエンジンヘッドノード上のクライアント側ストレージサービスドライバ)が、保護グループのストレージノードの選抜グループから書き込みが無事に完了した旨の肯定応答を受信するまで、データベースエンジンヘッドノードは、保護グループのストレージノードの選抜グループから書込み肯定応答を受信するのを待機してよい。これは、1330からの否定の終了から1330への入力へのフィードバックによって図13に示される。いったんデータベースエンジンヘッドノードが保護グループのストレージノードの選抜グループから書込み肯定応答を受信すると(1330からの肯定の終了として示される)、方法は、1340でのように、データベースエンジンヘッドノードが要求者に(例えば、データベースクライアントに)対応する書込み肯定応答を返すことを含んでよい。いくつかの実施形態では、書込み肯定応答が所定の期間内に保護グループのストレージノードの選抜グループから受信されない場合、データベースエンジンヘッドノード(またはより詳細にはデータベースエンジンヘッドノード上のクライアント側ストレージサービスドライバ)は、保護グループのストレージノードの内の1つまたは複数が故障した(もしくは、劣化している)またはなんらかの他のエラー状態がストレージシステムに存在すると決定するように構成されてよいことに留意されたい。
図13に示されるように、方法は、(例えば、書込み要求を受信し、書込み要求に応答することの後のなんらかの時点で)、データベースエンジンヘッドノード(またはより詳細にはデータベースエンジンヘッドノード上のクライアント側ストレージサービスドライバ)が(1350でのように)特定のデータページに向けられる読取り要求を受信することを含んでよい。読取り要求を受信することに応えて、方法は、データベースエンジンヘッドノード(またはより詳細にはデータベースエンジンヘッドノード上のクライアント側ストレージサービスドライバ)が、(1360でのように)特定のデータページを記憶する保護グループの2つ以上のストレージノードに読取り要求を送信することを含んでよい。
この例に示されるように、データベースエンジンヘッドノード(またはより詳細にはデータベースエンジンヘッドノード上のクライアント側ストレージサービスドライバ)が、保護グループのストレージノードの選抜グループから特定のデータページのカレントコピーを受信するまで、データベースエンジンヘッドノードは保護グループのストレージノードの選抜グループから特定のデータページのカレントコピーを受信するのを待機してよい。例えば、いくつかの実施形態では、保護グループのストレージノードの内の1つまたは複数は特定のデータページのカレントコピーを記憶しないことがあり、応答の前に(例えば、合体動作で)特定のデータページの初期バージョンに1つまたは複数の未決のリドゥログレコードを適用することによって特定のデータページのカレントコピーを作成しなければならないことがある。これは、1370からの否定の終了から1370への入力へのフィードバックによって図13に示される。いったんデータベースエンジンヘッドノードが、保護グループのストレージノードの選抜グループから特定のデータページのカレントコピーを受信すると(1370からの肯定の終了として示される)、方法は、データベースエンジンヘッドノードが、1380でのように、要求者に(例えば、データベースクライアントに)データページのカレントコピーを返すことを含んでよい。いくつかの実施形態では、特定のデータページのカレントコピーが所定の期間内に保護グループのストレージノードの選抜グループから受信されない場合、データベースエンジンヘッドノード(またはより詳細にはデータベースエンジンヘッドノード上のクライアント側ストレージサービスドライバ)は、保護グループのストレージノードの1つまたは複数が故障した(もしくは劣化している)こと、またはなんらかの他のエラー状態がストレージシステムに存在することを決定するように構成されてよいことに留意する。また、書込み動作を実行するための、または読取り動作を実行するための図13に示される動作は、そのようにする要求を受信することに応えて自動的に(例えば、ユーザー介入なしに)データベースシステムで実行されてよいことにも留意されたい。
いくつかの既存のデータベースシステムは、すべてのデータページをディスクに周期的にフラッシュする(例えば、5分ごとに1回ページのすべてをチェックポイントする)。係るシステムでは、クラッシュがある場合、システムは、前回データページがフラッシュされた以降多くの変更が向けられたデータページのカレントバージョンを作成し直すために多数のリドゥログレコードをリプレイしなければならない可能性がある。例えば、これは、入信命令が電子商取引アプリケーションで受信されるたびにシーケンス番号が増分されるページ等、多数の変更が継続的に向けられるキャッシュ内のホットデータページに当てはまることがある。システムに記憶されているすべてのデータページを一度にチェックポイントとする代わりに、本明細書に説明されるシステムでは、チェックポイントは、データベースまたはセグメント単位でよりむしろ、データブロック(例えば、データページ)単位で実行されてよい。例えば、いくつかの実施形態では、チェックポイントは各ストレージノードで実行されてよく、特定のストレージノードに記憶されるデータページのそれぞれが、それが保証されるとき(例えば、リドゥログレコードの数それ自体のリドゥログが所定数に達するとき)だけに、ストレージノードでデータページの新しいバージョン(例えば、そのデータページのチェックポイント)を作成するために合体してよい。係る実施形態では、データベース階層はチェックポイントにまったく関与していなくてもよい。代わりに、チェックポイントは、ストレージノード自体の責任である分散プロセス(例えば、バックグラウンドプロセス)であってよい。チェックポイントは(各ストレージノードに影響を及ぼす他のフォアグラウンド活動及び/またはバックグラウンド活動に対する可視性を有してよい)記憶階層上のバックグラウンドプロセスによって実行されてよいため、いくつかの実施形態では、記憶階層(または記憶階層のストレージシステムサーバノードの1つ)は、それが別のフォアグラウンドプロセスまたはバックグラウンドプロセスによって非常にロードされている場合、特定のストレージノードのためのチェックポイント動作を延期するように構成されてよい。いくつかの実施形態では、チェックポイント動作を延期することは、チェックポイントがフォアグラウンドレーテンシに悪影響を及ぼすのを妨げてよい。
いくつかの実施形態では、(例えば、本明細書に説明されるデータ構造等の)多様なメモリ内データ構造が、セグメントが機能するために必要とされてよい。いくつかの実施形態では、これらのメモリ内構造は、すべてのログページのフルスキャンを行うことによって(例えば、クラッシュに続く)起動中に構築されてよい。いくつかの実施形態では、これらのメモリ内データ構造のいくつかの周期的なチェックポイントは、クラッシュに続く起動時間を短縮するために実行されてよい。
いくつかの既存のデータベースシステムでは、データベース階層は、変更が受信されているのと同じ頻度で、ストレージ層にデータページを書き出す必要があってよく、それ以外の場合、キャッシュが、ストレージ層にまだ書き出されていない汚れたページを十分に得る場合、より多くの変更を受け入れるためにページはフラッシュされなければならないことがあり、このことがシステムにレーテンシをもたらす。対照的に、本明細書に説明されるシステムでは、データベースエンジンヘッドノードのキャッシュ内のデータページのリドゥログが分散型ストレージシステムに渡され(書込み肯定応答が受信され)る限り、データベース階層はそのキャッシュから、(ストレージ層によっていつでも再構築できる)データページを立ち退かせてよい。
本明細書に説明されるシステムのいくつかの実施形態では、クラッシュ回復動作、フラッシュバック動作、及びポイントインタイムリストア動作は、リドゥログまたはアンドゥログのどちらかのリプレイを必要としないことがある。代わりに、該動作は、インスタンスの構築、カレントボリュームLSNの適切なコミットポイントへのリセット、及びデータベースサービスの再起動を含んでよい。
本明細書に説明されるデータベースシステムは、いくつかの実施形態では、以前のデータベーススケーリング手法に関連付けられる不利な点(例えば、複雑度及び/またはコストに関して不利な点)のいくつかを被ることなく、いくつかの既存のデータベースよりも大きなデータベーステーブル及び/またはより高いスループットに対処するためにスケーリングされてよい。例えば、いくつかの実施形態では、ボリュームサイズに対して実際の制限はないことがあり、ボリュームは(例えば、セグメントの追加の保護グループを加えることによって)可用性の損失または性能の変化なしに動的に成長できてよい。さらに、書込みトラフィックがセグメント全体で拡散されることを仮定すると、IOPSは実質的に際限なしにされてよい。例えば、いくつかの実施形態では、IOPSは、新しい書き込みが記憶階層に転送される間に、必要な再ストライピングがバックグラウンドで実行されている状態で、現在実行中のデータベースの性能に影響を与えることなく増加または減少してよい。係る実施形態では、クエリー性能は、バックアップ動作または再ミラーリングの間にIOトラフィックをフリーズする必要なく、予測可能且つ一貫性があるようにされてよい。代わりに、記憶階層は、ストライピング、ミラーリング、及び熱管理を管理し、これらの責任をデータベース階層または管理者から取り除いてよい。
本明細書に説明されるように、記憶階層でのすべての書込みは、データベース階層へ肯定応答される前に永続媒体で耐久的にされてよい。これは大規模な電力事象での論理的な破損を妨げてよく、係る場合にバックアップから復旧する必要性を取り除いてよい。いくつかの実施形態では、バックアップからの復旧が必要とされる唯一のときは、カスタマエラー(例えば、テーブルの偶然の削除、または同等)に応えてであってよい。
いくつかの実施形態では、複製動作は、データブロックではなくログレコードの移動を伴うので、複製の性能の影響は他のデータベースシステムにおいてよりはるかに低くてよい。さらに、可用性ゾーン全体での書込みの調整は記憶階層で実行されてよく、同期複製のための確保されたデータベーススタンバイノードの使用を必要としなくてよく、このことが既存のデータベースシステムと比較してコストを削減してよい。
本明細書に説明される方法は、多様な実施形態では、ハードウェア及びソフトウェアの任意の組合せによって実装されてよい。例えば、一実施形態では、方法は、プロセッサに結合されたコンピュータ可読記憶媒体に記憶されるプログラム命令を実行する1台または複数のプロセッサを含むコンピュータシステムによって実装されてよい。プログラム命令は、本明細書に説明される機能性(例えば、本明細書に説明されるデータベースサービス/システム及び/またはストレージサービス/システムを実装する多様なサーバ及び他の構成要素の機能性)を実装するように構成されてよい。
図14は、多様な実施形態に従って、本明細書に説明されるデータベースシステムの少なくとも一部を実装するように構成されるコンピュータシステムを示すブロック図である。例えば、コンピュータシステム1400は、異なる実施形態で、データベース階層のデータベースエンジンヘッドノード、またはデータベース階層のクライアントの代わりにデータベーステーブル及び関連付けられたメタデータを記憶する別個の分散型データベース最適化ストレージシステムの複数のストレージノードの内の1つを実装するように構成されてよい。コンピュータシステム1400は、パーソナルコンピュータシステム、デスクトップコンピュータ、ラップトップコンピュータまたはノートパソコン、メインフレームコンピュータシステム、ハンドヘルドコンピュータ、ワークステーション、ネットワークコンピュータ、消費者装置、アプリケーションサーバ、ストレージデバイス、電話、携帯電話、または一般的に任意のタイプのコンピューティング装置を含むが、これに限定されることがない多様なタイプの装置のいずれかであってよい。
コンピュータシステム1400は、入出力(I/O)インタフェース1430を介してシステムメモリ1420に結合される(いずれかが、単一スレッドまたはマルチスレッドであってよい複数のコアを含んでよい)1台または複数のプロセッサ1410を含む。コンピュータシステム1400は、I/Oインタフェース1430に結合されるネットワークインタフェース1440をさらに含む。多様な実施形態では、コンピュータシステム1400は、1台のプロセッサ1410を含んだユニプロセッサシステム、または数台のプロセッサ1410(例えば、2,4、8、または別の適切な数)を含んだマルチプロセッサシステムであってよい。プロセッサ1410は、命令を実行できる任意の適切なプロセッサであってよい。例えば、多様な実施形態では、プロセッサ1410は、x86、PowerPC、SPARC、もしくはMIPS ISA等のさまざまな命令セットアーキテクチャ(ISA)または任意の他の適切なISAのいずれかを実装する汎用プロセッサまたは組み込みプロセッサであってよい。マルチプロセッサシステムでは、プロセッサ1410のそれぞれが、一般に同じISAを実装してよいが、必ずしも同じISAを実装しないこともある。コンピュータシステム1400は、通信ネットワーク(例えば、インターネット、LAN等)上で他のシステム及び/または構成要素と通信するための1台または複数のネットワーク通信装置(例えば、ネットワークインタフェース1440)も含む。例えば、システム1400で実行中のクライアントアプリケーションは、単一のサーバ上、または本明細書で説明されるデータベースシステムの構成要素の内の1つまたは複数の実装するサーバのクラスタ上で実行中のサーバアプリケーションと通信するためにネットワークインタフェース1440を使用してよい。別の例では、コンピュータシステム1400上で実行中のサーバアプリケーションのインスタンスは、他のコンピュータシステム(例えば、コンピュータシステム1490)の上で実装されてよいサーバアプリケーション(または別のサーバアプリケーション)の他のインスタンスと通信するために、ネットワークインタフェース1440を使用してよい。
示されている実施形態では、コンピュータシステム1400は、1台または複数の永続ストレージデバイス1460及び/または1台または複数のI/Oデバイス1480も含む。多様な実施形態では、永続ストレージデバイス1460は、ディスクドライブ、テープドライブ、ソリッドステートメモリ、他の大容量記憶装置、または任意の他の永続ストレージデバイスに相当してよい。コンピュータシステム1400(または、コンピュータシステム1400上で動作する分散アプリケーションもしくはオペレーティングシステム)は、所望されるように、命令及び/またはデータを永続ストレージデバイス1460に記憶してよく、必要に応じて記憶されている命令及び/またはデータを取り出してよい。例えば、いくつかの実施形態では、コンピュータシステム1400は、ストレージシステムサーバノードをホストしてよく、永続記憶装置1460はそのサーバノードにアタッチされるSSDを含んでよい。
コンピュータシステム1400は、プロセッサ(複数の場合がある)1410によってアクセス可能な命令及びデータを記憶するように構成される1つまたは複数のシステムメモリ1420を含む。多様な実施形態では、システムメモリ1420は、任意の適切なメモリ技術(例えば、キャッシュ、スタティックランダムアクセスメモリ(SRAM)、DRAM、RDRAM、EDO RAM,DDR 10RAM、同期ダイナミックRAM(SDRAM)、Rambus RAM、EEPROM、不揮発性/フラッシュタイプメモリ、または任意の他のタイプのメモリの内の1つまたは複数)を使用して実装されてよい。システムメモリ1420は、本明細書に説明される方法及び技法を実装するためにプロセッサ(複数の場合がある)1410によって実行可能であるプログラム命令1425を含んでよい。多様な実施形態では、プログラム命令1425は、プラットホームネイティブバイナリ、JavaTMバイトコード等の任意のインタープリター型言語で、またはC/C++、JavaTM等の任意の他の言語で、またはその任意の組合せで符号化されてよい。例えば、示されている実施形態では、プログラム命令1425は、データベース階層のデータベースエンジンヘッドノードの、または異なる実施形態で、データベース階層のクライアントの代わりにデータベーステーブル及び関連付けられたメタデータを記憶する別個の分散型データベース最適化ストレージシステムの複数のストレージノードの内の1つの機能性を実装するために実行可能なプログラム命令を含む。いくつかの実施形態では、プログラム命令1425は、複数の別個のクライアント、サーバノード、及び/または他の構成要素を実装してよい。
いくつかの実施形態では、プログラム命令1425が、UNIX(登録商標)、LINUX(登録商標)、SolarisTM、MacOSTM、WindowsTM等の多様なオペレーティングシステムの内のいずれかであってよいオペレーティングシステム(不図示)を実装するために実行可能な命令を含んでよい。プログラム命令1425のいずれかまたはすべては、多様な実施形態に従ってプロセスを実行するためにコンピュータシステム(または他の電子機器)をプログラミングするために使用されてよい、その上に記憶されている命令を有する非一過性のコンピュータ可読記憶媒体を含んでよいコンピュータプログラム製品、つまりソフトウェアとして提供されてよい。非一過性のコンピュータ可読記憶媒体は、マシン(例えば、コンピュータ)によって読取り可能な形(例えば、ソフトウェア、処理アプリケーション)をとる情報を記憶するための任意の機構を含んでよい。一般的に言えば、非一過性のコンピュータアクセス可能記憶媒体は、例えばI/Oインタフェース1430を介してコンピュータシステム1400に結合される、ディスクまたはDVD/CD−ROM等の磁気媒体または光学媒体等の、コンピュータ可読記憶媒体または記憶媒体を含んでよい。また、非一過性のコンピュータ可読記憶媒体は、コンピュータシステム1400のいくつかの実施形態では、システムメモリ1420または別のタイプのメモリとして含まれてよい、RAM(例えば、SDRAM、DDR SDRAM、SDRAM、RDRAM、SRAM等)、ROM等の任意の揮発性媒体または不揮発性媒体を含んでもよい。他の実施形態では、プログラム命令は、ネットワークインタフェース1440を介して実装されてよい等、ネットワークリンク及び/または無線リンク等の通信媒体を介して伝達される、光信号、音響信号、または他の形の伝搬信号(例えば、搬送波、赤外線信号、デジタル信号等)を使用して通信されてよい。
いくつかの実施形態では、システムメモリ1420は、本明細書に説明されるように構成されてよいデータストア1445を含んでよい。例えば、本明細書に説明されるデータベース階層の機能を実行する際に使用されるトランザクションログ、アンドゥログ、キャッシュに入れられたページデータ、または他の情報等の、データベース階層によって(例えば、データベースエンジンヘッドノード上に)記憶されるとして本明細書に説明される情報は、データストア1445にもしくは1つまたは複数のノード上のシステムメモリ1420の別の部分に、永続記憶装置1460に、及び/または1つまたは複数のリモートストレージデバイス1470に異なるときに及び多様な実施形態で記憶されてよい。同様に、記憶階層によって記憶されているとして本明細書に説明される情報(例えば、本明細書に説明される分散型ストレージシステムの機能を実行する上で使用されるリドゥログレコード、合体データページ、及び/または他の情報)は、データストア1445にもしくは1つまたは複数のノード上のシステムメモリ1420の別の部分に、永続記憶装置1460に、及び/または1つまたは複数のリモートストレージデバイス1470に異なるときに及び多様な実施形態で記憶されてよい。一般に、システムメモリ1420(例えば、システムメモリ1420の中のデータストア1445)、永続記憶装置1460、及び/またはリモートストレージ1470は、データブロック、データブロックのレプリカ、データブロックと関連付けられたメタデータ、及び/またはその状態、データベース構成情報、及び/または本明細書に説明される方法及び技法を実装する上で使用できる任意の他の情報を記憶してよい。
一実施形態では、I/Oインタフェース1430は、プロセッサ1410と、システムメモリ1420と、ネットワークインタフェース1440または他の周辺インタフェースを通してを含んだシステムのあらゆる周辺装置との間のI/Oトラフィックを調整するように構成されてよい。いくつかの実施形態では、I/Oインタフェース1430は、1つの構成要素(例えば、システムメモリ1420)から別の構成要素(例えば、プロセッサ1410)による使用に適したフォーマットにデータ信号を変換するために任意の必要なプロトコル、タイミング、または他のデータ媒体変換を実行してよい。いくつかの実施形態では、I/Oインタフェース1430は、例えばペリフェラルコンポーネントインターコネクト(PCI)バス規格、またはユニバーサルシリアルバス(USB)規格の変形等の多様なタイプの周辺バスを通してアタッチされるデバイスに対するサポートを含んでよい。いくつかの実施形態では、I/Oインタフェース1430の機能は、例えばノースブリッジ及びサウスブリッジ等、2つ以上の別々の構成要素に分割されてよい。また、いくつかの実施形態では、システムメモリ1420へのインタフェース等、I/Oインタフェース1430の機能性のいくつかまたはすべては、プロセッサ1410の中に直接的に組み込まれてよい。
ネットワークインタフェース1440は、例えば、コンピュータシステム1400と、(本明細書に説明される1つまたは複数のストレージシステムサーバノード、データベースエンジンヘッドノード、及び/またはデータベースシステムのクライアントを実装してよい)他のコンピュータシステム1490等の、ネットワークにアタッチされる他のデバイスとの間でデータを交換できるように構成されてよい。さらに、ネットワークインタフェース1440は、コンピュータシステム1400と多様なI/O装置1450及び/またはリモートストレージ1470との間の通信を可能にするように構成されてよい。入出力装置1450は、いくつかの実施形態では、1つまたは複数のディスプレイ端末、キーボード、キーパッド、タッチパッド、スキャン装置、音声認識装置もしくは光学認識装置、または1つまたは複数のコンピュータシステム1400によってデータを入力するまたは取り出すために適した任意の他の装置を含んでよい。複数の入出力装置1450は、コンピュータシステム1400に存在してよい、またはコンピュータシステム1400を含む分散型システムの多様なノードで分散されてよい。いくつかの実施形態では、類似する入出力装置はコンピュータシステム1400とは別個であってよく、ネットワークインタフェース1440上で等、有線接続または無線接続を通してコンピュータシステム1400を含む分散型システムの1つまたは複数のノードと対話してよい。ネットワークインタフェース1440は、一般に1つまたは複数の無線ネットワークプロトコル(例えば、Wi−Fi/IEEE 802.11、または別の無線ネットワーキング規格)をサポートしてよい。ただし、多様な実施形態では、ネットワークインタフェース1440は、例えば他のタイプのイーサネット(登録商標)ネットワーク等、任意の適切な有線汎用データネットワークまたは無線汎用データネットワークを介する通信をサポートしてよい。さらに、ネットワークインタフェース1440は、Fibre Channel SAN等のストレージエリアネットワークを介して、または任意の他の適切なタイプのネットワーク及び/またはプロトコルを介して、アナログ音声ネットワークまたはデジタルファイバ通信ネットワーク等の電気通信ネットワーク/電話網を介する通信をサポートしてよい。多様な実施形態では、コンピュータシステム1400は、図14に示される構成要素より多い、少ない、または異なる構成要素(例えば、ディスプレイ、ビデオカード、オーディオカード、周辺装置、ATMインタフェース、イーサネットインタフェース、フレームリレーインタフェース等の他のネットワークインタフェース等)を含んでよい。
本明細書に説明される分散型システムの実施形態のいずれも、またはその構成要素のいずれも1つまたは複数のウェブサービスとして実装されてよいことに留意されたい。例えば、データベースシステムのデータベース階層の中のデータベースエンジンヘッドノードは、データベースサービス、及び/または本明細書に説明される分散型ストレージシステムを利用する他のタイプのデータストレージサービスをウェブサービスとしてのクライアントに提示してよい。いくつかの実施形態では、ウェブサービスは、ネットワーク上で相互運用可能なマシン対マシンの対話をサポートするように設計されたソフトウェアシステム及び/またはハードウェアシステムによって実装されてよい。ウェブサービスは、ウェブサービス記述言語(WSDL)等のマシン処理可能なフォーマットで記述されるインタフェースを有してよい。他のシステムは、ウェブサービスのインタフェースの記述によって規定される方法でウェブサービスと対話してよい。例えば、ウェブサービスは、他のシステムが呼び出してよい多様な動作を定義してよく、多様な動作を要求するときに他のシステムが準拠することを期待されてよい特定のアプリケーションプログラミングインタフェース(API)を定義してよい。
多様な実施形態では、ウェブサービスは、ウェブサービス要求と関連付けられるパラメータ及び/またはデータを含むメッセージを使用することによって要求されてよい、または呼び出されてよい。係るメッセージは、拡張マークアップ言語(XML)等の特定のマークアップ言語に従ってフォーマットされてよい、及び/またはシンプルオブジェクトアクセスプロトコル(SOAP)等のプロトコルを使用してカプセル化されてよい。ウェブサービス要求を実行するために、ウェブサービスクライアントは、要求を含むメッセージをアセンブルし、ハイパテキスト転送プロトコル(HTTP)等のインターネットベースのアプリケーション層転送プロトコルを使用して、メッセージをウェブサービスに対応するアドレス可能なエンドポイント(例えば、ユニフォームリソースロケータ(URL))に伝達してよい。
いくつかの実施形態では、ウェブサービスは、メッセージベースの技法よりむしろ、表象状態転送(「RESTful」)技法を使用して実装されてよい。例えば、RESTful技法に従って実装されるウェブサービスは、SOAPメッセージの中でカプセル化されるよりむしろ、PUT、GET、またはDELETE等のHTTP方法の中に含まれるパラメータを通して呼び出されてよい。
以下の実施形態は以下の節を鑑みてさらによう理解されてよい。
1.それぞれが少なくとも1台のプロセッサ及びメモリを備える複数のコンピューティングノード
を含み、
複数のコンピューティングノードの1つまたは複数がデータベースサービスを実装するように構成され、データベースサービスがデータベースエンジンヘッドノードを含み、
複数のコンピューティングノードの2つ以上の他のコンピューティングノードが、1台または複数のストレージデバイスにそれぞれのデータページとしてデータベーステーブルの部分を記憶する分散型ストレージサービスのサーバノードを実装するように構成され、
データベースエンジンヘッドノードが、
データベースサービスのクライアントから、データベーステーブルの所与のデータレコードに向けられる書込み要求であって、所与のデータレコードに加えられる修正を指定する書込み要求を受信する、
所与のデータレコードに加えられる修正を表すリドゥログレコードを生成する、
所与のデータレコードを含むデータページのバージョンを記憶する分散型ストレージサービスの特定のサーバノードに、所与のデータレコードを含むデータページを送信しないが、リドゥログレコードを送信する
ように構成され、
分散型ストレージサービスの特定のサーバノードが、
データベースエンジンヘッドノードからリドゥログレコードを受信する、
1台または複数のストレージデバイスにリドゥログレコードを書き込む、
データベースエンジンヘッドノードに、リドゥログレコードが書き込まれた旨の肯定応答を返す、及び
肯定応答を返すことの後に、
データページのカレントバージョンを生成するために、分散型ストレージサービスの特定のサーバノードが、データページの以前に記憶されたバージョンに、受信されたリドゥログレコード及びデータページへの修正を表す1つまたは複数の他のリドゥログレコードを適用するように構成される、所与のデータレコードを含むデータページのカレントバージョンを生成する、及び
1台または複数のストレージデバイスにデータページのカレントバージョンを書き込む
ように構成される、
コンピューティングシステム。
2.データベースエンジンヘッドノードが、
データベースクライアントから、所与のデータレコードを含んだデータページを読み取る要求を受信する、
データページを読み取る要求を受信することに応えて、分散型ストレージサービスの特定のサーバノードにデータページのカレントバージョンに対する要求を送信する
ようにさらに構成される、節1に記載のコンピューティングシステム。
3.分散型ストレージサービスの特定のサーバノードが、
データベースエンジンヘッドノードから、所与のデータレコードを含んだデータページのカレントバージョンに対する要求を受信する、及び
データページのカレントバージョンに対する要求を受信することに応えて、データベースエンジンヘッドノードにデータページのカレントバージョンを返す
ようにさらに構成される、節2に記載のコンピューティングシステム。
4.データページのカレントバージョンを生成することが、データページのカレントバージョンに対する要求を受信することに応えて実行される、節3に記載のコンピューティングシステム。
5.データベースエンジンヘッドノードが、分散型ストレージシステムのためのクライアント側ドライバを含み、
分散型ストレージシステムの特定のサーバノードにリドゥログレコードを送信するために、クライアント側ドライバが、
所与のデータレコードを含んだデータページのバージョンを記憶する分散型ストレージサービスの特定のサーバノードを決定する、及び
データベースサービスの代わりに分散型ストレージシステムの特定のサーバノードにリドゥログレコードを送信する
ように構成される、節1に記載のコンピューティングシステム。
6.それぞれが少なくとも1台のプロセッサ及びメモリを備える1つまたは複数のコンピューティングノードであって、1つまたは複数のコンピューティングノードがデータベースサービスを集合的に実装するように構成され、データベースサービスがデータベースエンジンヘッドノード及び分散型ストレージシステムへのインタフェースを含む、1つまたは複数のコンピューティングノード
を含み、
データベースエンジンヘッドノードが、
データベースサービスのクライアントから、データベーステーブルの所与のデータレコードに向けられる書込み要求であって、所与のデータレコードに加えられる修正を指定する書込み要求を受信する、
所与のデータレコードに加えられる修正を表すリドゥログレコードを生成する、
インタフェースを介して、所与のデータレコードを含んだデータページのバージョンを記憶する分散型ストレージサービスの特定のサーバノードに、所与のデータレコードを含んだデータページを送信しないが、リドゥログレコードを送信する、
インタフェースを介して、リドゥログレコードが分散型ストレージサービスに書き込まれた旨の肯定応答を受信する、及び
データベースクライアントに、要求された書込みが実行されたことを示す応答を返す
ように構成される、システム。
7.データベースエンジンヘッドノードが、
データベースサービスのクライアントから、所与のデータレコードを含んだデータページを読み取る要求を受信する、及び
データページを読み取る要求を受信することに応えて、
インタフェースを介して、分散型ストレージサービスの特定のサーバノードにデータページのカレントバージョンに対する要求を送信する、
インタフェースを介して、データページのカレントバージョンを受信する、及び
そこからデータページを読み取る要求が受信されたクライアントに、データページのカレントバージョンを返す
ようにさらに構成される、節6に記載のシステム。
8.データベースエンジンヘッドノードが、最近アクセスされたデータページを記憶するキャッシュを含み、
データベースエンジンヘッドノードが、データページのカレントバージョンがキャッシュに存在しないと決定することに応えて、特定のサーバノードにデータページのカレントバージョンに対する要求を送信するように構成される、
節7に記載のシステム。
9.データベースエンジンヘッドノードが、最近アクセスされたデータページを記憶するキャッシュを含み、
キャッシュが所与のデータレコードを含んだデータページのコピーを記憶し、
データベースエンジンヘッドノードが、データページのキャッシュに入れられたコピーの所与のデータレコードに、書込み要求で指定される修正を適用するようにさらに構成される、
節6に記載のシステム。
10.データベースエンジンヘッドノードが、
リドゥログレコードを送信する前に、特定のサーバノードを決定することが分散型ストレージシステムへのインタフェースによって実行される、所与のデータレコードを含んだデータページのバージョンを記憶する分散型ストレージサービスの特定のサーバノードを決定する
ようにさらに構成される、節6に記載のシステム。
11.データベースエンジンヘッドノードが、
データベースサービスの1つまたは複数のクライアントから、データベーステーブルに向けられる2つ以上の追加の書込み要求を受信する、及び
2つ以上の追加の書込み要求を提供することが、データベーステーブルをターゲットとするトランザクションの原子性、独立性、及び一貫性のプロパティを強化することを含む、2つ以上の追加の書込み要求を提供する
ようにさらに構成される、節6に記載のシステム。
12.それぞれが少なくとも1台のプロセッサ及びメモリを含む1つまたは複数のコンピューティングノードであって、1つまたは複数のコンピューティングノードが、分散型ストレージサービスのクライアントの代わりに、1台または複数のストレージデバイスにデータブロックを記憶する分散型ストレージサービスを集合的に実装するように構成される、1つまたは複数のコンピューティングノード
を含み、
1つまたは複数のコンピューティングノードの所与のコンピューティングノードが、
クライアントから、所与のコンピューティングノードに記憶される特定のデータブロックの更新レコードであって、特定のデータブロックに加えられる修正を指定する更新レコードを受信する、
1台または複数のストレージデバイスの1つまたは複数に更新レコードを書き込む、
クライアントに、生成される特定のデータブロックのカレントバージョンを、または特定のデータブロックに適用される更新レコードに指定される修正を待機することなく、更新レコードが書き込まれた旨の肯定応答を返す
ように構成される、システム。
13.肯定応答を返すことの後に、1つまたは複数のコンピューティングノードの所与のコンピューティングノードが、
更新レコードに応じて、特定のデータブロックのカレントバージョンを生成する、及び
1台または複数のストレージデバイスの1つまたは複数に特定のデータブロックのカレントバージョンを書き込む
ようにさらに構成される、節12に記載のシステム。
14.特定のデータブロックのカレントバージョンを生成するために、所与のコンピューティングノードが、特定のデータブロックの以前に記憶されたバージョンに更新レコードを適用するように構成される、節13に記載のシステム。
15.特定のデータブロックのカレントバージョンを生成するために、所与のコンピューティングノードが特定のデータブロックの以前に記憶されたバージョンに、特定のデータブロックの以前に記憶されたバージョンが書き込まれた以降に受信された特定のデータブロックに対する修正を表す1つまたは複数の他の更新レコードを適用するようにさらに構成される、節14に記載のシステム。
16.特定のデータブロックのカレントバージョンを生成するために、所与のコンピューティングノードが特定のデータブロックの以前に記憶されたバージョンに、更新レコード及び1つまたは複数の他の更新レコードを適用するためにバックグラウンドプロセスを実行するように構成され、一方フォアグラウンドプロセスが分散型ストレージサービスによって記憶されるデータブロックをターゲットとする読取り要求及び書込み要求を受信する、節13に記載のシステム。
17.1つまたは複数のコンピューティングノードの所与のコンピューティングノードが、
クライアントから、データブロックをターゲットとする読取り要求を受信するようにさらに構成され、
特定のデータブロックのカレントバージョンを生成することが、読取り要求を受信することに応えて実行される、
節13に記載のシステム。
18.1つまたは複数のコンピューティングノードの別のコンピューティングノードが、特定のデータブロックを記憶し、
1つまたは複数のコンピューティングノードの他のコンピューティングノードが、
クライアントから、特定のデータブロックの更新レコードを受信する、
1台または複数のストレージデバイスの別のストレージデバイスに更新レコードを書き込む、
クライアントに、更新レコードが書き込まれた旨の別の肯定応答を返す、及び
他の肯定応答を返すことの後に、
特定のデータブロックのカレントバージョンを生成するために、所与のコンピューティングノードが特定のデータブロックの以前に記憶されたバージョンに、受信された更新レコードを適用するように構成される、特定のデータブロックのカレントバージョンを生成する、及び
1台または複数のストレージデバイスの別のストレージデバイスに特定のデータブロックのカレントバージョンを書き込む
ように構成される、節12に記載のシステム。
19.1台または複数のコンピュータで実行されるときに、1台または複数のコンピュータに、
分散型ストレージシステムに記憶されるデータブロックをターゲットとする書込み要求であって、データブロックに加えられる修正を指定する書込み要求を含んだクエリーを受信することと、
データブロックに加えられる修正を表すリドゥログレコードを生成することと、
データブロックを記憶する分散型ストレージシステムのノードを決定することと、
分散型ストレージシステムの決定されたノードにリドゥログレコードを送信するが、データブロックのコピーを送信しないことと、
分散型ストレージシステムの決定されたノードから、リドゥログレコードが決定されたノードのストレージデバイスに書き込まれた旨の肯定応答を受信することと、
を実行させる、プログラム命令を記憶する非一過性のコンピュータ可読記憶媒体。
20.1台または複数のコンピュータで実行されるときに、プログラム命令が、1台または複数のコンピュータに、リドゥログを上記生成する前に、
クエリーをパースすることと、
クエリー実行計画を生成することと、
をさらに実行させる、節19に記載の非一過性のコンピュータ可読記憶媒体。
21.1台または複数のコンピュータで実行されるときに、プログラム命令が、1台または複数のコンピュータに、
データブロックを記憶する分散型ストレージシステムの1つまたは複数の他のノードを決定することであって、1つまたは複数の他のノードが決定されたノードと同じ保護グループの一部である、決定することと、
分散型ストレージシステムの1つまたは複数の他のノードに、リドゥログレコードを送信するが、データブロックのコピーを送信しないことと、
をさらに実行させる、節19に記載の非一過性のコンピュータ可読記憶媒体。
22.1台または複数のコンピュータで実行されるときに、プログラム命令が、1台または複数のコンピュータに、
保護グループのノードの選抜グループから、ノードの選抜グループのノードのそれぞれのストレージデバイスにリドゥログレコードが書き込まれた旨の肯定応答を受信することと、
ノードの選抜グループから肯定応答を受信することに応えて、そこからクエリーが受信されたクライアントに、書込み要求がコミットされたことを示すクエリー応答を返すことと、
をさらに実行させる、節21に記載の非一過性のコンピュータ可読記憶媒体。
23.クエリーがデータベースサービスから受信される、節19に記載の非一過性のコンピュータ可読記憶媒体。
24.1台または複数のコンピュータで実行されるときに、1台または複数のコンピュータに、
それぞれが1台または複数のストレージデバイスを含んだ1つまたは複数のストレージシステムサーバノードに、データベーステーブルのデータレコードを含んだ複数のデータページを記憶することと、
特定のデータページに向けられるリドゥログレコードを受信することと、
ストレージデバイスの1台または複数にリドゥログレコードを記憶することと、
特定のデータページのために合体動作が保証されることを決定することと、
上記決定することに応えて、
特定のデータページのために合体動作を実行することであって、合体動作を実行することが、特定のデータページのカレントバージョンを生成するために、特定のデータページの以前に生成されたバージョンに、リドゥログレコード及び1つまたは複数の他のリドゥログレコードを適用することを含む、実行することと、
特定のデータページのカレントバージョンを、ストレージデバイスの1つまたは複数記憶することと、
を実行させる、プログラム命令を記憶する非一過性のコンピュータ可読記憶媒体。
25.1つまたは複数のコンピュータで実行されるときに、プログラム命令が、1台または複数のコンピュータに、
特定のデータページに向けられる読取り要求を受信することと、
読取り要求を受信することに応えて、特定のデータページのカレントバージョンを返すことと、
をさらに実行させる、節24に記載の非一過性のコンピュータ可読記憶媒体。
26.合体動作が保証されることを上記決定することが、受信されているが、まだ特定のデータページに適用されていない特定のデータページに向けられるリドゥログレコードの数が合体動作のための所定の閾値を超えると決定することを含む、節24に記載の非一過性のコンピュータ可読記憶媒体。
27.合体動作が保証されることを上記決定することが、ノードまたはストレージデバイスが故障したと決定することを含む、節24に記載の非一過性のコンピュータ可読記憶媒体。
28.1台または複数のコンピュータで実行されるときに、プログラム命令が1台または複数のコンピュータに、
別のデータページに向けられる別のリドゥログレコードを受信することと、
ストレージデバイスの1台または複数に他のリドゥログレコードを記憶することと、
合体動作が他のデータページのために保証されていないと決定することと、
上記決定することに応えて、他のデータページのために合体動作を実行することを控えることと、
を実行させる、節24に記載の非一過性のコンピュータ可読記憶媒体。
図に示され、本明細書に説明される多様な方法は、方法の例の実施形態を表す。方法は、ソフトウェアで、ハードウェアで、またはソフトウェア及びハードウェアの組合せで手動で実装されてよい。任意の方法の順序は変更されてよく、多様な要素が追加、再順序付け、結合、省略、修正等、されてよい。
上記実施形態はかなり詳細に説明されているが、いったん上記開示が完全に理解されると当業者に明らかになるように、多数の変形形態及び修正形態が加えられてよい。続く特許請求の範囲が、すべての係る修正形態及び変更を包含すると解釈され、したがって上記説明は制限的な意味よりむしろ例示的な意味で考えられることが意図される。

Claims (15)

  1. それぞれが少なくとも1台のプロセッサ及びメモリを備える複数のコンピューティングノード
    を備え、
    前記複数のコンピューティングノードの1つまたは複数がデータベースサービスを実装するように構成され、前記データベースサービスがデータベースエンジンヘッドノードを備え、
    前記複数のコンピューティングノードの2つ以上の他のコンピューティングノードが、1台または複数のストレージデバイスにそれぞれのデータページとしてデータベーステーブルの部分を記憶する分散型ストレージサービスのサーバノードを実装するように構成され、
    前記データベースエンジンヘッドノードが、
    前記データベースサービスのクライアントから、データベーステーブルの所与のデータレコードに向けられる書込み要求であって、前記所与のデータレコードに加えられる修正を指定する前記書込み要求を受信する、
    前記所与のデータレコードに加えられる前記修正を表すリドゥログレコードを生成する、
    前記所与のデータレコードを備える前記データページのバージョンを記憶する前記分散型ストレージサービスの特定のサーバノードに、前記所与のデータレコードを備えるデータページを送信しないが、前記リドゥログレコードを送信する
    ように構成され、
    前記分散型ストレージサービスの前記特定のサーバノードが、
    前記データベースエンジンヘッドノードから前記リドゥログレコードを受信する、
    1台または複数のストレージデバイスに前記リドゥログレコードを書き込む、
    前記データベースエンジンヘッドノードに、前記リドゥログレコードが書き込まれた旨の肯定応答を返す、及び
    前記肯定応答を返すことの後に
    前記所与のデータレコードを備える前記データページのカレントバージョンを生成し、前記データページの前記カレントバージョンを生成するために、前記分散型ストレージサービスの前記特定のサーバノードが、前記データページの以前に記憶されたバージョンに、前記受信されたリドゥログレコード及び前記データページへの修正を表す1つまたは複数の他のリドゥログレコードを適用するように構成される及び
    1台または複数のストレージデバイスに前記データページの前記カレントバージョンを書き込む
    ように構成され
    前記データベースエンジンヘッドノードは、さらに、
    前記分散型ストレージサービスの前記特定のサーバノードからの前記肯定応答の受信に基づいて、前記クライアントへ、前記要求された書込みが実行されたことを示す応答を返すように構成される、
    コンピューティングシステム。
  2. 前記データベースエンジンヘッドノードが、
    データベースクライアントから、前記所与のデータレコードを備える前記データページを読み取る要求を受信する、
    前記データページを読み取る前記要求を受信することに応えて、前記分散型ストレージサービスの前記特定のサーバノードに前記データページのカレントバージョンに対する要求を送信する
    ようにさらに構成される、請求項1に記載の前記コンピューティングシステム。
  3. 前記データベースエンジンヘッドノードが、前記分散型ストレージサービスのためのクライアント側ドライバを備え、
    前記分散型ストレージサービスの前記特定のサーバノードに前記リドゥログレコードを送信するために、前記クライアント側ドライバが、
    前記所与のデータレコードを備える前記データページのバージョンを記憶する前記分散型ストレージサービスの前記特定のサーバノードを決定する、及び
    前記データベースサービスの代わりに前記分散型ストレージサービスの前記特定のサーバノードに前記リドゥログレコードを送信する
    ように構成される、請求項1に記載の前記コンピューティングシステム。
  4. それぞれが少なくとも1台のプロセッサ及びメモリを備える1つまたは複数のコンピューティングノードであって、前記1つまたは複数のコンピューティングノードがデータベースサービスを集合的に実装するように構成され、前記データベースサービスがデータベースエンジンヘッドノード及び分散型ストレージサービスへのインタフェースを備える、1つまたは複数のコンピューティングノード
    を備え、
    前記データベースエンジンヘッドノードが、
    前記データベースサービスのクライアントから、データベーステーブルの所与のデータレコードに向けられる書込み要求であって、前記所与のデータレコードに加えられる修正を指定する前記書込み要求を受信する、
    前記所与のデータレコードに加えられる前記修正を表すリドゥログレコードを生成する、
    前記インタフェースを介して、前記所与のデータレコードを備えるータページのバージョンを記憶する前記分散型ストレージサービスの特定のサーバノードに、前記所与のデータレコードを備える前記データページを送信しないが、前記リドゥログレコードを送信する、
    前記インタフェースを介して、前記リドゥログレコードが前記分散型ストレージサービスに書き込まれた旨の肯定応答を受信する、及び
    前記肯定応答の受信に基づいて、前記データベースサービスのクライアントに、前記要求された書込みが実行されたことを示す応答を返す
    ように構成される、システム。
  5. 前記データベースエンジンヘッドノードが、
    前記データベースサービスのクライアントから、前記所与のデータレコードを備える前記データページを読み取る要求を受信する、
    前記データページを読み取る前記要求を受信することに応えて、
    前記インタフェースを介して、前記分散型ストレージサービスの前記特定のサーバノードに、前記データページのカレントバージョンに対する要求を送信する、
    前記インタフェースを介して、前記データページの前記カレントバージョンを受信する、及び
    そこから前記データページを読み取る前記要求が受信された前記クライアントに、前記データページの前記カレントバージョンを返す、
    ようにさらに構成される、請求項4に記載の前記システム。
  6. 前記データベースエンジンヘッドノードが、最近アクセスされたデータページを記憶するキャッシュを備え、
    前記データベースエンジンヘッドノードが、前記データページのカレントバージョンが前記キャッシュに存在しないと決定することに応えて、前記特定のサーバノードに前記データページの前記カレントバージョンに対する前記要求を送信するように構成される、
    請求項5に記載の前記システム。
  7. 前記データベースエンジンヘッドノードが、最近アクセスされたデータページを記憶するキャッシュを備え、
    前記キャッシュが、前記所与のデータレコードを備える前記データページのコピーを記憶し、
    前記データベースエンジンヘッドノードが、前記データページの前記キャッシュに入れられたコピーの前記所与のデータレコードに、前記書込み要求で指定される前記修正を適用するようにさらに構成される、請求項4に記載の前記システム。
  8. 前記データベースエンジンヘッドノードが、
    前記リドゥログレコードを送信する前に、前記特定のサーバノードを決定することが前記分散型ストレージサービスへの前記インタフェースによって実行される、前記所与のデータレコードを備える前記データページのバージョンを記憶する前記分散型ストレージサービスの前記特定のサーバノードを決定する
    ようにさらに構成される、請求項4に記載の前記システム。
  9. 前記データベースエンジンヘッドノードが、
    前記データベースサービスの1つまたは複数のクライアントから、前記データベーステーブルに向けられる2つ以上の追加の書込み要求を受信する、
    前記2つ以上の追加の書込み要求を提供することが、前記データベーステーブルをターゲットとするトランザクションの原子性、独立性、及び一貫性のプロパティを強化することを含む、前記2つ以上の追加の書込み要求を提供する
    ようにさらに構成される、請求項4に記載の前記システム。
  10. それぞれが少なくとも1台のプロセッサ及びメモリを備える1つまたは複数のコンピューティングノードであって、前記1つまたは複数のコンピューティングノードが、分散型ストレージサービスのクライアントの代わりに1台または複数のストレージデバイスにデータブロックを記憶する前記分散型ストレージサービスを集合的に実装するように構成される、前記1つまたは複数のコンピューティングノード
    を備え、
    前記1つまたは複数のコンピューティングノードの所与のコンピューティングノードが、
    前記クライアントから、前記所与のコンピューティングノードに記憶される特定のデータブロックの更新レコードであって、前記特定のデータブロックに加えられる修正を指定する前記更新レコードを受信するが、前記修正が加えられた前記特定のデータブロックを受信しない
    前記1台または複数のストレージデバイスの1つまたは複数に前記更新レコードを書き込む、及び
    前記クライアントに、生成される前記特定のデータブロックのカレントバージョンを、または前記特定のデータブロックに適用される前記更新レコードに指定される前記修正を待機することなく、前記更新レコードが書き込まれた旨の肯定応答を返す
    ように構成される、システム。
  11. 前記肯定応答を返すことの後に、前記1つまたは複数のコンピューティングノードの前記所与のコンピューティングノードが、
    前記更新レコードに応じて、前記特定のデータブロックのカレントバージョンを生成する、及び
    前記1台または複数のストレージデバイスの1つまたは複数に前記特定のデータブロックの前記カレントバージョンを書き込む
    ようにさらに構成される、請求項10に記載の前記システム。
  12. 前記特定のデータブロックの前記カレントバージョンを生成するために、前記所与のコンピューティングノードが、前記特定のデータブロックの以前に記憶されたバージョンに前記更新レコードを適用するように構成される、請求項11に記載の前記システム。
  13. 前記特定のデータブロックの前記カレントバージョンを生成するために、前記所与のコンピューティングノードが、前記特定のデータブロックの以前に記憶されたバージョンに、前記更新レコード及び1つまたは複数の他の更新レコードを適用するためにバックグラウンドプロセスを実行するように構成され、一方フォアグラウンドプロセスが前記分散型ストレージサービスによって記憶されるデータブロックをターゲットとする読取り要求または書き込み要求を受信する、請求項11に記載の前記システム。
  14. 前記1つまたは複数のコンピューティングノードの前記所与のコンピューティングノードが、
    前記クライアントから、前記データブロックをターゲットとする読取り要求を受信するようにさらに構成され、
    前記特定のデータブロックの前記カレントバージョンを生成することが、前記読取り要求を受信することに応えて実行される、
    請求項11に記載の前記システム。
  15. 前記1つまたは複数のコンピューティングノードの別のコンピューティングノードが前記特定のデータブロックを記憶し、
    前記1つまたは複数のコンピューティングノードの前記のコンピューティングノードが、
    前記クライアントから、前記特定のデータブロックの前記更新レコードを受信する、
    前記1台または複数のストレージデバイスの別のストレージデバイスに前記更新レコードを書き込む、
    前記クライアントに、前記更新レコードが書き込まれた旨の別の肯定応答を返す、及び、
    前記の肯定応答を返すことの後に、
    前記特定のデータブロックのカレントバージョンを生成するために、前記所与のコンピューティングノードが、前記特定のデータブロックの以前に記憶されたバージョンに、前記受信された更新レコードを適用するように構成される、前記特定のデータブロックの前記カレントバージョンを生成する、及び
    前記1台または複数のストレージデバイスの別のストレージデバイスに前記特定のデータブロックの前記カレントバージョンを書き込む
    ように構成される、請求項10に記載の前記システム。
JP2016501278A 2013-03-15 2014-03-11 データベースエンジンを備えたデータベースシステム及び別個の分散型ストレージサービス Active JP6346937B2 (ja)

Applications Claiming Priority (5)

Application Number Priority Date Filing Date Title
US201361794572P 2013-03-15 2013-03-15
US61/794,572 2013-03-15
US14/201,493 2014-03-07
US14/201,493 US9514007B2 (en) 2013-03-15 2014-03-07 Database system with database engine and separate distributed storage service
PCT/US2014/023542 WO2014150538A1 (en) 2013-03-15 2014-03-11 Database system with database engine and separate distributed storage service

Related Child Applications (1)

Application Number Title Priority Date Filing Date
JP2018101278A Division JP6661696B2 (ja) 2013-03-15 2018-05-28 データベースエンジンを備えたデータベースシステム及び別個の分散型ストレージサービス

Publications (2)

Publication Number Publication Date
JP2016511486A JP2016511486A (ja) 2016-04-14
JP6346937B2 true JP6346937B2 (ja) 2018-06-20

Family

ID=51532995

Family Applications (2)

Application Number Title Priority Date Filing Date
JP2016501278A Active JP6346937B2 (ja) 2013-03-15 2014-03-11 データベースエンジンを備えたデータベースシステム及び別個の分散型ストレージサービス
JP2018101278A Active JP6661696B2 (ja) 2013-03-15 2018-05-28 データベースエンジンを備えたデータベースシステム及び別個の分散型ストレージサービス

Family Applications After (1)

Application Number Title Priority Date Filing Date
JP2018101278A Active JP6661696B2 (ja) 2013-03-15 2018-05-28 データベースエンジンを備えたデータベースシステム及び別個の分散型ストレージサービス

Country Status (8)

Country Link
US (5) US9514007B2 (ja)
EP (2) EP2973054B1 (ja)
JP (2) JP6346937B2 (ja)
KR (2) KR101923334B1 (ja)
CN (2) CN105122241B (ja)
AU (2) AU2014237083B2 (ja)
CA (2) CA2906415C (ja)
WO (1) WO2014150538A1 (ja)

Families Citing this family (141)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US11544288B2 (en) 2010-12-23 2023-01-03 Mongodb, Inc. Systems and methods for managing distributed database deployments
US11615115B2 (en) 2010-12-23 2023-03-28 Mongodb, Inc. Systems and methods for managing distributed database deployments
US10262050B2 (en) 2015-09-25 2019-04-16 Mongodb, Inc. Distributed database systems and methods with pluggable storage engines
US8996463B2 (en) 2012-07-26 2015-03-31 Mongodb, Inc. Aggregation framework system architecture and method
US10366100B2 (en) 2012-07-26 2019-07-30 Mongodb, Inc. Aggregation framework system architecture and method
US8572031B2 (en) 2010-12-23 2013-10-29 Mongodb, Inc. Method and apparatus for maintaining replica sets
US10977277B2 (en) 2010-12-23 2021-04-13 Mongodb, Inc. Systems and methods for database zone sharding and API integration
US10346430B2 (en) 2010-12-23 2019-07-09 Mongodb, Inc. System and method for determining consensus within a distributed database
US10740353B2 (en) 2010-12-23 2020-08-11 Mongodb, Inc. Systems and methods for managing distributed database deployments
US10713280B2 (en) 2010-12-23 2020-07-14 Mongodb, Inc. Systems and methods for managing distributed database deployments
US9805108B2 (en) 2010-12-23 2017-10-31 Mongodb, Inc. Large distributed database clustering systems and methods
US9740762B2 (en) 2011-04-01 2017-08-22 Mongodb, Inc. System and method for optimizing data migration in a partitioned database
US9881034B2 (en) 2015-12-15 2018-01-30 Mongodb, Inc. Systems and methods for automating management of distributed databases
US10698775B2 (en) 2016-05-31 2020-06-30 Mongodb, Inc. Method and apparatus for reading and writing committed data
US10614098B2 (en) 2010-12-23 2020-04-07 Mongodb, Inc. System and method for determining consensus within a distributed database
US10997211B2 (en) 2010-12-23 2021-05-04 Mongodb, Inc. Systems and methods for database zone sharding and API integration
US10872095B2 (en) 2012-07-26 2020-12-22 Mongodb, Inc. Aggregation framework system architecture and method
US11544284B2 (en) 2012-07-26 2023-01-03 Mongodb, Inc. Aggregation framework system architecture and method
US11403317B2 (en) 2012-07-26 2022-08-02 Mongodb, Inc. Aggregation framework system architecture and method
US9514007B2 (en) * 2013-03-15 2016-12-06 Amazon Technologies, Inc. Database system with database engine and separate distributed storage service
CN103729442B (zh) * 2013-12-30 2017-11-24 华为技术有限公司 记录事务日志的方法和数据库引擎
US9213485B1 (en) 2014-06-04 2015-12-15 Pure Storage, Inc. Storage system architecture
US11399063B2 (en) * 2014-06-04 2022-07-26 Pure Storage, Inc. Network authentication for a storage system
US11652884B2 (en) 2014-06-04 2023-05-16 Pure Storage, Inc. Customized hash algorithms
US9836234B2 (en) 2014-06-04 2017-12-05 Pure Storage, Inc. Storage cluster
US10574754B1 (en) 2014-06-04 2020-02-25 Pure Storage, Inc. Multi-chassis array with multi-level load balancing
US10949401B2 (en) * 2014-06-25 2021-03-16 Vmware, Inc. Data replication in site recovery environment
US9473461B2 (en) * 2014-11-25 2016-10-18 International Business Machines Corporation Transparent tunneling architecture for a secured database
US10884869B2 (en) 2015-04-16 2021-01-05 Nuodb, Inc. Backup and restore in a distributed database utilizing consistent database snapshots
US9916338B2 (en) * 2015-04-24 2018-03-13 International Business Machines Corporation Managing data records
US10282364B2 (en) 2015-04-28 2019-05-07 Microsoft Technology Licensing, Llc. Transactional replicator
US10868665B1 (en) * 2015-05-18 2020-12-15 Amazon Technologies, Inc. Mitigating timing side-channel attacks by obscuring accesses to sensitive data
US10311229B1 (en) 2015-05-18 2019-06-04 Amazon Technologies, Inc. Mitigating timing side-channel attacks by obscuring alternatives in code
US10061852B1 (en) * 2015-05-19 2018-08-28 Amazon Technologies, Inc. Transparent proxy tunnel caching for database access
US10180954B2 (en) 2015-05-29 2019-01-15 Nuodb, Inc. Disconnected operation within distributed database systems
US10067969B2 (en) * 2015-05-29 2018-09-04 Nuodb, Inc. Table partitioning within distributed database systems
US10496669B2 (en) 2015-07-02 2019-12-03 Mongodb, Inc. System and method for augmenting consensus election in a distributed database
US10423626B2 (en) 2015-09-25 2019-09-24 Mongodb, Inc. Systems and methods for data conversion and comparison
US10394822B2 (en) 2015-09-25 2019-08-27 Mongodb, Inc. Systems and methods for data conversion and comparison
US10846411B2 (en) 2015-09-25 2020-11-24 Mongodb, Inc. Distributed database systems and methods with encrypted storage engines
US10673623B2 (en) 2015-09-25 2020-06-02 Mongodb, Inc. Systems and methods for hierarchical key management in encrypted distributed databases
CN106855822A (zh) * 2015-12-08 2017-06-16 阿里巴巴集团控股有限公司 用于分布式事务处理的方法及设备
EP3391223B1 (en) * 2015-12-16 2020-01-29 AB Initio Technology LLC High throughput, high reliability data processing system
US10152527B1 (en) * 2015-12-28 2018-12-11 EMC IP Holding Company LLC Increment resynchronization in hash-based replication
CN105760452B (zh) * 2016-02-04 2020-03-10 深圳市嘉力达实业有限公司 一种高并发海量数据的采集、处理和存储的方法及系统
WO2017163426A1 (ja) * 2016-03-25 2017-09-28 富士通株式会社 中継装置、中継方法及び中継プログラム
US10387248B2 (en) 2016-03-29 2019-08-20 International Business Machines Corporation Allocating data for storage by utilizing a location-based hierarchy in a dispersed storage network
US11349922B2 (en) 2016-04-06 2022-05-31 Marvell Asia Pte Ltd. System and method for a database proxy
US10237350B2 (en) * 2016-04-06 2019-03-19 Reniac, Inc. System and method for a database proxy
US11157517B2 (en) * 2016-04-18 2021-10-26 Amazon Technologies, Inc. Versioned hierarchical data structures in a distributed data store
CN105897915B (zh) * 2016-05-23 2022-09-09 珠海格力电器股份有限公司 一种数据接收服务器、及数据处理系统
US10116725B2 (en) * 2016-05-27 2018-10-30 Intuit Inc. Processing data retrieval requests in a graph projection of an application programming interfaces (API)
US10776220B2 (en) 2016-06-27 2020-09-15 Mongodb, Inc. Systems and methods for monitoring distributed database deployments
CN106897338A (zh) * 2016-07-04 2017-06-27 阿里巴巴集团控股有限公司 一种针对数据库的数据修改请求处理方法及装置
US10366106B2 (en) * 2016-12-09 2019-07-30 Sap Se Quorum-based replication of data records
US10783136B1 (en) * 2017-02-28 2020-09-22 Virtuozzo International Gmbh Management of garbage data in distributed systems
US10769034B2 (en) * 2017-03-07 2020-09-08 Sap Se Caching DML statement context during asynchronous database system replication
CN106951488B (zh) * 2017-03-14 2021-03-12 海尔优家智能科技(北京)有限公司 一种日志记录方法和装置
US10423342B1 (en) 2017-03-30 2019-09-24 Amazon Technologies, Inc. Scaling events for hosting hierarchical data structures
US10860550B1 (en) 2017-03-30 2020-12-08 Amazon Technologies, Inc. Versioning schemas for hierarchical data structures
US10671639B1 (en) 2017-03-30 2020-06-02 Amazon Technologies, Inc. Selectively replicating changes to hierarchial data structures
KR102301257B1 (ko) * 2017-04-11 2021-09-10 휴렛-팩커드 디벨롭먼트 컴퍼니, 엘.피. 블록체인 부분 원장
US10909143B1 (en) * 2017-04-14 2021-02-02 Amazon Technologies, Inc. Shared pages for database copies
US10866868B2 (en) 2017-06-20 2020-12-15 Mongodb, Inc. Systems and methods for optimization of database operations
US11016990B2 (en) * 2017-08-02 2021-05-25 Salesforce.Com, Inc. Fencing out nodes in a distributed clustered system
CN110019066A (zh) * 2017-09-21 2019-07-16 阿里巴巴集团控股有限公司 数据库处理方法及装置、系统
CN110069505B (zh) * 2017-09-21 2021-12-24 张锐 离线数据处理方法及离线数据更新装置
US11914571B1 (en) 2017-11-22 2024-02-27 Amazon Technologies, Inc. Optimistic concurrency for a multi-writer database
US10725983B2 (en) 2017-12-29 2020-07-28 Huawei Technologies Co., Ltd. Systems and methods for database management using append-only storage devices
US10902016B2 (en) 2018-02-12 2021-01-26 Artem Shamsutdinov Autonomous interdependent repositories
CN110362547B (zh) * 2018-04-02 2023-10-03 杭州阿里巴巴智融数字技术有限公司 日志文件的编码、解析、存储方法和装置
CN108897634A (zh) * 2018-06-13 2018-11-27 郑州云海信息技术有限公司 一种linux操作系统日志容错方法及系统
US20200034472A1 (en) * 2018-07-27 2020-01-30 Futurewei Technologies, Inc. Asynchronous cache coherency for mvcc based database systems
US11991273B2 (en) 2018-09-04 2024-05-21 International Business Machines Corporation Storage device key management for encrypted host data
US11038698B2 (en) 2018-09-04 2021-06-15 International Business Machines Corporation Securing a path at a selected node
US11025413B2 (en) 2018-09-04 2021-06-01 International Business Machines Corporation Securing a storage network using key server authentication
US11038671B2 (en) 2018-09-04 2021-06-15 International Business Machines Corporation Shared key processing by a storage device to secure links
US10764291B2 (en) 2018-09-04 2020-09-01 International Business Machines Corporation Controlling access between nodes by a key server
US10833856B2 (en) 2018-09-04 2020-11-10 International Business Machines Corporation Automatic re-authentication of links using a key server
US11088829B2 (en) 2018-09-04 2021-08-10 International Business Machines Corporation Securing a path at a node
US10833860B2 (en) 2018-09-04 2020-11-10 International Business Machines Corporation Shared key processing by a host to secure links
US11044312B2 (en) 2018-09-21 2021-06-22 Microsoft Technology Licensing, Llc Storage segment server covered cache
US10877868B2 (en) * 2018-09-21 2020-12-29 Microsoft Technology Licensing, Llc Applying a log to storage segments
US10802926B2 (en) 2018-09-21 2020-10-13 Microsoft Technology Licensing, Llc Accessing prior storage segment server state
US11455292B2 (en) * 2018-09-21 2022-09-27 Microsoft Technology Licensing, Llc Brokering persisted and unpersisted log records
CN110955653A (zh) * 2018-09-26 2020-04-03 阿里巴巴集团控股有限公司 一种数据页面的处理方法、装置、设备及计算机系统
GB201816837D0 (en) * 2018-10-16 2018-11-28 Microsoft Technology Licensing Llc Database management
US12093276B1 (en) * 2018-11-23 2024-09-17 Amazon Technologies, Inc. Emulating a non-relational database on a relational database with a distributed data store
US11106541B2 (en) * 2019-03-15 2021-08-31 Huawei Technologies Co., Ltd System and method for replicating data in distributed database systems
US11176004B2 (en) * 2019-04-01 2021-11-16 Sap Se Test continuous log replay
CN111797062B (zh) * 2019-04-09 2023-10-27 华为云计算技术有限公司 数据处理方法、装置和分布式数据库系统
CN110134665B (zh) * 2019-04-17 2021-05-25 北京百度网讯科技有限公司 基于流量镜像的数据库自学习优化方法及装置
US11100109B2 (en) 2019-05-03 2021-08-24 Microsoft Technology Licensing, Llc Querying data in a distributed storage system
CN110188140A (zh) * 2019-05-09 2019-08-30 广州视源电子科技股份有限公司 数据拉取方法、装置、存储介质和计算机设备
CN110213357B (zh) * 2019-05-22 2022-04-22 深圳壹账通智能科技有限公司 业务数据回退方法、装置、计算机设备和存储介质
CN112015586B (zh) * 2019-05-28 2024-04-26 华为云计算技术有限公司 一种数据重构计算的方法以及相关装置
US11288123B2 (en) * 2019-07-31 2022-03-29 Stratus Technologies Ireland Ltd. Systems and methods for applying checkpoints on a secondary computer in parallel with transmission
EP3695328A4 (en) 2019-09-12 2020-12-09 Alibaba Group Holding Limited NEWSPAPER STRUCTURE STORAGE SYSTEMS
SG11202002732TA (en) 2019-09-12 2020-04-29 Alibaba Group Holding Ltd Log-structured storage systems
SG11202002587TA (en) 2019-09-12 2020-04-29 Alibaba Group Holding Ltd Log-structured storage systems
CN111566611B (zh) 2019-09-12 2023-08-04 创新先进技术有限公司 日志结构存储系统
EP3682344A4 (en) 2019-09-12 2020-12-02 Advanced New Technologies Co., Ltd. ENERGY STORAGE SYSTEMS
WO2019228571A2 (en) 2019-09-12 2019-12-05 Alibaba Group Holding Limited Log-structured storage systems
EP3695304B1 (en) * 2019-09-12 2023-04-12 Advanced New Technologies Co., Ltd. Log-structured storage systems
US10942852B1 (en) 2019-09-12 2021-03-09 Advanced New Technologies Co., Ltd. Log-structured storage systems
SG11202002775RA (en) 2019-09-12 2020-04-29 Alibaba Group Holding Ltd Log-structured storage systems
CN112925473B (zh) * 2019-12-06 2024-06-04 阿里巴巴集团控股有限公司 数据存储方法、装置、设备及存储介质
CN111324665B (zh) * 2020-01-23 2023-06-27 阿里巴巴集团控股有限公司 一种日志回放方法及装置
US11514015B2 (en) * 2020-01-30 2022-11-29 Salesforce.Com, Inc. Reducing requests using probabilistic data structures
CN111290714B (zh) * 2020-02-06 2023-09-05 北京百度网讯科技有限公司 数据读取方法和装置
EP4088196A4 (en) 2020-02-18 2023-06-14 Sony Group Corporation COMMON DATABASE ARCHITECTURE TO SUPPORT LARGE TRANSACTIONS AND NODE ARCHIVING ON A MAAS PLATFORM
CN113010480B (zh) * 2020-03-26 2024-03-19 腾讯科技(深圳)有限公司 日志处理方法、装置、电子设备及计算机可读存储介质
US11561864B1 (en) 2020-03-26 2023-01-24 Amazon Technologies, Inc. Creating database clones at a specified point-in-time
CN111444147B (zh) * 2020-03-30 2023-05-12 上海达梦数据库有限公司 一种数据页创建方法、装置、终端设备及存储介质
US11341163B1 (en) 2020-03-30 2022-05-24 Amazon Technologies, Inc. Multi-level replication filtering for a distributed database
US11429595B2 (en) 2020-04-01 2022-08-30 Marvell Asia Pte Ltd. Persistence of write requests in a database proxy
US11625370B2 (en) 2020-04-07 2023-04-11 Vmware, Inc. Techniques for reducing data log recovery time and metadata write amplification
US11334277B2 (en) * 2020-04-07 2022-05-17 Vmware Inc. Issuing efficient writes to erasure coded objects in a distributed storage system with two tiers of storage
US11467746B2 (en) 2020-04-07 2022-10-11 Vmware, Inc. Issuing efficient writes to erasure coded objects in a distributed storage system via adaptive logging
US11334276B2 (en) * 2020-04-07 2022-05-17 Vmware Inc. Using segment pre-allocation to support large segments
CN111930692B (zh) * 2020-05-28 2022-05-13 武汉达梦数据库股份有限公司 一种基于日志解析同步的事务合并执行方法及装置
US11556545B2 (en) * 2020-07-24 2023-01-17 Sap Se Disk based hybrid transactional analytical processing system
CN111880969B (zh) * 2020-07-30 2024-06-04 上海达梦数据库有限公司 存储节点恢复方法、装置、设备和存储介质
CN112084265B (zh) * 2020-09-11 2024-07-30 北京金山云网络技术有限公司 一种日志数据同步方法、装置、服务器及存储介质
CN112231119B (zh) * 2020-10-16 2024-01-30 广西科技大学 一种基于分布式的云管理系统数据中台服务设计方法
US11455219B2 (en) 2020-10-22 2022-09-27 Oracle International Corporation High availability and automated recovery in scale-out distributed database system
EP4002148A1 (en) * 2020-11-23 2022-05-25 Sap Se Cloud-native object storage for page-based relational database
US11593352B2 (en) 2020-11-23 2023-02-28 Sap Se Cloud-native object storage for page-based relational database
CN112346913B (zh) * 2020-12-01 2024-03-15 上海达梦数据库有限公司 数据恢复方法、装置、设备及存储介质
US11947839B2 (en) * 2021-05-10 2024-04-02 Samsung Electronics Co., Ltd. Storage device, system, and method for customizable metadata
US11474719B1 (en) 2021-05-13 2022-10-18 Vmware, Inc. Combining the metadata and data address spaces of a distributed storage object via a composite object configuration tree
CN113282564B (zh) * 2021-07-24 2022-01-04 阿里云计算有限公司 数据存储方法、系统、节点和存储介质
CN113630273A (zh) * 2021-08-06 2021-11-09 百果园技术(新加坡)有限公司 账号注销系统、方法、设备及存储介质
US11853605B2 (en) 2021-09-17 2023-12-26 Micron Technology, Inc. Database persistence
CN113641424B (zh) * 2021-10-13 2022-02-01 北京安华金和科技有限公司 一种数据库操作的处理方法和系统
US12086118B2 (en) * 2021-11-15 2024-09-10 International Business Corporation Machines Chaining version data bi-directionally in data page to avoid additional version data accesses
CN115118583B (zh) * 2022-06-29 2024-03-26 北京奇艺世纪科技有限公司 日志查询方法、装置、电子设备及计算机可读存储设备
CN117687564A (zh) * 2022-09-05 2024-03-12 华为云计算技术有限公司 一种数据存储方法、装置及相关设备
CN116414579B (zh) * 2023-02-21 2024-05-10 北京友友天宇系统技术有限公司 基于分布式群组通信实现的多副本间数据一致性的方法
CN118708645A (zh) * 2023-03-17 2024-09-27 华为云计算技术有限公司 数据库访问方法、装置及计算机可读存储介质
CN117194566B (zh) * 2023-08-21 2024-04-19 泽拓科技(深圳)有限责任公司 多存储引擎数据复制方法、系统、计算机设备

Family Cites Families (169)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH03130842A (ja) 1989-10-17 1991-06-04 Toshiba Corp データベースシステムの同時実行制御装置
EP0465018B1 (en) 1990-06-29 1997-05-14 Oracle Corporation Method and apparatus for optimizing undo log usage
US5280612A (en) 1991-11-26 1994-01-18 International Business Machines Corporation Multiple version database concurrency control system
US5452445A (en) 1992-04-30 1995-09-19 Oracle Corporation Two-pass multi-version read consistency
US5530850A (en) 1993-10-25 1996-06-25 International Business Machines Corporation Data storage library array with log-structured file system which allows simultaneous write and garbage collection
EP0675451A3 (en) 1994-03-30 1996-12-04 Siemens Stromberg Carlson Distributed database architecture and system for managing a distributed database for development in an open network.
US5892917A (en) 1995-09-27 1999-04-06 Microsoft Corporation System for log record and log expansion with inserted log records representing object request for specified object corresponding to cached object copies
US5870758A (en) 1996-03-11 1999-02-09 Oracle Corporation Method and apparatus for providing isolation levels in a database system
US6041423A (en) 1996-11-08 2000-03-21 Oracle Corporation Method and apparatus for using undo/redo logging to perform asynchronous updates of parity and data pages in a redundant array data storage environment
US5974425A (en) * 1996-12-17 1999-10-26 Oracle Corporation Method and apparatus for reapplying changes to a database
JPH10254748A (ja) 1997-03-11 1998-09-25 Fujitsu Ltd 分散共有メモリ一貫性最適制御方法
US5907848A (en) 1997-03-14 1999-05-25 Lakeview Technology, Inc. Method and system for defining transactions from a database log
US7031987B2 (en) 1997-05-30 2006-04-18 Oracle International Corporation Integrating tablespaces with different block sizes
US5951695A (en) 1997-07-25 1999-09-14 Hewlett-Packard Company Fast database failover
US6240413B1 (en) 1997-12-22 2001-05-29 Sun Microsystems, Inc. Fine-grained consistency mechanism for optimistic concurrency control using lock groups
US7930278B2 (en) 1998-02-13 2011-04-19 Oracle International Corporation Methods to perform disk writes in a distributed shared disk system needing consistency across failures
US6233585B1 (en) 1998-03-12 2001-05-15 Crossworlds Software, Inc. Isolation levels and compensating transactions in an information system
US6205449B1 (en) 1998-03-20 2001-03-20 Lucent Technologies, Inc. System and method for providing hot spare redundancy and recovery for a very large database management system
US6185577B1 (en) * 1998-06-23 2001-02-06 Oracle Corporation Method and apparatus for incremental undo
US9239763B2 (en) * 2012-09-28 2016-01-19 Oracle International Corporation Container database
JP3763992B2 (ja) 1999-03-30 2006-04-05 富士通株式会社 データ処理装置及び記録媒体
US6615219B1 (en) 1999-12-29 2003-09-02 Unisys Corporation Database management system and method for databases having large objects
US6856993B1 (en) 2000-03-30 2005-02-15 Microsoft Corporation Transactional file system
KR100390853B1 (ko) 2000-06-07 2003-07-10 차상균 주 메모리 트랜잭션 처리 시스템에서 병렬적 회복 연산을 위한 디퍼런셜 로깅 방법 및 장치
US6631374B1 (en) 2000-09-29 2003-10-07 Oracle Corp. System and method for providing fine-grained temporal database access
EP1332444A4 (en) 2000-10-09 2005-10-12 Maximum Availability Ltd METHOD AND APPARATUS FOR PROCESSING DATA
US20020107835A1 (en) 2001-02-08 2002-08-08 Coram Michael T. System and method for adaptive result set caching
EP1366420B1 (en) 2001-03-07 2014-07-16 Oracle International Corporation Disk writes in a distributed shared disk system
US6832229B2 (en) 2001-03-09 2004-12-14 Oracle International Corporation System and method for maintaining large-grained database concurrency with a log monitor incorporating dynamically redefinable business logic
US20040249869A1 (en) 2001-06-25 2004-12-09 Kenneth Oksanen Method and system for restarting a replica of a database
US6957236B1 (en) 2002-05-10 2005-10-18 Oracle International Corporation Providing a useable version of a data item
US6732171B2 (en) 2002-05-31 2004-05-04 Lefthand Networks, Inc. Distributed network storage system with virtualization
US6792518B2 (en) 2002-08-06 2004-09-14 Emc Corporation Data storage system having mata bit maps for indicating whether data blocks are invalid in snapshot copies
US7305386B2 (en) 2002-09-13 2007-12-04 Netezza Corporation Controlling visibility in multi-version database systems
US7089253B2 (en) 2002-09-13 2006-08-08 Netezza Corporation Computer method and system for concurrency control using dynamic serialization ordering
US6976022B2 (en) 2002-09-16 2005-12-13 Oracle International Corporation Method and mechanism for batch processing transaction logging records
US8489742B2 (en) 2002-10-10 2013-07-16 Convergys Information Management Group, Inc. System and method for work management
US7308456B2 (en) 2002-12-19 2007-12-11 International Business Machines Corporation Method and apparatus for building one or more indexes on data concurrent with manipulation of data
US7010645B2 (en) 2002-12-27 2006-03-07 International Business Machines Corporation System and method for sequentially staging received data to a write cache in advance of storing the received data
CA2513503A1 (en) * 2003-01-17 2004-08-12 Tacit Networks, Inc. Method and system for use of storage caching with a distributed file system
US7937551B2 (en) 2003-01-21 2011-05-03 Dell Products L.P. Storage systems having differentiated storage pools
US7287034B2 (en) * 2003-05-08 2007-10-23 Oracle International Corporation On-demand multi-version data dictionary to support distributed applications
US20050015416A1 (en) 2003-07-16 2005-01-20 Hitachi, Ltd. Method and apparatus for data recovery using storage based journaling
US7328226B1 (en) 2003-06-30 2008-02-05 Symantec Operating Corporation Coordinated distributed log-based snapshots in a multi-host environment
US8095511B2 (en) 2003-06-30 2012-01-10 Microsoft Corporation Database data recovery system and method
JP2005050024A (ja) 2003-07-31 2005-02-24 Toshiba Corp 計算機システムおよびプログラム
US8799225B2 (en) 2003-11-05 2014-08-05 Lumigent Technologies, Inc. Process and system for auditing database activity
US7299378B2 (en) * 2004-01-15 2007-11-20 Oracle International Corporation Geographically distributed clusters
CN1784676B (zh) 2004-02-25 2012-05-30 微软公司 数据库数据恢复系统和方法
JP2005276094A (ja) 2004-03-26 2005-10-06 Hitachi Ltd 分散ストレージ装置のファイル管理方法及び分散ストレージシステム並びにプログラム
US7146386B2 (en) 2004-03-29 2006-12-05 Microsoft Corporation System and method for a snapshot query during database recovery
US7461101B2 (en) * 2004-07-13 2008-12-02 International Business Machines Corporation Method for reducing data loss and unavailability by integrating multiple levels of a storage hierarchy
US20060020634A1 (en) 2004-07-20 2006-01-26 International Business Machines Corporation Method, system and program for recording changes made to a database
US7650356B2 (en) 2004-08-24 2010-01-19 Microsoft Corporation Generating an optimized restore plan
US7403945B2 (en) * 2004-11-01 2008-07-22 Sybase, Inc. Distributed database system providing data and space management methodology
JP2006263581A (ja) 2005-03-24 2006-10-05 Mazda Motor Corp 排気ガス浄化用触媒
US7814057B2 (en) 2005-04-05 2010-10-12 Microsoft Corporation Page recovery using volume snapshots and logs
US7716645B2 (en) 2005-06-10 2010-05-11 International Business Machines Corporation Using atomic sets of memory locations
US7620660B2 (en) 2005-06-30 2009-11-17 Microsoft Corporation Pre-image logging for database recovery
US7873683B2 (en) 2005-07-01 2011-01-18 Qnx Software Systems Gmbh & Co. Kg File system having transaction record coalescing
US8688780B2 (en) 2005-09-30 2014-04-01 Rockwell Automation Technologies, Inc. Peer-to-peer exchange of data resources in a control system
US7885922B2 (en) 2005-10-28 2011-02-08 Oracle International Corporation Apparatus and method for creating a real time database replica
US8156083B2 (en) * 2005-12-01 2012-04-10 Oracle International Corporation Database system that provides for history-enabled tables
ES2582364T3 (es) 2005-12-19 2016-09-12 Commvault Systems, Inc. Sistemas y métodos para realizar replicación de datos
JP2007200182A (ja) 2006-01-30 2007-08-09 Hitachi Ltd ストレージ装置、及びストレージシステム
JP4800046B2 (ja) 2006-01-31 2011-10-26 株式会社日立製作所 ストレージシステム
JP5124989B2 (ja) 2006-05-26 2013-01-23 日本電気株式会社 ストレージシステム及びデータ保護方法とプログラム
US7882064B2 (en) 2006-07-06 2011-02-01 Emc Corporation File system replication
US8069191B2 (en) 2006-07-13 2011-11-29 International Business Machines Corporation Method, an apparatus and a system for managing a snapshot storage pool
US7587564B2 (en) 2006-09-26 2009-09-08 International Business Machines Corporation System, method and computer program product for managing data versions
US8935206B2 (en) 2007-01-31 2015-01-13 Hewlett-Packard Development Company, L.P. Snapshots in distributed storage systems
US8370715B2 (en) 2007-04-12 2013-02-05 International Business Machines Corporation Error checking addressable blocks in storage
US8086650B1 (en) 2007-06-15 2011-12-27 Ipswitch, Inc. Method for transforming and consolidating fields in log records from logs generated on different operating systems
US8266122B1 (en) * 2007-12-19 2012-09-11 Amazon Technologies, Inc. System and method for versioning data in a distributed data store
US8326897B2 (en) 2007-12-19 2012-12-04 International Business Machines Corporation Apparatus and method for managing data storage
EP2079020B1 (en) 2008-01-03 2013-03-20 Accenture Global Services Limited System amd method for automating ETL applications
US7979670B2 (en) 2008-01-24 2011-07-12 Quantum Corporation Methods and systems for vectored data de-duplication
US8296301B2 (en) 2008-01-30 2012-10-23 Commvault Systems, Inc. Systems and methods for probabilistic data classification
US8401994B2 (en) 2009-09-18 2013-03-19 Oracle International Corporation Distributed consistent grid of in-memory database caches
JP2011515727A (ja) 2008-02-12 2011-05-19 ネットアップ,インコーポレイテッド ハイブリッド媒体ストレージシステムアーキテクチャ
US7747663B2 (en) 2008-03-05 2010-06-29 Nec Laboratories America, Inc. System and method for content addressable storage
US8229945B2 (en) 2008-03-20 2012-07-24 Schooner Information Technology, Inc. Scalable database management software on a cluster of nodes using a shared-distributed flash memory
US8074014B2 (en) 2008-03-31 2011-12-06 Microsoft Corporation Storage systems using write off-loading
US8266114B2 (en) 2008-09-22 2012-09-11 Riverbed Technology, Inc. Log structured content addressable deduplicating storage
US8341128B1 (en) 2008-05-09 2012-12-25 Workday, Inc. Concurrency control using an effective change stack and tenant-based isolation
US9104662B2 (en) 2008-08-08 2015-08-11 Oracle International Corporation Method and system for implementing parallel transformations of records
US9842004B2 (en) 2008-08-22 2017-12-12 Red Hat, Inc. Adjusting resource usage for cloud-based networks
EP2350837A4 (en) 2008-09-15 2012-10-17 Virsto Software Corp STORAGE MANAGEMENT SYSTEM FOR VIRTUAL MACHINES
US8255373B2 (en) 2008-10-24 2012-08-28 Microsoft Corporation Atomic multiple modification of data in a distributed storage system
US9996572B2 (en) * 2008-10-24 2018-06-12 Microsoft Technology Licensing, Llc Partition management in a partitioned, scalable, and available structured storage
US8230228B2 (en) 2008-10-31 2012-07-24 International Business Machines Corporation Support of tamper detection for a log of records
US8229890B2 (en) 2008-12-15 2012-07-24 International Business Machines Corporation Opening document stored at multiple database replicas
US20100274750A1 (en) 2009-04-22 2010-10-28 Microsoft Corporation Data Classification Pipeline Including Automatic Classification Rules
US8429134B2 (en) * 2009-09-08 2013-04-23 Oracle International Corporation Distributed database recovery
WO2011031900A2 (en) 2009-09-09 2011-03-17 Fusion-Io, Inc. Apparatus, system, and method for power reduction management in a storage device
US8392479B1 (en) 2009-09-14 2013-03-05 Symantec Corporation Method and apparatus for optimizing storage space allocation for computer data
US8255627B2 (en) 2009-10-10 2012-08-28 International Business Machines Corporation Secondary cache for write accumulation and coalescing
US8250213B2 (en) 2009-11-16 2012-08-21 At&T Intellectual Property I, L.P. Methods and apparatus to allocate resources associated with a distributive computing network
US20110145201A1 (en) * 2009-12-11 2011-06-16 Microsoft Corporation Database mirroring
US8356007B2 (en) * 2010-10-20 2013-01-15 Microsoft Corporation Distributed transaction management for database systems with multiversioning
US8396831B2 (en) 2009-12-18 2013-03-12 Microsoft Corporation Optimistic serializable snapshot isolation
US20110161496A1 (en) 2009-12-28 2011-06-30 Nicklin Jonathan C Implementation and management of internet accessible services using dynamically provisioned resources
WO2011082138A1 (en) 2009-12-31 2011-07-07 Commvault Systems, Inc. Systems and methods for performing data management operations using snapshots
US20110178984A1 (en) 2010-01-18 2011-07-21 Microsoft Corporation Replication protocol for database systems
US8671074B2 (en) 2010-04-12 2014-03-11 Microsoft Corporation Logical replication in clustered database system with adaptive cloning
US8463825B1 (en) 2010-04-27 2013-06-11 Tintri Inc. Hybrid file system for virtual machine storage
JP5536568B2 (ja) 2010-07-01 2014-07-02 インターナショナル・ビジネス・マシーンズ・コーポレーション トランザクションを集約して処理する方法、システム、およびプログラム
US8412689B2 (en) 2010-07-07 2013-04-02 Microsoft Corporation Shared log-structured multi-version transactional datastore with metadata to enable melding trees
US20120041899A1 (en) 2010-08-10 2012-02-16 Palo Alto Research Center Incorporated Data center customer cost determination mechanisms
US8589361B2 (en) * 2010-08-30 2013-11-19 Oracle International Corporation Reduced disk space standby
US10430298B2 (en) 2010-10-28 2019-10-01 Microsoft Technology Licensing, Llc Versatile in-memory database recovery using logical log records
CN102012849B (zh) 2010-11-19 2012-10-24 中国人民大学 一种基于闪存的数据库恢复方法
US8572031B2 (en) 2010-12-23 2013-10-29 Mongodb, Inc. Method and apparatus for maintaining replica sets
US8910172B2 (en) 2010-12-29 2014-12-09 Symantec Corporation Application resource switchover systems and methods
JP5672491B2 (ja) 2011-03-29 2015-02-18 ソニー株式会社 情報処理装置および方法、並びにログ収集システム
US9519555B2 (en) * 2011-05-23 2016-12-13 Microsoft Technology Licensing, Llc Synchronous replication in a distributed storage environment
US9098470B2 (en) * 2011-05-23 2015-08-04 Microsoft Technology Licensing, Llc Versioned and hierarchical data structures and distributed transactions
US8554726B2 (en) 2011-06-01 2013-10-08 Clustrix, Inc. Systems and methods for reslicing data in a relational database
US8543538B2 (en) 2011-06-01 2013-09-24 Clustrix, Inc. Systems and methods for redistributing data in a relational database
US9348883B2 (en) 2011-06-01 2016-05-24 Clustrix, Inc. Systems and methods for replication replay in a relational database
US8868492B2 (en) * 2011-06-15 2014-10-21 Oracle International Corporation Method for maximizing throughput and minimizing transactions response times on the primary system in the presence of a zero data loss standby replica
JP5405530B2 (ja) * 2011-06-27 2014-02-05 日本電信電話株式会社 分散データストアシステムおよび障害復旧方法
US9294564B2 (en) 2011-06-30 2016-03-22 Amazon Technologies, Inc. Shadowing storage gateway
US8909996B2 (en) 2011-08-12 2014-12-09 Oracle International Corporation Utilizing multiple storage devices to reduce write latency for database logging
KR101824295B1 (ko) 2011-08-12 2018-01-31 샌디스크 테크놀로지스 엘엘씨 솔리드 스테이트 장치 가상화를 포함하는 캐시 관리
US8712961B2 (en) 2011-09-23 2014-04-29 International Business Machines Corporation Database caching utilizing asynchronous log-based replication
US10042674B2 (en) 2011-09-30 2018-08-07 Teradata Us, Inc. Regulating capacity and managing services of computing environments and systems that include a database
US8527462B1 (en) * 2012-02-09 2013-09-03 Microsoft Corporation Database point-in-time restore and as-of query
US20150058293A1 (en) * 2012-03-22 2015-02-26 Nec Corporation Distributed storage system, storage control method and program
US9171020B2 (en) * 2012-04-30 2015-10-27 Sap Se Deleting records in a multi-level storage architecture
CN102768676B (zh) 2012-06-14 2014-03-12 腾讯科技(深圳)有限公司 一种格式未知文件的处理方法和装置
CN102737131B (zh) * 2012-06-21 2016-03-30 瑞典爱立信有限公司 一种针对数据库重做日志的处理方法及系统
US9229983B2 (en) * 2012-11-30 2016-01-05 Amazon Technologies, Inc. System-wide query optimization
US9304998B2 (en) * 2012-12-19 2016-04-05 Microsoft Technology Licensing, Llc Main-memory database checkpointing
US9514007B2 (en) 2013-03-15 2016-12-06 Amazon Technologies, Inc. Database system with database engine and separate distributed storage service
US11030055B2 (en) 2013-03-15 2021-06-08 Amazon Technologies, Inc. Fast crash recovery for distributed database systems
US9672237B2 (en) 2013-03-15 2017-06-06 Amazon Technologies, Inc. System-wide checkpoint avoidance for distributed database systems
US10180951B2 (en) 2013-03-15 2019-01-15 Amazon Technologies, Inc. Place snapshots
US9501501B2 (en) 2013-03-15 2016-11-22 Amazon Technologies, Inc. Log record management
US10747746B2 (en) 2013-04-30 2020-08-18 Amazon Technologies, Inc. Efficient read replicas
US9317213B1 (en) 2013-05-10 2016-04-19 Amazon Technologies, Inc. Efficient storage of variably-sized data objects in a data store
US9760596B2 (en) 2013-05-13 2017-09-12 Amazon Technologies, Inc. Transaction ordering
US9208032B1 (en) 2013-05-15 2015-12-08 Amazon Technologies, Inc. Managing contingency capacity of pooled resources in multiple availability zones
US10303564B1 (en) 2013-05-23 2019-05-28 Amazon Technologies, Inc. Reduced transaction I/O for log-structured storage systems
US9305056B1 (en) 2013-05-24 2016-04-05 Amazon Technologies, Inc. Results cache invalidation
US9047189B1 (en) 2013-05-28 2015-06-02 Amazon Technologies, Inc. Self-describing data blocks of a minimum atomic write size for a data store
US9519664B1 (en) 2013-09-20 2016-12-13 Amazon Technologies, Inc. Index structure navigation using page versions for read-only nodes
US9460008B1 (en) 2013-09-20 2016-10-04 Amazon Technologies, Inc. Efficient garbage collection for a log-structured data store
US9507843B1 (en) 2013-09-20 2016-11-29 Amazon Technologies, Inc. Efficient replication of distributed storage changes for read-only nodes of a distributed database
US9280591B1 (en) 2013-09-20 2016-03-08 Amazon Technologies, Inc. Efficient replication of system transactions for read-only nodes of a distributed database
US9699017B1 (en) 2013-09-25 2017-07-04 Amazon Technologies, Inc. Dynamic utilization of bandwidth for a quorum-based distributed storage system
US10223184B1 (en) 2013-09-25 2019-03-05 Amazon Technologies, Inc. Individual write quorums for a log-structured distributed storage system
US9582556B2 (en) 2013-10-03 2017-02-28 International Business Machines Corporation Automatic generation of an extract, transform, load (ETL) job
US9223843B1 (en) 2013-12-02 2015-12-29 Amazon Technologies, Inc. Optimized log storage for asynchronous log updates
US20150286701A1 (en) 2014-04-04 2015-10-08 Quantum Corporation Data Classification Aware Object Storage
US10803012B1 (en) * 2014-05-09 2020-10-13 Amazon Technologies, Inc. Variable data replication for storage systems implementing quorum-based durability schemes
US9600547B2 (en) 2014-05-30 2017-03-21 International Business Machines Corporation System and method of consuming and integrating with rest-based cloud and enterprise services
US11222036B1 (en) * 2015-12-15 2022-01-11 Amazon Technologies, Inc. Data warehouse access reporting
US10909091B1 (en) * 2016-11-23 2021-02-02 Amazon Technologies, Inc. On-demand data schema modifications
US11210184B1 (en) * 2017-06-07 2021-12-28 Amazon Technologies, Inc. Online restore to a selectable prior state for database engines
US11188501B1 (en) * 2017-08-15 2021-11-30 Amazon Technologies, Inc. Transactional and batch-updated data store search
US11010267B2 (en) * 2017-09-22 2021-05-18 Oracle International Corporation Method and system for automatic maintenance of standby databases for non-logged workloads
US10802766B2 (en) * 2017-09-29 2020-10-13 Oracle International Corporation Database with NVDIMM as persistent storage
US11256695B1 (en) * 2017-11-22 2022-02-22 Amazon Technologies, Inc. Hybrid query execution engine using transaction and analytical engines
US10725983B2 (en) * 2017-12-29 2020-07-28 Huawei Technologies Co., Ltd. Systems and methods for database management using append-only storage devices
US10990571B1 (en) * 2018-01-19 2021-04-27 Amazon Technologies, Inc. Online reordering of database table columns
US11250022B1 (en) * 2020-09-29 2022-02-15 Amazon Technologies, Inc. Offline index builds for database tables
US11397645B1 (en) * 2020-10-30 2022-07-26 Amazon Technologies, Inc. Storage volume snapshot object management
US12032592B2 (en) * 2022-07-29 2024-07-09 Huawei Technologies Co., Ltd. Method, database host, and medium for database b-tree branch locking

Also Published As

Publication number Publication date
KR20150122226A (ko) 2015-10-30
US10698881B2 (en) 2020-06-30
KR101764897B1 (ko) 2017-08-04
AU2014237083B2 (en) 2017-03-02
US20230092908A1 (en) 2023-03-23
AU2014237083A1 (en) 2015-10-08
CA2906415A1 (en) 2014-09-25
US20170083565A1 (en) 2017-03-23
EP2973054B1 (en) 2018-05-09
CA3025369C (en) 2021-08-24
EP2973054A4 (en) 2016-12-07
CN105122241B (zh) 2019-03-29
EP3327572A1 (en) 2018-05-30
US20240330270A1 (en) 2024-10-03
EP2973054A1 (en) 2016-01-20
CN109933597B (zh) 2024-01-30
JP2016511486A (ja) 2016-04-14
EP3327572B1 (en) 2020-11-04
WO2014150538A1 (en) 2014-09-25
CN105122241A (zh) 2015-12-02
AU2017203631A1 (en) 2017-06-15
CA3025369A1 (en) 2014-09-25
US11500852B2 (en) 2022-11-15
CA2906415C (en) 2019-01-15
KR101923334B1 (ko) 2018-11-28
US20140279929A1 (en) 2014-09-18
JP2018152118A (ja) 2018-09-27
US9514007B2 (en) 2016-12-06
AU2017203631B2 (en) 2019-02-07
US20200327114A1 (en) 2020-10-15
CN109933597A (zh) 2019-06-25
JP6661696B2 (ja) 2020-03-11
KR20170091189A (ko) 2017-08-08
US12038906B2 (en) 2024-07-16

Similar Documents

Publication Publication Date Title
JP6661696B2 (ja) データベースエンジンを備えたデータベースシステム及び別個の分散型ストレージサービス
JP6619406B2 (ja) ログレコード管理
JP6777673B2 (ja) インプレーススナップショット
JP6522812B2 (ja) 分散型データベースシステム用高速クラッシュ回復
US11755415B2 (en) Variable data replication for storage implementing data backup
JP6538780B2 (ja) 分散型データベースシステムのシステム全体のチェックポイント回避
US10223184B1 (en) Individual write quorums for a log-structured distributed storage system

Legal Events

Date Code Title Description
A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20151008

A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20161111

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20161129

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20170228

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20170620

A601 Written request for extension of time

Free format text: JAPANESE INTERMEDIATE CODE: A601

Effective date: 20170920

A601 Written request for extension of time

Free format text: JAPANESE INTERMEDIATE CODE: A601

Effective date: 20171120

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

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20180528

R150 Certificate of patent or registration of utility model

Ref document number: 6346937

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R150

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250