API 経由でクラスターを配置
- Cloud Managerへのプログラムによるアクセスのための OAuth 2.0認証はプレビュー機能として利用できます。
- 機能および関連するドキュメントは、プレビュー期間中にいつでも変更される可能性があります。 OAuth2.0 認証を使用するには、 Cloud Manager Public APIへのリクエストで使用する サービス アカウント を作成します。
このチュートリアルでは、 Cloud Manager Administration API のオートメーション構成を操作して、別のユーザーが所有するシャーディングされたクラスターを配置します。 このチュートリアルでは、最初に新しいプロジェクトを作成し、次にプロジェクトの所有者として新しいユーザーを作成し、次に新しいユーザーが所有するシャーディングされたクラスターを作成します。 スクリプトを作成して、ルーチン操作で使用するこれらの手順を自動化できます。
これらの手順を実行するには、Cloud Manager に対する十分なアクセス権が必要です。 Project Owner
ロールを持つユーザーには十分なアクセス権があります。
手順では、2 つのシャードを持つクラスターをインストールします。 各シャードは 3 つのメンバーのレプリカセットで構成されています。 このチュートリアルでは、1 つのmongos
と 3 つのコンフィギュレーションサーバーをインストールします。 クラスターの各コンポーネントは独自のサーバー上に存在するため、合計で10のホストが必要です。
チュートリアルでは、各ホストにMongoDB Agentをインストールします。
前提条件
シャーディングされたクラスターのコンポーネントを提供するために 10 個のホストをプロビジョニングします。 ホスト要件については、MongoDB マニュアルの 「プロダクション ノート」を参照してください。
各ホストは、そのMongoDB Agentが、他のすべてのホスト上のMongoDB Agent のホスト名とポートへの完全なネットワークアクセスを提供する必要があります。 各エージェントは コマンドhostname -f
を実行して、ホスト名とポートを自己識別し、Cloud Manager に報告します。
Tip
エージェントが相互にアクセスできるようにするには、 オートメーション を使用してホストをプロビジョニングします。 これにより、正しいネットワーク アクセス権を持つ MongoDB エージェントがインストールされます。 このチュートリアルを使用して、それらのマシンにオートメーションを再インストールします。
例
APIを使用している場合は、Github サンプル ページ で例を表示できます。
クラスター作成 API リソースの変数
API リソースは、これらの変数の 1 つ以上を使用します。 これらの API リソースを呼び出す前に、これらの変数を目的の値に置き換えます。
名前 | タイプ | 説明 |
---|---|---|
| string | API認証情報の公開 API キー。 |
| string | API 認証情報の プライベート API キー 。 |
| string | Cloud Manager インスタンスのURL 。 |
| string | プロジェクト設定からのプロジェクトの一意の識別子。 |
前提条件
API を使用できるようにするには、 API アクセスを設定します。
手順
API 経由でグループとユーザーを作成
API を使用してプロジェクトを作成します。
Cloud Manager Administration API を使用して、新しいプロジェクトを作成するためのプロジェクトドキュメントを送信します。
curl --user "{PUBLIC-KEY}:{PRIVATE-KEY}" --digest \ --header "Content-Type: application/json" \ --request POST "https://cloud.mongodb.com/api/public/v1.0/groups?pretty=true" \ --data ' { "name": "{GROUP-NAME}" }'
APIは、プロジェクトのagentApiKey
とid
を含むドキュメントを返します。
返されたドキュメントに agentApiKey
と id
の値を記録します。
この手順やこのチュートリアルの他の手順で使用するためにこれらの値を記録します。
API を使用して、新しいプロジェクトにユーザーを作成します。
/users
エンドポイントを使用して、新しいプロジェクトにユーザーを追加します。
リクエストの本文には、ユーザーの情報を含むユーザーJSONドキュメントが含まれている必要があります。
ユーザーのroles.roleName
をGROUP_OWNER
に設定し、ユーザーのroles.groupId
を新しいグループのid
に設定します。
curl --user "{PUBLIC-KEY}:{PRIVATE-KEY}" --digest \ --header 'Accept: application/json' \ --header "Content-Type: application/json" \ --request POST "https://cloud.mongodb.com/api/public/v1.0/users?pretty=true" \ --data ' { "username": "<new_user@example.com>", "emailAddress": "<new_user@example.com>", "firstName": "<First>", "lastName": "<Last>", "password": "<password>", "roles": [{ "groupId": "{PROJECT-ID}", "roleName": "GROUP_OWNER" }] }'
プロビジョニングされた各ホストへの MongoDB Agent のインストール
各ホストで MongoDB Agent のインストール手順を完了します。
MongoDB Agent をインストールする方法については、適切なプラットフォームの手順に従ってください。
自動化構成の初期状態を確認します。
MongoDB Agent が初めて実行されると、自動化構成の目的の状態を記述するmms-cluster-config-backup.json
ファイルがダウンロードされます。
のホストの 1 つで、 に移動し、/var/lib/mongodb-mms-automation/
mms-cluster-config-backup.json
を開きます。ファイルのversion
フィールドが1
に設定されていることを確認します。 Cloud Manager は、変更が発生するとこのフィールドを自動的に増加させます。
新しいクラスターの配置
配置を追加または更新するには、構成を取得し、必要に応じて変更を加え、更新された構成をAPI経由で Cloud Manager に送信します。
次の手順では、 APIを介して更新されたオートメーション構成を配置します。
Cloud Manager からオートメーション構成を取得して検証します。
構成を取得するには、 automationConfigリソースを使用します。 次のコマンドを実行して、プレースホルダーをクラスター作成 API リソースの変数に置き換えます。
curl --user "{PUBLIC-KEY}:{PRIVATE-KEY}" --digest \ --request GET "https://cloud.mongodb.com/api/public/v1.0/groups/{PROJECT-ID}/automationConfig?pretty=true" \ --output currentAutomationConfig.json ダウンロードしたオートメーション構成ファイルを検証します。
version
のcurrentAutomationConfig.json
フィールドと Automation Configuration バックアップ ファイルのmms-cluster-config-backup.json
フィールドを比較します。version
値は両方のJSONドキュメントの最後の要素です。 このファイルは、MongoDB Agent を実行しているホスト上の次の場所にあります。Linux と macOS:
/var/lib/mongodb-mms-automation/mms-cluster-config-backup.json
Windows:
%SystemDrive%\MMSAutomation\versions\mms-cluster-config-backup.json
version
値が一致する場合は、現在のバージョンの Automation 構成ファイルを操作します。
新しいオートメーション構成の最上位レベルを作成します。
次のフィールドを含むドキュメントを作成します。 構成ドキュメントを作成する際には、設定の詳細な説明については、オートメーション構成の説明を参照してください。 例については、 MongoDB Lambs ページ を参照してください。
1 { 2 "options": { 3 "downloadBase": "/var/lib/mongodb-mms-automation", 4 }, 5 "mongoDbVersions": [], 6 "monitoringVersions": [], 7 "backupVersions": [], 8 "processes": [], 9 "replicaSets": [], 10 "sharding": [] 11 }
モニタリングをオートメーション構成に追加します。
monitoringVersions.hostname
フィールドに、Cloud Manager がモニタリングをインストールするサーバーのホスト名を入力します。 次のように、サーバー上でhostname -f
を実行すると返される完全修飾ドメイン名を使用します。
1 "monitoringVersions": [ 2 { 3 "hostname": "<server_x.example.com>", 4 "logPath": "/var/log/mongodb-mms-automation/monitoring-agent.log", 5 "logRotate": { 6 "sizeThresholdMB": 1000, 7 "timeThresholdHrs": 24 8 } 9 } 10 ]
この構成例には、ログの場所を指定するlogPath
フィールドと、ログしきい値を指定するlogRotate
も含まれています。
サーバーをオートメーション構成に追加します。
このシャーディングされたクラスターには、 API 経由でクラスターを配置する で説明されているように、それぞれが独自のサーバー上で実行されている10の MongoDB インスタンスがあります。 したがって、オートメーション構成のprocesses
配列には、MongoDB インスタンスごとに 1 つずつ、 10ドキュメントが含まれます。
次の例では、 最初の ドキュメントをprocesses
配列に追加します。 <process_name_1>
を選択した任意の名前に置き換え、 <server1.example.com>
をホストのFQDNに置き換えます。
シャーディングされたクラスター内の各 MongoDB インスタンスに対して 1 つずつ、9 つのドキュメントを追加します。
processes.<args>
フィールドにargs2_6
構文を指定します。 processes.args2_6
オブジェクトは、MongoDB バージョン 2.6 以降のほとんどの MongoDB 設定とパラメータを受け入れます。 詳しくは、「 MongoDB 設定とオートメーション サポート 」を参照してください。
1 "processes": [ 2 { 3 "version": "4.0.6", 4 "name": "<process_name_1>", 5 "hostname": "<server1.example.com>", 6 "logRotate": { 7 "sizeThresholdMB": 1000, 8 "timeThresholdHrs": 24 9 }, 10 "authSchemaVersion": 5, 11 "featureCompatibilityVersion": "4.0", 12 "processType": "mongod", 13 "args2_6": { 14 "net": { 15 "port": 27017 16 }, 17 "storage": { 18 "dbPath": "/data/" 19 }, 20 "systemLog": { 21 "path": "/data/mongodb.log", 22 "destination": "file" 23 }, 24 "replication": { 25 "replSetName": "rs1" 26 } 27 } 28 }, 29 ]
シャーディングされたクラスターのトポロジーをオートメーション構成に追加します。
2 つのレプリカセット ドキュメントをreplicaSets
配列に追加します。 各ドキュメントに 3 つのメンバーを追加します。
例
このセクションでは、最初のレプリカセット ドキュメントに 1 つのレプリカセット メンバーを追加します。
重要
各レプリカセットのルート ドキュメントに"protocolVersion": 1
を含める必要があります。
1 "replicaSets": [ 2 { 3 "_id": "rs1", 4 "members": [ 5 { 6 "_id": 0, 7 "host": "<process_name_1>", 8 "priority": 1, 9 "votes": 1, 10 "secondaryDelaySecs": 0, 11 "hidden": false, 12 "arbiterOnly": false 13 } 14 ], 15 "protocolVersion": 1 16 } 17 ]
sharding
配列で、次のようにレプリカセットをシャードに追加し、コンフィギュレーションサーバーのレプリカセット名を追加します。
1 "sharding": [ 2 { 3 "shards": [ 4 { 5 "tags": [], 6 "_id": "shard1", 7 "rs": "rs1" 8 }, 9 { 10 "tags": [], 11 "_id": "shard2", 12 "rs": "rs2" 13 } 14 ], 15 "name": "sharded_cluster_via_api", 16 "configServerReplica": "rs-config", 17 "collections": [] 18 } 19 ]
更新された自動化構成を送信します。
更新されたオートメーション構成を送信するには、 automationConfigリソースを使用します。
更新された構成ドキュメントへのパスを指定して次のコマンドを実行し、プレースホルダーをクラスター作成 API リソースの変数に置き換えます。
curl --user "{PUBLIC-KEY}:{PRIVATE-KEY}" --digest \ --header "Content-Type: application/json" --request PUT "https://cloud.mongodb.com/api/public/v1.0/groups/{PROJECT-ID}/automationConfig?pretty=true" \ --data @currentAutomationConfig.json
構成の更新に成功すると、API はリクエストが成功したことを示す HTTP 200 OK
ステータス コードを返します。
構成の更新が配置されたことを確認します。
AutomationStatusリソースを使用して、構成更新が完全に配置されたことを確認します。 次のコマンドを発行します:
curl --user "{PUBLIC-KEY}:{PRIVATE-KEY}" --digest \ --request GET "https://cloud.mongodb.com/api/public/v1.0/groups/{PROJECT-ID}/automationStatus?pretty=true"
curl
コマンドは、 processes
配列とgoalVersion
のキーと値を含むJSONオブジェクトを返します。 processes
配列には、MongoDB インスタンスをホストする各サーバーのドキュメントが含まれています。 processes
配列内のすべてのlastGoalVersionAchieved
フィールドがgoalVersion
に指定された値と等しい場合、新しい構成は正常に配置されます。
例
この応答では、 processes[2].lastGoalVersionAchieved
はgoalVersion
より遅れています。 これは、 server3.example.com
の MongoDB インスタンスがgoalVersion
より 1 つ前のバージョンを実行していることを示します。 数秒待ってからcurl
コマンドを再度発行します。
1 { 2 "goalVersion": 2, 3 "processes": [{ 4 "hostname": "server1.example.com", 5 "lastGoalVersionAchieved": 2, 6 "name": "ReplSet_0", 7 "plan": [] 8 }, { 9 "hostname": "server2.example.com", 10 "lastGoalVersionAchieved": 2, 11 "name": "ReplSet_1", 12 "plan": [] 13 }, { 14 "hostname": "server3.example.com", 15 "lastGoalVersionAchieved": 1, 16 "name": "ReplSet_2", 17 "plan":[] 18 }] 19 }
Cloud Manager コンソールで新しい構成を表示するには、次の手順に従います。
MongoDB Cloud Managerで、プロジェクトのGo Deployment{0 ページに します。
まだ表示されていない場合は、目的のプロジェクトを含む組織をナビゲーション バーの Organizations メニューで選択します。
まだ表示されていない場合は、ナビゲーション バーのProjectsメニューから目的のプロジェクトを選択します。
Deployment ページがまだ表示されていない場合は、サイドバーの Deployment をクリックします。
配置ページが表示されます。
新しい構成を確認します。
次のステップ
クラスターで追加のバージョンの MongoDB を使用できるようにするには、「配置の MongoDB バージョンの更新 」を参照してください。