整合性のある読み取り操作と書き込み操作はどのように処理されるのか
DataStax Enterpriseが、調整可能な整合性を伴うように結果整合性を拡張して、読み取られるデータおよび書き込まれるデータの整合性を変える方法の概要。
「整合性」とは、データ行のすべてのレプリカがどの程度まで最新の状態にあり、いつでも同期化されているかを指します。DataStax Enterprise(DSE)では、継続的なリペア操作により、行のすべてのレプリカの整合性が最終的に確保されます。リペア操作によってレプリカ・データのばらつきは減りますが、広範囲に分散するシステム全体で一定のデータ・トラフィックで不整合(古いデータ)がいつでも起こる可能性があります。DSEは、CAP定理に従うAP(高可用性と分断耐性を備える)システムです。DSEは構成に柔軟性があるため、アプリケーション要件に基づき、CAP定理に従うCP(整合性と分断耐性を備えた)システムとして動作できます。理解すべき2つの重要な整合性の特徴は、調整可能な整合性と直列可能な整合性です。
調整可能な整合性
データベースの読み取りおよび書き込みの整合性を適切なレベルで確保するために、DSEは調整可能な整合性を提供することによって、結果整合性の概念を拡大しています。整合性レベルは、操作ごとに調整することも、クラスターまたはデータ・センターに対してグローバルに設定することもできます。個々の読み取りまたは書き込み操作の整合性を変えることができるため、返されるデータの整合性はほぼクライアント・アプリケーションの要求どおりに確保されます。これにより、DSEはアプリケーション要件に応じて、CPシステムまたはAPシステムのように動作できます。
操作のレイテンシーと整合性の間にはトレードオフがあります。整合性が高いほどレイテンシーが高くなり、整合性が低いほどレイテンシーが低くなります。レイテンシーを制御するには、整合性を調整します。
整合性レベルは、クライアント・アプリケーションに対して読み取りまたは書き込み操作の成功を確認応答する必要があるレプリカの数を定めます。読み取り操作の場合、読み取り整合性レベルは、データがクライアント・アプリケーションに返される前に、読み取り要求に応答する必要があるレプリカの数を指定します。読み取り操作によりレプリカ間の不整合が判明した場合、データベースは読み取りリペアを開始して不整合データを更新します。
書き込み操作の場合、書き込み整合性レベルは、書き込みが成功したと見なされる前に、書き込み要求に応答する必要があるレプリカの数を指定します。整合性レベルが低い場合も、データベースは他のデータ・センターのレプリカも含めてパーティション・キーのすべてのレプリカに書き込みを行います。書き込み整合性レベルは、書き込み操作が完了したと見なすことをいつコーディネーター・ノードがクライアント・アプリケーションに報告するかのみを指定します。書き込み操作は、ヒンテッド・ハンドオフを使用して、レプリカがダウンしているか、その他の理由で書き込みに応答しない場合に、書き込みが確実に完了するようにします。
クライアントは、キースペースによって指定されているレプリケーション係数よりも低い整合性レベルを指定するのが普通です。別の一般的なプラクティスとして、書き込みをQUORUM整合性レベルで行い、読み取りをQUORUM整合性レベルで行います。この選択は、クライアント・アプリケーションのニーズによって異なります。DSEは、アプリケーション設計の柔軟性を最大限に高めます。
直列化可能な整合性
ACID用語で言えば、「直列化可能な整合性(シリアル整合性)」とは、軽量トランザクションに対するシリアル(即時)分離レベルです。DSEは、複数の行またはテーブルを同時に更新するときに、ロックまたはトランザクション依存関係のような従来のメカニズムを使用しません。
ただし、操作によっては、順次実行し、他の操作によって中断されてはならない場合があります。たとえば、ユーザー・アカウントの作成時に複製または上書きを行うと、深刻な結果をもたらす可能性があります。競合状態(2つのクライアントが同じレコードを更新する)のような状況では、レプリカ全体で不整合が発生することがあります。整合性が高い書き込みであっても、このような状況は解消されません。直列化可能な整合性は、ユーザーIDや電子メール・アドレスのような一意識別子に適用できますが、ユーザーのアカウントのすべての要素に必要なわけではありません。これらの要素のシリアル操作はPaxos合意プロトコルを使用してデータベースに実装できます。これはクォーラム・ベースのアルゴリズムを採用して、障害発生時に、少なくとも一部の生存プロセッサーが検索結果の知識を保持することを保証します。
軽量トランザクションは、マスター・データベースや2相コミット・プロセスを必要とせずに実装できます。軽量トランザクションの書き込み操作は、Paxos合意にシリアル整合性レベルを使用し、テーブルへの書き込みに通常の整合性レベルを使用します。詳細については、「軽量トランザクション」を参照してください。
整合性の計算
R + W > N
ここで、 - Rは読み取り操作の整合性レベルです
- Wは書き込み操作の整合性レベルです
- Nはレプリカの数です
たとえば、レプリケーション係数が3の場合、読み取り操作と書き込み操作を組み合わせた整合性レベルは4以上になる必要があります。読み取り操作で値を検証するために3つのレプリカのうち2つを使用し、書き込み操作で値を検証するために3つのレプリカのうち2つを使用すると、強力な整合性が実現します。高速な書き込み操作が必要だが、強力な整合性も求められる場合、書き込みの整合性レベルは1まで低下しますが、読み取り操作は3つのレプリカすべてで値が一致しているか検証する必要があります。書き込み速度は上昇しますが、読み取り速度は低下します。
R + W <= N
レプリケーション係数が3の場合、読み取り操作と書き込み操作を組み合わさせた整合性レベルは3以下です。たとえば、読み取り操作で値を検証するためにQUORUMを使用(3つのレプリカのうち2つを使用)し、書き込み操作で高速書き込みを行うためにONEを使用(3つのレプリカのうち1つを使用)すると、結果整合性が実現します。すべてのレプリカがデータを受け取りますが、読み取り操作は、すべてのレプリカがデータを書き込む前はデータの選択に対して脆弱になります。
その他の整合性の例:
- ONEで書き込みを行い、そのレプリカが1秒後にクラッシュします。他のメッセージは配信されません。そのデータは失われます。
- ONEで書き込みを行い、その操作がタイムアウトになります。その後の読み取りでは、古い値か新しい値が返されます。データが正しいかどうかわかりません。
- ONEで書き込みを行い、他のいずれかのレプリカがダウンします。そのノードがオンラインに戻ります。アプリケーションは、そのノードが正しいデータを取得するか、読み取りリペアが発生するまで、そのノードから古いデータを取得します。
- QUORUMで書き込みを行った後、QUORUMで読み取りを行います。いずれかのレプリカがダウンします。常に正しいデータを取得できます。