更新自动化配置
项目的自动化配置决定其MongoDB进程和代理的目标状态。 MongoDB Agent根据指定的目标构建部署。
要更新配置,请执行以下操作:
检索当前配置。
根据需要进行更改,仅更改要修改的项目。
使用
PUT
替换整个配置。 您必须使用PUT
。 请勿使用PATCH
。
先决条件
您必须有权访问 API 。 要了解更多信息,请参阅配置 API 访问权限。
自动化配置 API 资源的变量
API 资源使用其中的一个或多个变量。 在调用这些 API 资源之前,将这些变量替换为您所需的值。
步骤
从 Ops Manager 检索并验证自动化配置。
使用AutomationConfig资源检索配置。 发出以下命令,将占位符替换为自动化配置 API 资源的变量。
curl --user "{PUBLIC-KEY}:{PRIVATE-KEY}" --digest \ --request GET "https://<OpsManagerHost>:<Port>/api/public/v1.0/groups/{PROJECT-ID}/automationConfig?pretty=true" \ --output currentAutomationConfig.json 验证下载的自动化配置文件。
将
currentAutomationConfig.json
的version
字段与自动化配置备份文件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
值匹配,则您正在使用当前版本的自动化配置文件。
发送更新的自动化配置。
使用AutomationConfig资源发送更新的自动化配置。
使用更新后的配置文档的路径发出以下命令,并将占位符替换为自动化配置 API 资源的变量。
curl --user "{PUBLIC-KEY}:{PRIVATE-KEY}" --digest \ --header "Content-Type: application/json" --request PUT "https://<OpsManagerHost>:<Port>/api/public/v1.0/groups/{PROJECT-ID}/automationConfig?pretty=true" \ --data @currentAutomationConfig.json
成功更新配置后,API 会返回 HTTP 200 OK
状态代码,以指示请求已成功。
检查部署状态以确保达到目标状态。
使用AutomationStatus资源检索部署状态。 发出以下命令,将占位符替换为自动化配置 API 资源的变量。
curl --user "{PUBLIC-KEY}:{PRIVATE-KEY}" --digest \ --request GET "https://<OpsManagerHost>:<Port>/api/public/v1.0/groups/{PROJECT-ID}/automationStatus?pretty=true"
确认processes
数组中所有lastGoalVersionAchieved
字段的值与goalVersion
字段匹配。 要了解部署状态,请参阅获取最新计划的自动化状态。