本文為英文版的機器翻譯版本,如內容有任何歧義或不一致之處,概以英文版為準。
更新環境
如果 AWS Proton 環境與環境帳戶連線相關聯,請勿更新或包含要更新或連線至環境帳戶連線的protonServiceRoleArn
參數。
只有在下列兩項都成立時,您才能更新為新的環境帳戶連線:
如果環境未與環境帳戶連線相關聯,請勿更新或包含environmentAccountConnectionId
參數。
您可以更新environmentAccountConnectionId
或protonServiceRoleArn
參數和值。您無法同時更新兩者。
如果您的環境使用自我管理的佈建,請勿更新provisioning-repository
參數並省略environmentAccountConnectionId
和protonServiceRoleArn
參數。
更新環境有四種模式,如下列清單所述。使用時 AWS CLI,deployment-type
欄位會定義模式。使用主控台時,這些模式會對應至 [編輯]、[更新]、[更新次要動作] 和 [更新動作] 下拉式清單中的主要動作。
-
NONE
在此模式中,不會發生部署。只會更新要求的中繼資料參數。
-
CURRENT_VERSION
在此模式下,環境會部署並使用您提供的新規格進行更新。只會更新要求的參數。使用此參數時,請勿包含次要或主要版本參數deployment-type
。
-
MINOR_VERSION
在此模式下,依預設,會使用目前主要版本的已發佈、建議 (最新) 次要版本來部署和更新環境。您也可以指定目前正在使用的主要版本的不同次要版本。
-
MAJOR_VERSION
在此模式下,依預設,會使用目前範本的已發佈、建議 (最新) 主要和次要版本來部署和更新環境。您也可以指定高於使用中的主要版本和次要版本 (選用) 的不同主要版本。
更新 AWS 受管理的佈建環境
標準佈建只有提供的環境才支援 AWS CloudFormation。
使用主控台或 AWS CLI 更新您的環境。
- AWS Management Console
-
如下列步驟所示,使用主控台更新環境。
-
選擇以下 2 個步驟之一。
-
在環境列表中。
-
在AWS Proton 主控台中,選擇 [環境]。
-
在環境清單中,選擇您要更新之環境左側的圓鈕。
-
在控制台環境詳細信息頁面中。
-
在AWS Proton 主控台中,選擇 [環境]。
-
在環境清單中,選擇您要更新之環境的名稱。
-
選擇接下來 4 個步驟中的一個來更新您的環境。
-
進行不需要環境部署的編輯。
-
例如,若要變更描述。
選擇編輯。
-
填寫表格,然後選擇「下一步」。
-
檢閱您的編輯並選擇 [更新]。
-
僅對中繼資料輸入進行更新。
-
選擇動作,然後選擇更新。
-
填寫表格,然後選擇 「編輯」。
-
填寫表格,然後選擇「下一步」,直到到達「審核」頁面。
-
檢閱您的更新並選擇 [更新]。
-
更新其環境範本的新次要版本。
-
選擇作業,然後選擇更新次要項目
-
填寫表格,然後選擇「下一步」。
-
填寫表格,然後選擇「下一步」,直到到達「審核」頁面。
-
檢閱您的更新並選擇 [更新]。
-
要更新其環境模板的新主要版本。
-
選擇動作,然後選擇更新主要。
-
填寫表格,然後選擇「下一步」。
-
填寫表格,然後選擇「下一步」,直到到達「審核」頁面。
-
檢閱您的更新並選擇 [更新]。
- AWS CLI
-
使用 AWS Proton AWS CLI 將環境更新為新的次要版本。
執行下列命令來更新您的環境:
$
aws proton update-environment \
--name "MySimpleEnv
" \
--deployment-type "MINOR_VERSION
" \
--template-major-version "1
" \
--template-minor-version "1
" \
--proton-service-role-arn arn:aws:iam::123456789012
:role/service-role/ProtonServiceRole
\
--spec "file:///spec.yaml
"
回應:
{
"environment": {
"arn": "arn:aws:proton:region-id:123456789012:environment/MySimpleEnv",
"createdAt": "2021-04-02T17:29:55.472000+00:00",
"deploymentStatus": "IN_PROGRESS",
"lastDeploymentAttemptedAt": "2021-04-02T17:48:26.307000+00:00",
"lastDeploymentSucceededAt": "2021-04-02T17:29:55.472000+00:00",
"name": "MySimpleEnv",
"protonServiceRoleArn": "arn:aws:iam::123456789012:role/service-role/ProtonServiceRole",
"templateMajorVersion": "1",
"templateMinorVersion": "0",
"templateName": "simple-env"
}
}
執行下列命令以取得並確認狀態:
$
aws proton get-environment \
--name "MySimpleEnv
"
回應:
{
"environment": {
"arn": "arn:aws:proton:region-id:123456789012:environment/MySimpleEnv",
"createdAt": "2021-04-02T17:29:55.472000+00:00",
"deploymentStatus": "SUCCEEDED",
"environmentName": "MySimpleEnv",
"lastDeploymentAttemptedAt": "2021-04-02T17:48:26.307000+00:00",
"lastDeploymentSucceededAt": "2021-04-02T17:48:26.307000+00:00",
"protonServiceRoleArn": "arn:aws:iam::123456789012:role/service-role/ProtonServiceRole",
"spec": "proton: EnvironmentSpec\n\nspec:\n my_sample_input: hello\n my_other_sample_input: everybody\n",
"templateMajorVersion": "1",
"templateMinorVersion": "1",
"templateName": "simple-env"
}
}
更新自我管理的佈建環境
只有使用 Terraform 佈建的環境才支援自我管理的佈建。
使用主控台或 AWS CLI 更新您的環境。
- AWS Management Console
-
如下列步驟所示,使用主控台更新環境。
-
選擇以下 2 個步驟之一。
-
在環境列表中。
-
在AWS Proton 主控台中,選擇 [環境]。
-
在環境清單中,選擇您要更新之環境範本左側的圓鈕。
-
在控制台環境詳細信息頁面中。
-
在AWS Proton 主控台中,選擇 [環境]。
-
在環境清單中,選擇您要更新之環境的名稱。
-
選擇接下來 4 個步驟中的一個來更新您的環境。
-
進行不需要環境部署的編輯。
-
例如,若要變更描述。
選擇編輯。
-
填寫表格,然後選擇「下一步」。
-
檢閱您的編輯並選擇 [更新]。
-
僅對中繼資料輸入進行更新。
-
選擇動作,然後選擇更新。
-
填寫表格,然後選擇 「編輯」。
-
填寫表格,然後選擇「下一步」,直到到達「審核」頁面。
-
檢閱您的更新並選擇 [更新]。
-
更新其環境範本的新次要版本。
-
選擇作業,然後選擇更新次要項目
-
填寫表格,然後選擇「下一步」。
-
填寫表格,然後選擇「下一步」,直到到達「審核」頁面。
-
檢閱您的更新並選擇 [更新]。
-
要更新其環境模板的新主要版本。
-
選擇動作,然後選擇更新主要。
-
填寫表格,然後選擇「下一步」。
-
填寫表格,然後選擇「下一步」,直到到達「審核」頁面。
-
檢閱您的更新並選擇 [更新]。
- AWS CLI
-
使用 AWS CLI 將 Terraform 環境更新為具有自我管理佈建的新次要版本。
-
執行下列命令來更新您的環境:
$
aws proton update-environment \
--name "pr-environment
" \
--deployment-type "MINOR_VERSION
" \
--template-major-version "1
" \
--template-minor-version "1
" \
--provisioning-repository "branch=main
,name=myrepos/env-repo
,provider=GITHUB
" \
--spec "file://env-spec-mod.yaml
"
回應:
{
"environment": {
"arn": "arn:aws:proton:region-id:123456789012:environment/pr-environment",
"createdAt": "2021-11-18T21:09:15.745000+00:00",
"deploymentStatus": "IN_PROGRESS",
"lastDeploymentAttemptedAt": "2021-11-18T21:25:41.998000+00:00",
"lastDeploymentSucceededAt": "2021-11-18T21:09:15.745000+00:00",
"name": "pr-environment",
"provisioningRepository": {
"arn": "arn:aws:proton:region-id:123456789012:repository/github:myrepos/env-repo",
"branch": "main",
"name": "myrepos/env-repo",
"provider": "GITHUB"
},
"templateMajorVersion": "1",
"templateMinorVersion": "0",
"templateName": "pr-env-template"
}
}
-
執行下列命令以取得並確認狀態:
$
aws proton get-environment \
--name "pr-environment
"
回應:
{
"environment": {
"arn": "arn:aws:proton:region-id:123456789012:environment/pr-environment",
"createdAt": "2021-11-18T21:09:15.745000+00:00",
"deploymentStatus": "SUCCEEDED",
"lastDeploymentAttemptedAt": "2021-11-18T21:25:41.998000+00:00",
"lastDeploymentSucceededAt": "2021-11-18T21:25:41.998000+00:00",
"name": "pr-environment",
"provisioningRepository": {
"arn": "arn:aws:proton:region-id:123456789012:repository/github:myrepos/env-repo",
"branch": "main",
"name": "myrepos/env-repo",
"provider": "GITHUB"
},
"spec": "proton: EnvironmentSpec\nspec:\n ssm_parameter_value: \"test\"\n ssm_another_parameter_value: \"update\"\n",
"templateMajorVersion": "1",
"templateMinorVersion": "1",
"templateName": "pr-env-template"
}
}
-
檢閱由傳送的提取要求 AWS Proton。
-
如果您核准請求,則正在進行佈建。
-
如果您拒絕請求,則會取消環境建立。
-
如果提取請求逾時,則環境建立不完成。
-
將佈建狀態提供給 AWS Proton。
$
aws proton notify-resource-deployment-status-change \
--resource-arn "arn:aws:proton:region-id
:123456789012
:environment/pr-environment
" \
--status "SUCCEEDED
"
取消進行中的環境部署
如果位於中,您可以嘗試取消環境更新部署IN_PROGRESS
。deploymentStatus
AWS Proton 嘗試取消部署。不能保證取消成功。
取消更新部署時,會 AWS Proton 嘗試取消部署,如下列步驟所列。
透過 AWS管理佈建,執 AWS Proton 行下列動作:
使用自我管理佈建,可執 AWS Proton 行下列動作:
如需如何取消環境部署的指示,請參閱〈AWS Proton API參考〉CancelEnvironmentDeployment中的〈〉。
您可以使用控制台或CLI取消進行中的環境。
- AWS Management Console
-
使用主控台取消環境更新部署,如下列步驟所示。
-
在AWS Proton 主控台中,選擇導覽窗格中的 [環境]。
-
在環境清單中,選擇您要取消之部署更新之環境的名稱。
-
如果更新部署狀態為 [進行中],請在 [環境詳細資料] 頁面中選擇 [動作],然後選擇 [取消部署]
-
強制回應會提示您確認要取消。選擇 [取消部署]。
-
您的更新部署狀態設定為「取消」,然後設定為「已取消」以完成取消。
- AWS CLI
-
使用 AWS Proton AWS CLI 取消 IN_ PROGRESS 環境更新部署至新的次要版本 2。
等待條件包含在用於此範例的範本中,以便在更新部署成功之前開始取消。
執行下列命令以取消更新:
$
aws proton cancel-environment-deployment \
--environment-name "MySimpleEnv
"
回應:
{
"environment": {
"arn": "arn:aws:proton:region-id:123456789012:environment/MySimpleEnv",
"createdAt": "2021-04-02T17:29:55.472000+00:00",
"deploymentStatus": "CANCELLING",
"lastDeploymentAttemptedAt": "2021-04-02T18:15:10.243000+00:00",
"lastDeploymentSucceededAt": "2021-04-02T17:48:26.307000+00:00",
"name": "MySimpleEnv",
"protonServiceRoleArn": "arn:aws:iam::123456789012:role/service-role/ProtonServiceRole",
"spec": "proton: EnvironmentSpec\n\nspec:\n my_sample_input: hello\n my_other_sample_input: everybody\n",
"templateMajorVersion": "1",
"templateMinorVersion": "1",
"templateName": "simple-env"
}
}
執行下列命令以取得並確認狀態:」
$
aws proton get-environment \
--name "MySimpleEnv
"
回應:
{
"environment": {
"arn": "arn:aws:proton:region-id:123456789012:environment/MySimpleEnv",
"createdAt": "2021-04-02T17:29:55.472000+00:00",
"deploymentStatus": "CANCELLED",
"deploymentStatusMessage": "User initiated cancellation.",
"lastDeploymentAttemptedAt": "2021-04-02T18:15:10.243000+00:00",
"lastDeploymentSucceededAt": "2021-04-02T17:48:26.307000+00:00",
"name": "MySimpleEnv",
"protonServiceRoleArn": "arn:aws:iam::123456789012:role/service-role/ProtonServiceRole",
"spec": "proton: EnvironmentSpec\n\nspec:\n my_sample_input: hello\n my_other_sample_input: everybody\n",
"templateMajorVersion": "1",
"templateMinorVersion": "1",
"templateName": "simple-env"
}
}