ビデオ: Scaling Databases - Web Development 2024
NoSQLシステムの共通の特徴の1つは、多くのコモディティサーバーで規模を調整できることです。これらの比較的安価なプラットフォームを使用すると、古いハードウェアを新しく強力なハードウェアに置き換えるのではなく、新しいサーバーを追加することでデータベースをスケールアップできます。
大量のユースケースがあり、すぐにスケールアウトすることになります。これには以下のものが含まれます。
-
IT環境全体からステータスレポートとログメッセージを受信します。 このシナリオでは、早い摂取時間が必要ですが、高度な分析サポートは必要ありません。
<! - 1 - > -
複雑なクエリでは高速キャッシュが必要です。 たぶん、あなたは最新のニュース記事をウェブサイトで入手したいと思うかもしれません。ここでは、読み取りキャッシュはクエリまたは取り込み速度よりも顕著になります。
すべてのNoSQLデータベースのパフォーマンスに共通することの1つは、公開されたデータに頼ることができないことです。それ以外の方法は、データにどのようなパフォーマンスがあるかを把握することはできません。
<! - 2 - >あなたは確かに特定のデータベースベンダーの業績への約束に頼ることはできません!多くのベンダーは、データベースの覇権を証明するものとして、データベースの現実的な使用ではない人工ユースケースに対して、高い摂取速度を挙げています。
しかし、問題は、これらの同じ研究がクエリ速度を完全に無視する可能性があることです。あなたはそれを使用しない場合、データを格納する際のポイントは何ですか?
これらの研究は、主要な機能が無効になっているシステムでも行うことができます。セキュリティインデックスが有効になっていないか、調査中にACIDトランザクションのサポートが無効になっているため、データがすぐに保存されますが、安全であるという保証はありません。
<! - 3 - >これは、あなた自身のテストを行う必要があることを意味しますが、それは簡単ですが、できるだけテストが最終システムに近いことを確認してください。たとえば、20台のサーバーに拡張する予定がある場合は、1台のサーバーをテストする必要はありません。具体的には、データの取り込み、変更、およびクエリの正確な組み合わせを必ず用意してください。
NoSQLベンダーに次の質問をすることを検討してください。
-
引用符で囲まれたすべてのサイジングとパフォーマンスの数字は、取り込み中にリアルタイムインデックス作成をサポートし、インジェストと読み取りの現実的な組み合わせを含むACIDトランザクションを保証するシステム/クエリのリクエスト?
-
あなたの製品は、サーバーの容量を簡単に増やす機能を備えていますか?
-
ご使用の製品で、未使用のサーバー容量を簡単に削除できる機能はありますか?
-
製品のデータクエリ速度は、RAMにキャッシュされる情報の量によって制限されますか?
-
適切なパフォーマンスを得るためにすべてのインデックスをRAMに保持する必要のあるメモリマップ戦略を使用していますか?(マップされたメモリは、格納される最大データ量がインストールされた物理RAMの量と同じです。
-
高頻度の更新を受信しているときにデータベースが秒未満のクエリ応答時間を維持できますか?
-
システムは、サーバーの容量を追加または削除するためのダウンタイムがないことを保証していますか?
-
システムは、情報がデータベースに追加された後にすぐに利用可能であることを確認しますか?
-
システムは、クエリ速度に悪影響を及ぼすことなくデータのセキュリティを維持することを確実にしますか?
-
システムは、データベースのスケールアウトとスケールバック機能がスクリプト化可能であり、選択したサーバープロビジョニングソフトウェア(たとえば、VMwareとAmazon Cloud Formation)に統合されることを保証しますか?