本文属于机器翻译版本。若本译文内容与英语原文存在差异,则一律以英文原文为准。
步骤 2:将应用程序部署到 Auto Scaling 组
在此步骤中,您将在 Auto Scaling 组中将修订版部署到单个 Amazon EC2 实例。
创建部署 (CLI)
-
调用 create-application 命令以创建一个名为
SimpleDemoApp
的应用程序。aws deploy create-application --application-name SimpleDemoApp
-
您应该已经按照步骤 2:为创建服务角色 CodeDeploy中的说明创建了一个服务角色。服务角色将提供CodeDeploy访问您的 Amazon EC2 实例以扩展(读取)其标签的权限。您将需要服务角色 ARN。要获取服务角色 ARN,请按照获取服务角色 ARN (CLI) 中的说明操作。
-
现在您有了服务角色 ARN,请调用create-deployment-group创建名为的部署组的命令
SimpleDemoDG
,与名为的应用程序相关联SimpleDemoApp
,使用名为的 Auto Scaling 组CodeDeployDemo-AS-Group
部署配置名为CodeDeployDefault.OneAtATime
,使用指定的服务角色 ARN。注意
这个create-deployment-group命令支持创建触发器,这些触发器会导致向主题订阅者发送有关部署和实例中指定事件的 Amazon SNS 通知。该命令还支持在监控 Amazon 中的阈值时自动回滚部署和设置警报以停止部署的选项CloudWatch警报已满足。本教程中不包括这些操作的命令。
在本地 Linux、macOS 或 Unix 计算机上:
aws deploy create-deployment-group \ --application-name SimpleDemoApp \ --auto-scaling-groups CodeDeployDemo-AS-Group \ --deployment-group-name SimpleDemoDG \ --deployment-config-name CodeDeployDefault.OneAtATime \ --service-role-arn
service-role-arn
在本地 Windows 计算机上:
aws deploy create-deployment-group --application-name SimpleDemoApp --auto-scaling-groups CodeDeployDemo-AS-Group --deployment-group-name SimpleDemoDG --deployment-config-name CodeDeployDefault.OneAtATime --service-role-arn
service-role-arn
-
调用 create-deployment 命令,使用指定位置的修订创建一个与名为
SimpleDemoApp
的应用程序、名为CodeDeployDefault.OneAtATime
的部署配置、名为SimpleDemoDG
的部署组相关联的部署。对于亚马逊 Linux 和 RHEL 亚马逊 EC2 实例,从本地 Linux、macOS 或 Unix 计算机调用
对于中国(北京)区域:
aws deploy create-deployment \ --application-name SimpleDemoApp \ --deployment-config-name CodeDeployDefault.OneAtATime \ --deployment-group-name SimpleDemoDG \ --s3-location bucket=aws-codedeploy-cn-north-1,bundleType=zip,key=samples/latest/SampleApp_Linux.zip
对于中国(宁夏)区域:
aws deploy create-deployment \ --application-name SimpleDemoApp \ --deployment-config-name CodeDeployDefault.OneAtATime \ --deployment-group-name SimpleDemoDG \ --s3-location bucket=aws-codedeploy-cn-northwest-1,bundleType=zip,key=samples/latest/SampleApp_Linux.zip
对于亚马逊 Linux 和 RHEL 亚马逊 EC2 实例,从本地 Windows 计算机调用
对于中国(北京)区域:
aws deploy create-deployment --application-name SimpleDemoApp --deployment-config-name CodeDeployDefault.OneAtATime --deployment-group-name SimpleDemoDG --s3-location bucket=aws-codedeploy-cn-north-1,bundleType=zip,key=samples/latest/SampleApp_Linux.zip
对于中国(宁夏)区域:
aws deploy create-deployment --application-name SimpleDemoApp --deployment-config-name CodeDeployDefault.OneAtATime --deployment-group-name SimpleDemoDG --s3-location bucket=aws-codedeploy-cn-northwest-1,bundleType=zip,key=samples/latest/SampleApp_Linux.zip
对于 Windows Server 亚马逊 EC2 实例,从本地 Linux、macOS 或 Unix 计算机调用
对于中国(北京)区域:
aws deploy create-deployment \ --application-name SimpleDemoApp \ --deployment-config-name CodeDeployDefault.OneAtATime \ --deployment-group-name SimpleDemoDG \ --s3-location bucket=aws-codedeploy-cn-north-1,bundleType=zip,key=samples/latest/SampleApp_Windows.zip
对于中国(宁夏)区域:
aws deploy create-deployment \ --application-name SimpleDemoApp \ --deployment-config-name CodeDeployDefault.OneAtATime \ --deployment-group-name SimpleDemoDG \ --s3-location bucket=aws-codedeploy-cn-northwest-1,bundleType=zip,key=samples/latest/SampleApp_Windows.zip
对于 Windows 服务器亚马逊 EC2 实例,从本地 Windows 计算机调用
对于中国(北京)区域:
aws deploy create-deployment --application-name SimpleDemoApp --deployment-config-name CodeDeployDefault.OneAtATime --deployment-group-name SimpleDemoDG --s3-location bucket=aws-codedeploy-cn-north-1,bundleType=zip,key=samples/latest/SampleApp_Windows.zip
对于中国(宁夏)区域:
aws deploy create-deployment --application-name SimpleDemoApp --deployment-config-name CodeDeployDefault.OneAtATime --deployment-group-name SimpleDemoDG --s3-location bucket=aws-codedeploy-cn-northwest-1,bundleType=zip,key=samples/latest/SampleApp_Windows.zip
注意
目前,CodeDeploy不提供部署到 Ubuntu 服务器亚马逊 EC2 实例的示例修订版。要自己创建修订,请参阅使用 CodeDeploy 的应用程序修订。
-
调用 get-deployment 命令以确保部署已成功。
在调用此命令之前,您需要应该已经通过调用 create-deployment 命令返回的部署 ID。如果需要再次获取部署 ID,请针对名为
SimpleDemoApp
的应用程序和名为SimpleDemoDG
的部署组调用 list-deployments 命令:aws deploy list-deployments --application-name SimpleDemoApp --deployment-group-name SimpleDemoDG --query "deployments" --output text
现在,使用部署 ID 调用 get-deployment 命令:
aws deploy get-deployment --deployment-id
deployment-id
--query "deploymentInfo.status" --output text请在返回的值为
Succeeded
之后继续。
创建部署(控制台)
-
您应该已经按照步骤 2:为创建服务角色 CodeDeploy中的说明创建了一个服务角色。该服务角色将向 CodeDeploy 授予访问您的实例以展开(读取)其标签的权限。在使用 CodeDeploy 控制台部署应用程序修订之前,您需要服务角色 ARN。要获取服务角色 ARN,请按照获取服务角色 ARN(控制台) 中的说明操作。
-
现在您已拥有服务角色 ARN,可以开始使用 CodeDeploy 控制台部署您的应用程序修订。
登录到Amazon Web Services Management Console然后打开CodeDeploy控制台在https://console.aws.amazon.com/codedeploy
。 注意
使用您设置的同一个用户登录CodeDeploy 入门。
在导航窗格中,展开部署,然后选择应用程序。
-
选择创建应用程序。
-
选择自定义应用程序。
-
在 Application name (应用程序名称) 中,输入
SimpleDemoApp
。 -
在计算平台中,选择 EC2/本地。
-
选择创建应用程序。
-
在部署组选项卡中,选择创建部署组。
-
在 Deployment group name (部署组名称) 中,输入
SimpleDemoDG
。 -
在服务角色中,选择您的服务角色的名称。
-
在部署类型中,选择就地。
-
在环境配置选择自动缩放群组,然后选择
CodeDeployDemo-AS-Group
。 -
在部署配置,选择CodeDeployDefault。OneAtTime。
-
清除启用负载均衡。
-
选择 Create deployment group (创建部署组)。
-
在“部署组”页面中,选择创建部署。
-
在修订版类型,选择我的应用程序存储在 Amazon S3 中。
-
在修订位置中,输入您的操作系统的示例应用程序的位置和区域。
适用于亚马逊 Linux 和 RHEL 亚马逊 EC2 实例
对于中国(北京)区域:
https://s3.cn-north-1.amazonaws.com.cn/aws-codedeploy-cn-north-1/samples/latest/SampleApp_Linux.zip
对于中国(宁夏)区域:
https://s3.cn-northwest-1.amazonaws.com.cn/aws-codedeploy-cn-northwest-1/samples/latest/SampleApp_Linux.zip
适用于 Windows 服务器亚马逊 EC2 实例
对于中国(北京)区域:
https://s3.cn-north-1.amazonaws.com.cn/aws-codedeploy-cn-north-1/samples/latest/SampleApp_Windows.zip
对于中国(宁夏)区域:
https://s3.cn-northwest-1.amazonaws.com.cn/aws-codedeploy-cn-northwest-1/samples/latest/SampleApp_Windows.zip
对于 Ubuntu 服务器亚马逊 EC2 实例
键入存储在 Amazon S3 中的自定义应用程序修订版本的位置。
-
保留部署描述为空。
-
展开高级。
-
选择 Create deployment (创建部署)。
注意
如果显示失败而不是成功,则您可能需要尝试监控您的部署并进行故障排除中的一些方法(使用应用程序名称
SimpleDemoApp
和部署组名称SimpleDemoDG
)。