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

sh.unshardCollection

項目一覧

  • 定義
  • 構文
  • 互換性
  • Considerations
  • 要件
  • 動作
  • 詳細
sh.unshardCollection( namespace, shardID )

既存のシャーディングされたコレクションされたコレクションのシャーディングを解除し、コレクションデータを単一のシャードに移動します。 コレクションのシャーディングを解除すると、コレクションは複数のシャードにまたがって分割できなくなり、シャードキーが削除されます。

バージョン8.0の新機能

重要

mongosh メソッド

このページでは、mongosh メソッドについて説明します。ただし、データベースコマンドや Node.js などの言語固有のドライバーのドキュメントには該当しません

データベースコマンドについては、unshardCollection コマンドを参照してください。

MongoDB API ドライバーについては、各言語の MongoDB ドライバー ドキュメントを参照してください。

sh.unshardCollectionメソッドでは、コレクションデータを受信するためのシャードを指定する必要があります。 unshardCollectionコマンドでは、宛先シャードを指定しない場合、クラスターは自動的にデータが最も少ないシャードを選択します。

コレクションでゾーンシャーディングが使用されている場合は、コレクションのシャーディングを解除する 前に、まずゾーンから範囲の関連付けとシャードを削除する必要があります。詳細については、「 シャーディングされていないゾーン 」を参照してください。

注意

コレクションのシャーディングを解除するには 書き込み集中型の操作であり、 oplogの増加率が増加する可能性があります。 これを軽減するには、次の構成変更を検討してください。

  • oplogの無制限の増加を防ぐには、固定のoplogサイズを設定します。

  • セカンダリが古くなる可能性を減らすには、 oplogサイズを増やします。

詳しくは、レプリカセットのoplogを参照してください。

sh.unshardCollection の構文は次のとおりです。

sh.unshardCollection( namespace, shardID )
Parameter
タイプ
説明

namespace

string

シャーディングを解除するデータベースとコレクションを指定します。

shardID

string

受信者シャードIDを指定します。 MongoDBがコレクションのシャーディングを解除すると 、コレクション データが現在のシャードからこの特定のシャードにコレクションデータが移動されます。

このメソッドは、次の環境でホストされている配置で使用できます。

  • MongoDB Enterprise: サブスクリプションベースの自己管理型 MongoDB バージョン

  • MongoDB Community: ソースが利用可能で、無料で使用できる自己管理型の MongoDB のバージョン

  • MongoDB Atlas はクラウドでの MongoDB 配置のためのフルマネージド サービスです

重要

このコマンドは、共有インスタンスまたはサーバーレスインスタンスでは実行できません。 詳細については、「サポートされていないコマンド 」を参照してください。

  • sh.unshardCollection() は、シャーディングされたクラスターでのみ実行できます。

  • sh.unshardCollection() は、シャーディングされたコレクションでのみ動作できます。

  • sh.unshardCollection() は一度に 1 つのコレクションに対してのみ操作できます。

  • sh.unshardCollection() の最小期間は5分です。

  • Atlas Search インデックスは、 sh.unshardCollection()の実行後に 再構築する必要があります 。

  • sh.unshardCollection()が完了するまで、シャードの追加や削除、埋め込みコンフィギュレーションサーバーと専用コンフィギュレーションサーバーの間の移行などのトポロジー変更を行うことはできません。

  • sh.unshardCollection()の進行中にシャーディングされていないコレクションに対して次の操作を実行することはできません。

  • unshardCollectionの進行中は、クラスターで次の操作を実行できません。

  • sh.unshardCollection()の進行中に発生するインデックスビルドは、メッセージが表示されずに失敗する可能性があります。

    • sh.unshardCollection()の進行中は、インデックスを作成しないでください。

    • インデックスビルドが進行中の場合は、 sh.unshardCollection()を呼び出しないでください。

コレクションのシャーディングを解除する 前に、以下の要件を満たしていることを確認してください。

  • アプリケーションは、影響を受けるコレクションが書込みをブロックする期間を2 秒許容できます。 書込み (write) がブロックされている期間中、アプリケーションのレイテンシが増加します。

  • データベースが次のリソース要件を満たしている。

    • コレクションを移動するシャードに、コレクションとそのインデックス用の十分なストレージ領域があることを確認します。 宛先シャードでは少なくとも( Collection storage size + Index Size ) * 2バイトが使用可能である必要があります。

    • I/Oキャパシティーが50 % 未満であることを確認します。

    • CPU 負荷が80 % 未満であることを確認します。

ゾーンシャーディング を使用しているコレクションのシャーディングを解除するには、まずバランサーを停止し、次にゾーンから範囲とシャードを削除する必要があります。

例については、「 ゾーン シャーディングされたコレクションのシャーディングの解除 」を参照してください。

この例では、 appデータベース上のinventoryという名前のコレクションのシャーディングを解除し、 shard02シャードにします。

sh.unshardCollection( "app.inventory", "shard02" )

使用可能なシャード ID のリストを取得するには、 sh.status()を実行します。 詳細についてはsh.status() 出力 を参照してください。

この例では、ゾーン を使用するコレクションのシャーディングを解除します。

1

バランサー を停止するには、sh.stopBalancer() メソッドを実行します。

sh.stopBalancer()
2

ゾーンに関連付けられている範囲を識別するには、sh.status() chunksメソッドを実行し、各シャーディングされたコレクションの フィールドに範囲を確認します。

sh.status()
3

ゾーンから範囲を削除するには、sh.removeRangeFromZone() メソッドを使用します。

sh.removeRangeFromZone( {
"app.inventory",
{ size: 100 },
{ size: 500 }
} )

コレクションで使用されるゾーンからすべての範囲を削除するまで、この手順を繰り返します。

4

ゾーンからシャードを削除するには、sh.removeShardFromZone() メソッドを実行します。

sh.removeShardFromZone( "shard01", "mid" )

すべてのゾーンからシャードを削除するまで、 を繰り返します。

5

バランサー を再起動するには、sh.startBalancer() メソッドを実行します。

sh.startBalancer()
6

コレクション のシャーディングを解除するには、 sh.unshardCollection メソッドを実行します。

sh.unshardCollection( "app.inventory", "shard01" )

戻る

sh.stopBalancer