

本文為英文版的機器翻譯版本，如內容有任何歧義或不一致之處，概以英文版為準。

# 部署策略
<a name="deployment-strategies"></a>

部署策略會定義您要如何交付軟體。組織會根據其商業模式遵循不同的部署策略。有些選擇交付經過完整測試的軟體，有些則可能希望使用者提供意見回饋，並讓其使用者在開發功能 （例如 Beta 版） 下進行評估。下節討論各種部署策略。

## 就地部署：
<a name="in-place-deployments"></a>

在此策略中，會停止每個運算資源上先前的應用程式版本、安裝最新的應用程式，並啟動和驗證應用程式的新版本。這可讓應用程式部署以對基礎基礎設施的最小干擾繼續。透過就地部署，您可以部署應用程式，而無需建立新的基礎設施；不過，在這些部署期間，應用程式的可用性可能會受到影響。此方法也會將與建立新資源相關的基礎設施成本和管理開銷降至最低。您可以使用負載平衡器，讓每個執行個體在部署期間取消註冊，然後在部署完成後還原至服務。就地部署可以是all-at-once部署、假設服務中斷，或作為滾動更新完成。 AWS CodeDeploy 而 [AWS Elastic Beanstalk](https://aws.amazon.com/elasticbeanstalk/) 提供one-at-a-time、half-at-a-time和all-at-once部署組態。

## 藍/綠部署
<a name="blue-green-deployments"></a>

[藍/綠部署](https://docs.aws.amazon.com/whitepapers/latest/overview-deployment-options/bluegreen-deployments.html)，有時稱為紅/黑部署，是一種透過在執行應用程式不同版本之兩個相同環境之間轉移流量來釋放應用程式的技術。藍/綠部署可協助您在應用程式更新期間將停機時間降至最低，降低停機時間和回復功能的風險。

藍/綠部署可讓您啟動應用程式的新版本 （綠色） 與舊版本 （藍色），並在重新路由流量到新版本之前監控和測試新版本，並在問題偵測時復原。

## Canary 部署
<a name="canary-deployments"></a>

[Canary 部署](https://wa.aws.amazon.com/wellarchitected/2020-07-02T19-33-23/wat.concept.canary-deployment.en.html)的目的是降低部署會影響工作負載的新版本的風險。方法會逐步部署新版本，讓新使用者以緩慢的方式看見。隨著您對部署的信心，您將部署它來取代目前的版本。

## 線性部署
<a name="linear-deployments"></a>

線性部署表示以相等增量移動流量，每個增量之間的分鐘數相等。您可從預先指定的線性選項中指定每次增量的流量轉移百分比例，以及在每個增量之間的分鐘數。

## All-at-once部署
<a name="all-at-once-deployments"></a>

 All-at-once部署表示所有流量都會一次從原始環境轉移到替代環境。