Docs Menu
Docs Home
/
MongoDBマニュアル
/ /

シャーディングされたクラスターでのチャンクの分裂

デフォルトでは、MongoDB は、それに属するデータを移行するときにのみチャンクを分割する可能性があります。 ただし、既存のデータを使用してクラスターを配置した後など、クラスター内に大量のデータがあり、チャンクが非常に少ない場合は、チャンクを手動で分割することをお勧めします。

チャンクを手動で分割するには、フィールドmiddleまたはfindのいずれかを指定して、 splitコマンドを使用します。 mongoshにはヘルパー メソッドsh.splitFind()sh.splitAt()が提供されます。

splitFind()は、このクエリに一致するとして返された最初のドキュメントを含むチャンクを、同じサイズの 2 つのチャンクに分割します。 完全な名前空間( シャーディングされたコレクションの「 <database>.<collection> 」をsplitFind()に置き換えます。 splitFind()のクエリではシャードキーを使用する必要はありませんが、ほとんどの場合、シャードキーを使用する方が合理的です。

次のコマンドは、 recordsデータベースのpeopleコレクション内にあるzipcodeフィールドの63109の値を含むチャンクを分割します。

sh.splitFind( "records.people", { "zipcode": "63109" } )

splitAt()を使用して、クエリされたドキュメントを新しいチャンクの下限として使用し、チャンクを 2 に分割します。

次のコマンドは、 recordsデータベースのpeopleコレクション内にあるzipcodeフィールドの63109の値を含むチャンクを分割します。

sh.splitAt( "records.people", { "zipcode": "63109" } )

注意

splitAt() では、チャンクは必ずしも同じサイズの 2 つに分割される必要はありません。 分裂は、ドキュメントがチャンク内のどこにあるかに関係なく、クエリに一致するドキュメントの場所で行われます。

Tip

以下も参照してください。

戻る

範囲の作成