面向所有环境的常规选项 - AWS Elastic Beanstalk

本文属于机器翻译版本。若本译文内容与英语原文存在差异,则一律以英文原文为准。

面向所有环境的常规选项

aws:autoscaling:asg

配置环境的 Auto Scaling 组。有关更多信息,请参阅Elastic Beanstalk 环境的 Auto Scaling 组

命名空间: aws:autoscaling:asg
名称 描述 默认 有效值

Availability Zones

可用区 (AZs) 是一个 AWS 区域内的不同位置,经过精心设计,可与其他区域的故障隔离开来AZs。它们为同一地区的其他人提供低成本、低延迟AZs的网络连接。AZs为您的实例选择数量。

Any

Any

Any 1

Any 2

Any 3

Cooldown

冷却时间有助于防止 Amazon A EC2 uto Scaling 在之前活动的影响显现之前启动额外的扩展活动。冷却时间是一个调整活动完成后、另一个调整活动开始前的时长(秒)。

360

010000

Custom Availability Zones

AZs为您的实例定义。

us-east-1a

us-east-1b

us-east-1c

us-east-1d

us-east-1e

eu-central-1

EnableCapacityRebalancing

指定是否为 Auto Scaling 组中的 Spot 实例启用容量再平衡功能。有关更多信息,请参阅 Amazon A EC2 uto Scaling 用户指南中的容量重新平衡

只有在 aws:ec2:instances 命名空间里将 EnableSpot 设置为 true,并且 Auto Scaling 组中至少有一个 Spot 实例时,此选项才会相关联。

false

true

false

MinSize

您希望 Auto Scaling 组中拥有的最小实例数。

1

110000

MaxSize

您希望 Auto Scaling 组中拥有的最大实例数。

4

110000

aws:autoscaling:launchconfiguration

为您的环境配置亚马逊弹性计算云 (AmazonEC2) 实例。

用于您的环境的实例是使用 Amazon EC2 启动模板或 Auto Scaling 群组启动配置资源创建的。以下选项适用于这两种资源类型。

有关更多信息,请参阅 您的 Elastic Beanstalk 环境的 Amazon EC2 实例您还可以在亚马逊EC2用户指南的亚马逊EBS章节中参考有关亚马逊 Elastic Block Store (EBS) 的更多信息。

命名空间: aws:autoscaling:launchconfiguration
名称 描述 默认 有效值

DisableIMDSv1

设置为true以禁用实例元数据服务版本 1 (IMDSv1)。

根据平台操作系统,您的环境的实例默认如下所示:

  • Windows 服务器AL2及更早版本 — 同时启用IMDSv1和 IMDSv2

  • AL2023 — 仅启用 IMDSv2

有关更多信息,请参阅配置实例元数据服务(Amazon Linux)。

配置实例元数据服务(Windows 服务器)。

false – 基于 Windows 服务器、Amazon Linux 2 及更早版本的平台

true – 基于 Amazon Linux 2023 的平台

true

false

EC2KeyName

您可以使用 key pair 安全地登录您的EC2实例。

注意

如果您使用 Elastic Beanstalk 控制台创建环境,则无法在配置文件中设置此选项。控制台使用建议的值覆盖此选项。

IamInstanceProfile

实例配置文件允 AWS Identity and Access Management 许 (IAM) 用户和 AWS 服务访问临时安全证书进行 AWS API呼叫。指定实例配置文件的名称或其名称ARN。

示例:

  • aws-elasticbeanstalk-ec2-role

  • arn:aws:iam::123456789012:instance-profile/aws-elasticbeanstalk-ec2-role

实例配置文件名称或ARN。

ImageId

您可以通过指定自己的自定义 AMI ID 来覆盖默认的 Amazon 系统映像 (AMI)。

例如:ami-1f316660

InstanceType

用于在 Elastic Beanstalk 环境中运行您的应用程序的实例类型。

重要

InstanceType 选项已过时。它被 InstanceTypes 命名空间中更新、功能更强大的 aws:ec2:instances 选项所取代。您可以使用新选项为环境指定一个或多个实例类型的列表。该列表上的第一个值等于此处描述的 aws:autoscaling:launchconfiguration 命名空间中包含的 InstanceType 选项的值。我们建议您使用新选项指定实例类型。如果指定,则新选项优先于前一个选项。有关更多信息,请参阅 aws:ec2:instances 命名空间

可用的实例类型取决于使用的可用区和区域。如果您选择子网,则包含该子网的可用区将决定可用的实例类型。

因账户和区域而异。

一种EC2实例类型。

因账户、区域和可用区而异。您可以获得按这些值筛选的 Amazon EC2 实例类型列表。有关更多信息,请参阅亚马逊用户指南中的可用实例类型亚马逊EC2用户指南中的可用实例类型。EC2

LaunchTemplateTagPropagationEnabled

设置为 true,以允许将环境标签传播到为环境预调配的特定资源的启动模板。

Elastic Beanstalk 只能将标签传播到以下资源的启动模板:

  • EBS卷

  • EC2 实例

  • EC2 网络接口

  • AWS CloudFormation 启动定义资源的模板

之所以存在此限制,是因为 CloudFormation 仅允许在为特定资源创建模板时使用标签。有关更多信息,请参阅TagSpecificationAWS CloudFormation 用户指南》

重要
  • 将现有环境的此选项值从更改 falsetrue 对于先前存在的标签可能是一项重大更改。

  • 启用此功能后,标签的传播将需要EC2更换,这可能会导致停机。您可以启用滚动更新以批量应用配置更改,并防止在更新过程中出现停机。有关更多信息,请参阅 配置更改

有关启动模板的更多信息,请参阅以下内容:

有关此选项的更多信息,请参阅 标签传播到启动模板

false

true

false

MonitoringInterval

您希望返回 Amazon CloudWatch 指标的时间间隔(以分钟为单位)。

5 minute

1 minute

5 minute

SecurityGroups

列出IDs要分配给 Auto Scaling 组中EC2实例的 Amazon EC2 安全组,以便为实例定义防火墙规则。

您可以提供一串以逗号分隔的值,其中包含现有的 Amazon EC2 安全组IDs或对模板中创建的 AWS::EC2::SecurityGroup 资源的引用。

elasticbeanstalk-default

SSHSourceRestriction

用于锁定对环境的SSH访问权限。例如,您可以锁定对EC2实例的SSH访问权限,以便只有堡垒主机才能访问私有子网中的实例。

该字符串采用以下形式:

protocol, fromPort, toPort, source_restriction

protocol

入口流量规则的协议。

fromPort

起始端口号。

toPort

结尾端口号。

source_restriction

无类域间路由 (CIDR) 范围或流量必须路由的安全组。使用安全组 ID 指定安全组。

要指定来自其他账户的安全组,请在安全组 ID 之前添加 AWS 账户 ID,并用正斜杠分隔。另一个账户必须位于同一 AWS 区域。注意语法:aws-account-id/security-group-id. 例如:123456789012/sg-99999999

示例:
  • tcp, 22, 22, 54.240.196.185/32

  • tcp, 22, 22, my-security-group-id

  • tcp, 22, 22, 123456789012/their-security-group-id

BlockDeviceMappings

在 Auto Scaling 组中的所有实例上附加额外的 Amazon EBS 卷或实例存储卷。

映射实例存储卷时,您只需将设备名称映射到卷名称。但是,我们建议您在映射 Amazon EBS 卷时,另外指定以下部分或全部字段(每个字段必须用冒号分隔):

  • 快照 ID

  • 大小(GB)

  • 终止时删除(truefalse

  • 存储类型(仅适用于 gp3gp2standardst1sc1io1

  • IOPS(仅适用于gp3io1

  • 吞吐量(仅适用于 gp3

以下示例连接了三个 Amazon EBS 卷、一个空白 100GB gp2 卷和一个快照、一个预配置 IOPS 2000 的空白 20GB io1 卷以及一个实例存储卷。ephemeral0如果实例类型支持,则可以附加多个实例存储卷。

/dev/sdj=:100:true:gp2,/dev/sdh=snap-51eef269,/dev/sdi=:20:true:io1:2000,/dev/sdb=ephemeral0

  • 大小 — 必须在 500 到 16384 GiB 之间

  • 吞吐量 — 必须在每秒 125 到 1000 兆字节之间(MiB/s)

RootVolumeType

用于连接到您的环境EC2实例的 Amazon 根 Amazon EBS 卷的卷类型(磁性、通用SSD或预配置 IOPSSSD)。

因平台而异。

对于机械硬盘存储,为 standard

gp2gp3用于一般用途SSD。

io1用于已配置。IOPS SSD

RootVolumeSize

Amazon 根卷的存储容EBS量,以整数 GB 为单位。

如果设置为已配置RootVolumeType,则为必填项。IOPS SSD

例如,"64"

磁性存储和一般用途因平台而异SSD。

对于已置备,则为IOPSSSD无。

1016384 GB 用于一般用途并已预配置。IOPS SSD

对于机械硬盘存储,为 81024 GB。

RootVolumeIOPS

已配置的IOPSSSD根卷或通用gp3SSD根卷所需的每秒输入/输出操作 (IOPS)。

与卷大小的最大比例为 500 比 1。IOPS例如,容量为 3000 的卷IOPS必须至少为 6 GiB。

10020000于 io1 已配置的IOPSSSD根卷,则为。

300016000用于通用gp3SSD根卷。

RootVolumeThroughput

为连接到您的环境实例的 Amazon EBS 根卷预配置所需的吞吐量(每秒 MiB/s)。EC2

注意

此选项仅适用于 gp3 存储类型。

1251000

aws:autoscaling:scheduledaction

为环境的 Auto Scaling 组配置计划操作。对于每个操作,除了指定选项名称、命名空间和每个设置的值之外,还要指定 resource_name。有关示例,请参阅 aws:autoscaling:scheduledaction 命名空间

命名空间: aws:autoscaling:scheduledaction
名称 描述 默认 有效值

StartTime

对于一次性操作,请选择运行操作的日期和时间。对于重复操作,请选择激活操作的时间。

ISO-8601 时间戳在所有计划的扩展操作中都是唯一的。

EndTime

您希望计划的扩展操作停止重复的将来的日期和GMT时间(以 UTC /时区为单位)。如果未指定 EndTime,则操作将根据Recurrence表达式重复。

例如:2015-04-28T04:07:2Z

计划操作结束后,Amazon A EC2 uto Scaling 不会自动恢复到之前的设置。配置第二个计划操作,以根据需要返回原始设置。

ISO-8601 时间戳在所有计划的扩展操作中都是唯一的。

MaxSize

运行操作时要应用的最大实例计数。

010000

MinSize

运行操作时要应用的最小实例计数。

010000

DesiredCapacity

为 Auto Scaling 组设置初始所需容量。在应用计划的操作后,触发器将根据其设置调整所需容量。

010000

Recurrence

您希望计划操作发生的频率。如果不指定循环,则扩展操作仅发生一次,如 StartTime 所指定。

Cron 表达式。

Suspend

设置为 true 可临时停用重复的计划操作。

false

true

false

aws:autoscaling:trigger

为环境的 Auto Scaling 组配置扩展触发器。

注意

此命名空间中的三个选项确定在触发器启用之前触发器指标可超出其定义的限制多长时间。这些选项具有相关性,如下所述:

BreachDuration = Period * EvaluationPeriods

这些选项的默认值(分别是 5、5 和 1)满足此等式。如果您指定不一致的值,Elastic Beanstalk 可能会修改其中某个值,以便等式仍然成立。

命名空间: aws:autoscaling:trigger
名称 描述 默认 有效值

BreachDuration

调用触发器前,指标可以超出所定义限制(如 UpperThresholdLowerThreshold 所指定)的时间(单位:分钟)。

5

1600

LowerBreachScaleIncrement

执行扩展活动时要移除多少EC2个 Amazon 实例。

-1

LowerThreshold

如果测量值低于该违例持续时间值,则会调用触发器。

2000000

020000000

MeasureName

用于 Auto Scaling 触发器的指标。

注意

HealthyHostCountUnhealthyHostCountTargetResponseTime 仅适用于具有专用负载均衡器的环境。对于配置了共享负载均衡器的环境,这些值不是有效指标值。有关负载均衡器类型的更多信息,请参阅 Elastic Beanstalk 环境的负载均衡器

NetworkOut

CPUUtilization

NetworkIn

NetworkOut

DiskWriteOps

DiskReadBytes

DiskReadOps

DiskWriteBytes

Latency

RequestCount

HealthyHostCount

UnhealthyHostCount

TargetResponseTime

Period

指定 Amazon CloudWatch 衡量触发指标的频率。此值是两个连续时间段之间的分钟数。

5

1600

EvaluationPeriods

用于确定是否违例的连续评估期的数量。

1

1600

Statistic

触发器使用的统计数据,例如 Average

Average

Minimum

Maximum

Sum

Average

Unit

触发器度量单位,例如 Bytes

Bytes

Seconds

Percent

Bytes

Bits

Count

Bytes/Second

Bits/Second

Count/Second

None

UpperBreachScaleIncrement

指定在执行扩展活动时要添加多少EC2个 Amazon 实例。

1

UpperThreshold

如果测量值高于该违例持续时间值,则会调用触发器。

6000000

020000000

aws:autoscaling:updatepolicy:rollingupdate

为您环境的 Auto Scaling 组配置滚动更新。

命名空间: aws:autoscaling:updatepolicy:rollingupdate
名称 描述 默认 有效值

MaxBatchSize

滚动更新的每个批次中包含的实例数。

Auto Scaling 组的最小大小的三分之一(舍入到下一个最大整数)

110000

MinInstancesInService

终止其他实例时,Auto Scaling 组中必须处于运行中的最小实例数。

Auto Scaling 组的最小大小,或 Auto Scaling 组的最大大小减一(取二者中的较小值)。

09999

RollingUpdateEnabled

如果为 true,则为环境启用滚动更新。在您需要对 Elastic Beanstalk 软件应用程序进行频繁的少量更新,并且希望避免应用程序停机时,滚动更新很有用。

将此值设置为 true 会自动启用 MaxBatchSizeMinInstancesInServicePauseTime 选项。设置这些选项中的任何选项也会自动将 RollingUpdateEnabled 选项值设置为 true。将此选项设置为 false 会禁用滚动更新。

false

true

false

RollingUpdateType

其中包括三种类型:基于时间的滚动更新、基于运行状况的滚动更新和不可变更新。

基于时间的滚动更新在批次 PauseTime 之间应用。基于运行状况的滚动更新会等新实例通过运行状况检查后再继续下一个批次。不可变更新将启动新 Auto Scaling 组中的一整组实例。

Time

Time

Health

Immutable

PauseTime

Elastic Beanstalk 服务在完成一批实例更新之后到开始下一批实例更新之前要等待的时长(以秒、分钟或小时为单位)。

基于实例类型和容器自动计算。

PT0S*(0 秒)至 PT1H(1 小时)

Timeout

在取消更新之前,等待一个实例批次中的所有实例通过运行状况检查的最长时间(以分钟或小时为单位)。

PT30M(30 分钟)

PT5M*(5 分钟)至 PT1H(1 小时)

* ISO8601 持续时间格式:PT#H#M#S其中每个 # 分别是小时数、分钟数和/或秒数。

aws:ec2:instances

配置环境的实例,包括 Spot 选项。此命名空间是 aws:autoscaling:launchconfigurationaws:autoscaling:asg 的补充。

有关更多信息,请参阅 Elastic Beanstalk 环境的 Auto Scaling 组

命名空间: aws:ec2:instances
名称 描述 默认 有效值

EnableSpot

为您的环境启用 Spot 实例请求。如果为 false,此命名空间中的某些选项不会生效。

false

true

false

InstanceTypes

您希望环境使用的实例类型的逗号分隔列表(例如,t2.micro,t3.micro)。

当未激活 Spot 实例(EnableSpotfalse)时,仅使用列表中的第一种实例类型。

此选项的列表中的第一个实例类型等同于 InstanceType 命名空间中的 aws:autoscaling:launchconfiguration 选项的值。我们不建议使用后一个选项,因为它已经过时了。如果您同时指定两者,则使用 InstanceTypes 选项的列表中的第一个实例类型,并忽略 InstanceType

可用的实例类型取决于使用的可用区和区域。如果您选择子网,则包含该子网的可用区将决定可用的实例类型。

注意

一些较旧的 AWS 账户可能会为 Elastic Beanstalk 提供不支持竞价型实例的默认实例类型(例如 t1.micro)。如果激活 Spot 实例请求,并收到不支持 Spot 的实例类型的相关错误,请务必配置支持 Spot 的实例类型。要选择 Spot 实例类型,请使用 Spot Instance Advisor

当您更新环境配置并从InstanceTypes选项中移除一个或多个实例类型时,Elastic Beanstalk 会终止在EC2任何已删除的实例类型上运行的所有 Amazon 实例。然后,您环境的 Auto Scaling 组根据需要启动新实例,以使用当前指定的实例类型来完成所需的容量。

两种实例类型的列表。

因账户和区域而异。

一到四十种EC2实例类型。我们建议至少两种。

因账户、区域和可用区而异。您可以获得按这些值筛选的 Amazon EC2 实例类型列表。有关更多信息,请参阅亚马逊用户指南中的可用实例类型亚马逊EC2用户指南中的可用实例类型。EC2

实例类型必须均属于同一架构(arm64x86_64i386)。

SupportedArchitectures 也是此命名空间的一部分。如果您为 SupportedArchitectures 提供了任何值,则为 InstanceTypes 输入的值必须属于且仅属于为 SupportedArchitectures 提供的架构之一。

SpotFleetOnDemandBase

扩展环境时,在考虑 Spot 实例之前,Auto Scaling 组预配置的最小按需实例数。

此选项仅在 EnableSpottrue 时有意义。

0

0 命名空间中 MaxSizeaws:autoscaling:asg 选项

SpotFleetOnDemandAboveBasePercentage

Auto Scaling 组在 SpotOnDemandBase 实例之外作为额外容量预配置的按需实例的百分比。

此选项仅在 EnableSpottrue 时有意义。

0 适用于单实例环境

70 适用于负载均衡环境

0100

SpotMaxPrice

您愿意为竞价型实例支付的最高单位小时价格。USD有关竞价型实例最高价格选项的建议,请参阅 Amazon EC2 用户指南中的竞价型实例定价历史记录

此选项仅在 EnableSpottrue 时有意义。

每种实例类型的按需价格。在这种情况下,该选项的值为 null

0.00120.0

null

SupportedArchitectures

以逗号分隔的EC2实例架构类型列表,供您的环境使用。

Elastic Beanstalk 支持基于以下处理器架构的实例类型:

  • AWS Graviton 64 位 Arm 架构 (arm64)

  • 64 位架构 (x86_64)

  • 32 位架构 (i386)

有关处理器架构和 Amazon EC2 实例类型的更多信息,请参阅Amazon EC2 实例类型

arm64

x86_64

i386

注意

大多数 Elastic Beanstalk 平台都不支持 32 位架构 i386。我们建议您选择 x86_64arm64 架构类型代替。

aws:ec2:vpc

将您的环境配置为在自定义的亚马逊虚拟私有云 (AmazonVPC) 中启动资源。如果您未在此命名空间中配置设置,Elastic Beanstalk 会以默认方式启动资源。VPC

命名空间: aws:ec2:vpc
名称 描述 默认 有效值

VPCId

您的亚马逊账号VPC。

Subnets

Auto Scaling 组IDs的一个或多个子网中的一个或多个子网。如果您有多个子网,请将该值指定为一个以逗号分隔的子网字符串IDs(例如)。"subnet-11111111,subnet-22222222"

ELBSubnets

弹性负载均衡器IDs的一个或多个子网的。如果您有多个子网,请将该值指定为一个以逗号分隔的子网字符串IDs(例如)。"subnet-11111111,subnet-22222222"

ELBScheme

指定您internal是否要在亚马逊中创建内部负载均衡器,VPC以便无法从亚马逊外部访问您的 Elastic Beanstalk 应用程序。VPC如果指定 publicinternal 以外的值,Elastic Beanstalk 会忽略此值。

public

public

internal

DBSubnets

包含数据库IDs子网的。仅当您想要将 Amazon RDS 数据库实例作为应用程序的一部分添加时,才会使用此选项。如果您有多个子网,请将该值指定为一个以逗号分隔的子网字符串IDs(例如)。"subnet-11111111,subnet-22222222"

AssociatePublicIpAddress

指定是否在您的 Amazon 中启动带有公有 IP 地址的实例VPC。具有公有 IP 地址的实例不需要NAT设备即可与互联网通信。如果要在单个公有子网中包含您的负载均衡器和实例,则必须将值设置为 true

此选项对单实例环境没有影响,单实例环境中始终有一个带有弹性 IP 地址的 Amazon EC2 实例。该选项与负载平衡、可扩展的环境相关。

true

false

aws:elasticbeanstalk:application

为您的应用程序配置运行状况检查路径。有关更多信息,请参阅 基本运行状况报告

命名空间: aws:elasticbeanstalk:application
名称 描述 默认 有效值

应用程序运行状况检查 URL

运行状况检查请求发送到的路径。如果未设置此路径,则负载均衡器会尝试在端口 80 上TCP建立连接以验证应用程序的运行状况。设置为以开头的路径/以向该路径发送HTTPGET请求。您还可以在路径前加入协议(HTTPHTTPSTCP、、或SSL)和端口,以检查HTTPS连接或使用非默认端口。

注意

如果您使用 Elastic Beanstalk 控制台创建环境,则无法在配置文件中设置此选项。控制台使用建议的值覆盖此选项。

有效值包括:

/(HTTPGET到根路径)

/health

HTTPS:443/

HTTPS:443/health

EB CLI 和 Elastic Beanstalk 控制台为上述选项应用推荐值。如果您需要使用配置文件来配置相同的项,则必须删除这些设置。有关更多信息,请参阅 建议值

aws:elasticbeanstalk:application:environment

为您的应用程序配置环境属性。

命名空间: aws:elasticbeanstalk:application:environment
名称 描述 默认 有效值

任意环境变量名称。

传入密钥-值对。

任意环境变量值。

请参阅环境属性和其他软件设置了解更多信息。

aws:elasticbeanstalk:cloudwatch:logs

为应用程序配置实例日志流式传输。

命名空间: aws:elasticbeanstalk:cloudwatch:logs
名称 描述 默认 有效值

StreamLogs

指定是否在 CloudWatch 日志中为代理和部署日志创建组,以及是否从环境中的每个实例流式传输日志。

false

true

false

DeleteOnTerminate

指定是否在环境终止后删除日志组。如果为 false,则日志保留 RetentionInDays 天。

false

true

false

RetentionInDays

日志事件在到期前保留的天数。

7

1、3、5、7、14、30、60、90、120、150、180、365、400、545、731、1827、3653

aws:elasticbeanstalk:cloudwatch:logs:health

为应用程序配置环境运行状况日志流式传输。

命名空间: aws:elasticbeanstalk:cloudwatch:logs:health
名称 描述 默认 有效值

HealthStreamingEnabled

对于启用了增强型运行状况报告的环境,指定是否在环境运行状况 CloudWatch 日志中创建群组并存档 Elastic Beanstalk 环境运行状况数据。有关启用增强型运行状况的信息,请参阅 aws:elasticbeanstalk:healthreporting:system

false

true

false

DeleteOnTerminate

指定是否在终止环境后删除日志组。如果为 false,则运行状况数据将保留 RetentionInDays 天。

false

true

false

RetentionInDays

在存档的运行状况数据过期前要保留其的天数。

7

1、3、5、7、14、30、60、90、120、150、180、365、400、545、731、1827、3653

aws:elasticbeanstalk:command

为您的应用程序代码配置部署策略。有关更多信息,请参阅 部署策略和设置

命名空间: aws:elasticbeanstalk:command
名称 描述 默认 有效值

DeploymentPolicy

选择应用程序版本部署的部署策略

注意

如果您使用 Elastic Beanstalk 控制台创建环境,则无法在配置文件中设置此选项。控制台使用建议的值覆盖此选项。

AllAtOnce

AllAtOnce

Rolling

RollingWithAdditionalBatch

Immutable

TrafficSplitting

Timeout

等待实例完成执行命令的时间(单位:秒)。

Elastic Beanstalk 内部向 Timeout 值添加 240 秒(4 分钟)。例如,默认的有效超时为 840 秒(600 + 240)或 14 分钟。

600

13600

BatchSizeType

中指定的数字类型BatchSize

Percentage

Percentage

Fixed

BatchSize

Auto Scaling 组中要同时执行部署的 Amazon EC2 实例的百分比或固定数量。有效值因使用的BatchSizeType设置而异。

100

1100 (Percentage)。

1aws: autoscaling: asg:: () MaxSize Fixed

IgnoreHealthCheck

不要由于运行状况检查失败而取消部署。

false

true

false

aws:elasticbeanstalk:environment

配置您的环境的架构和服务角色。

命名空间: aws:elasticbeanstalk:environment
名称 描述 默认 有效值

EnvironmentType

设置SingleInstance为可启动一个没有负载均衡器的EC2实例。

LoadBalanced

SingleInstance

LoadBalanced

ServiceRole

Elastic Beanstalk 用来管理环境资源的IAM角色名称。指定角色名称(可选择以自定义路径为前缀)或其ARN名称。

示例:

  • aws-elasticbeanstalk-service-role

  • custom-path/custom-role

  • arn:aws:iam::123456789012:role/aws-elasticbeanstalk-service-role

IAM角色名、路径/名称或 ARN

LoadBalancerType

用于环境的负载均衡器的类型。有关更多信息,请参阅 Elastic Beanstalk 环境的负载均衡器

classic

classic

application

network

LoadBalancerIsShared

指定环境的负载均衡器是专用的还是共享的。只能为 Application Load Balancer 设置此选项。环境创建后无法更改。

当为 false 时,环境具有自己的专用负载均衡器(由 Elastic Beanstalk 创建和管理)。当为 true 时,环境使用共享的负载均衡器,该负载均衡器由您创建并在 aws:elbv2:loadbalancer 命名空间的 SharedLoadBalancer 选项中指定。

false

true

false

aws:elasticbeanstalk:environment:process:default

配置您的环境的默认过程。

命名空间: aws:elasticbeanstalk:environment:process:default
名称 描述 默认 有效值

DeregistrationDelay

在取消注册之前等待活动请求完成的时间(单位:秒)。

20

03600

HealthCheckInterval

Elastic Load Balancing 检查应用程序的亚马逊EC2实例运行状况的时间间隔,以秒为单位。

使用 Classic 或应用程序负载均衡器:15

使用网络负载均衡器:30

使用 Classic 或应用程序负载均衡器:5300

使用网络负载均衡器:1030

HealthCheckPath

健康检查HTTP请求的发送路径。

/

可路由路径。

HealthCheckTimeout

在运行状况检查期间等待响应的时间(单位:秒)。

此选项仅适用于使用应用程序负载均衡器的环境。

5

160

HealthyThresholdCount

Elastic Load Balancing 更改实例运行状况状态前的连续成功请求数。

使用 Classic 或应用程序负载均衡器:3

使用网络负载均衡器:5

210

MatcherHTTPCode

以逗号分隔的HTTP代码列表,表示实例运行正常。

此选项仅适用于使用网络或应用程序负载均衡器的环境。

200

使用应用程序负载均衡器:200499

使用网络负载均衡器:200399

Port

进程侦听的端口。

80

165535

Protocol

进程使用的协议。

使用应用程序负载均衡器时,您只能将此选项设置为 HTTPHTTPS

使用网络负载均衡器时,您只能将此选项设置为 TCP

使用 Classic 或应用程序负载均衡器:HTTP

使用网络负载均衡器:TCP

TCP

HTTP

HTTPS

StickinessEnabled

设置为 true 可启用粘性会话。

此选项仅适用于使用应用程序负载均衡器的环境。

'false'

'false'

'true'

StickinessLBCookieDuration

粘性会话 Cookie 的生存期(单位:秒)

此选项仅适用于使用应用程序负载均衡器的环境。

86400 (一天)

1604800

StickinessType

设置为 lb_cookie 可以为粘性会话使用 Cookie。

此选项仅适用于使用应用程序负载均衡器的环境。

lb_cookie

lb_cookie

UnhealthyThresholdCount

Elastic Load Balancing 更改实例运行状况状态前的连续失败请求数。

5

210

aws:elasticbeanstalk:environment:process:process_name

配置您的环境的其他过程。

命名空间: aws:elasticbeanstalk:environment:process:process_name
名称 描述 默认 有效值

DeregistrationDelay

在取消注册之前等待活动请求完成的时间(单位:秒)。

20

03600

HealthCheckInterval

Elastic Load Balancing 检查应用程序的亚马逊EC2实例运行状况的时间间隔,以秒为单位。

使用 Classic 或应用程序负载均衡器:15

使用网络负载均衡器:30

使用 Classic 或应用程序负载均衡器:5300

使用网络负载均衡器:1030

HealthCheckPath

健康检查HTTP请求的发送路径。

/

可路由路径。

HealthCheckTimeout

在运行状况检查期间等待响应的时间(单位:秒)。

此选项仅适用于使用应用程序负载均衡器的环境。

5

160

HealthyThresholdCount

Elastic Load Balancing 更改实例运行状况状态前的连续成功请求数。

使用 Classic 或应用程序负载均衡器:3

使用网络负载均衡器:5

210

MatcherHTTPCode

以逗号分隔的HTTP代码列表,表示实例运行正常。

此选项仅适用于使用网络或应用程序负载均衡器的环境。

200

使用应用程序负载均衡器:200499

使用网络负载均衡器:200399

Port

进程侦听的端口。

80

165535

Protocol

进程使用的协议。

使用应用程序负载均衡器时,您只能将此选项设置为 HTTPHTTPS

使用网络负载均衡器时,您只能将此选项设置为 TCP

使用 Classic 或应用程序负载均衡器:HTTP

使用网络负载均衡器:TCP

TCP

HTTP

HTTPS

StickinessEnabled

设置为 true 可启用粘性会话。

此选项仅适用于使用应用程序负载均衡器的环境。

'false'

'false'

'true'

StickinessLBCookieDuration

粘性会话 Cookie 的生存期(单位:秒)

此选项仅适用于使用应用程序负载均衡器的环境。

86400 (一天)

1604800

StickinessType

设置为 lb_cookie 可以为粘性会话使用 Cookie。

此选项仅适用于使用应用程序负载均衡器的环境。

lb_cookie

lb_cookie

UnhealthyThresholdCount

Elastic Load Balancing 更改实例运行状况状态前的连续失败请求数。

5

210

aws:elasticbeanstalk:environment:proxy:staticfiles

您可以使用以下命名空间来配置代理服务器提供静态文件。当代理服务器收到对指定路径下的某个文件的请求时,它将直接提供此文件,而不是将请求路由至您的应用程序。这将减少您的应用程序必须处理的请求的数量。

在源代码中将代理服务器提供的路径映射到包含静态资产的文件夹。在此命名空间中定义的每个选项都映射不同的路径。

注意

此命名空间适用于基于 Amazon Linux 2 的平台分支。如果您的环境使用基于 Amazon LinuxAMI(之前的 Amazon Linux 2)的平台版本,特定于平台的选项请参阅以了解平台特定的静态文件命名空间。

命名空间: aws:elasticbeanstalk:environment:proxy:staticfiles
名称

代理服务器提供文件的路径。值以 / 开始。

例如,指定 /images 以在 subdomain.eleasticbeanstalk.com/images 提供文件。

包含文件的文件夹名称。

例如,指定 staticimages 以在源代码包顶层从名为 staticimages 的文件夹中提供文件。

aws:elasticbeanstalk:healthreporting:system

为您的环境配置增强型运行状况报告。

命名空间: aws:elasticbeanstalk:healthreporting:system
名称 描述 默认 有效值

SystemType

运行状况报告系统(基本增强)。增强型运行状况报告需要一个服务角色和一个版本 2 或更高的平台版本

basic

basic

enhanced

ConfigDocument 描述要发布到的环境和实例指标的JSON文档 CloudWatch。

EnhancedHealthAuthEnabled

为内部启用授权,Elastic Beanstalk 使用API该授权将来自您的环境实例的增强运行状况信息传递给 Elastic Beanstalk 服务。

有关更多信息,请参阅 增强型运行状况角色

注意

此选项仅适用于增强型运行状况报告(例如 SystemType 设置为 enhanced 时)。

true

true

false

HealthCheckSuccessThreshold

降低阈值以便实例能够通过运行状况检查。

注意

如果您使用 Elastic Beanstalk 控制台创建环境,则无法在配置文件中设置此选项。控制台使用建议的值覆盖此选项。

Ok

Ok

Warning

Degraded

Severe

aws:elasticbeanstalk:hostmanager

将您的环境中的EC2实例配置为将轮换日志上传到 Amazon S3。

命名空间: aws:elasticbeanstalk:hostmanager
名称 描述 默认 有效值

LogPublicationControl

将您的应用程序的 Amazon EC2 实例的日志文件复制到与您的应用程序关联的 Amazon S3 存储桶中。

false

true

false

aws:elasticbeanstalk:managedactions

为您的环境配置托管平台更新。

命名空间: aws:elasticbeanstalk:managedactions
名称 描述 默认 有效值

ManagedActionsEnabled

启用托管平台更新

在将此项设置为 true 时,还必须指定 PreferredStartTimeUpdateLevel

false

true

false

PreferredStartTime

在中为托管操作配置维护时段UTC。

例如,"Tue:09:00"

日期和时间

day:hour:minute

格式的日期和时间。

ServiceRoleForManagedUpdates

Elastic Beanstalk 用来为您的环境执行托管平台更新的IAM角色的名称。

您可以使用为 ServiceRole 命名空间的 aws:elasticbeanstalk:environment 选项指定同一个角色,也可以使用账户的托管更新服务相关角色。在后一种情况下,如果账户还没有托管更新服务相关角色,Elastic Beanstalk 会创建该角色。

ServiceRole 相同

AWSServiceRoleForElasticBeanstalkManagedUpdates

aws:elasticbeanstalk:managedactions:platformupdate

为您的环境配置托管平台更新。

命名空间: aws:elasticbeanstalk:managedactions:platformupdate
名称 描述 默认 有效值

UpdateLevel

要通过托管平台更新应用的最高级别的更新。平台已版本化 major.minor.patch。 例如,2.0.8 的主版本为 2,次要版本为 0,补丁版本为 8。

patch 仅适用于修补版本更新。

minor 适用于次版本更新和修补版本更新。

InstanceRefreshEnabled

启用每周实例替换。

需要将 ManagedActionsEnabled 设置为 true

false

true

false

aws:elasticbeanstalk:monitoring

将您的环境配置为终止未通过运行状况检查的EC2实例。

命名空间: aws:elasticbeanstalk:monitoring
名称 描述 默认 有效值

Automatically Terminate Unhealthy Instances

如果实例无法通过运行状况检查,请将其终止。

注意

此选项仅在早期环境上受支持。它根据能够达到实例的运行状况及其他基于实例的指标确定了实例的运行状况。

Elastic Beanstalk 不提供根据应用程序运行状况自动终止实例的方法。

true

true

false

aws:elasticbeanstalk:sns:topics

为您的环境配置通知。

命名空间: aws:elasticbeanstalk:sns:topics
名称 描述 默认 有效值

Notification Endpoint

在该端点处,系统会通知您对应用程序产生影响的重要事件。

注意

如果您使用 Elastic Beanstalk 控制台创建环境,则无法在配置文件中设置此选项。控制台使用建议的值覆盖此选项。

Notification Protocol

用于向您的端点发送通知的协议。

email

http

https

email

email-json

sqs

Notification Topic ARN

您订阅的主题的 Amazon 资源名称 (ARN)。

Notification Topic Name

已订阅主题的名称。

aws:elasticbeanstalk:sqsd

为工作线程环境配置 Amazon SQS 队列。

命名空间: aws:elasticbeanstalk:sqsd
名称 描述 默认 有效值

WorkerQueueURL

工作线程环境层中的守护程序从中读取消息的队列。URL

注意

当你不指定值时,Elastic Beanstalk 自动创建的队列就是标准的亚马逊队列。 SQS当您提供值时,您可以提供标准队列URL或 A FIFOmazon SQS 队列的。请注意,如果您提供FIFO队列,则不支持定期任务

自动生成

如果您不指定值,则 Elastic Beanstalk 会自动创建队列。

HttpPath

HTTPPOST消息发送到的应用程序的相对路径。

/

MimeType

HTTPPOST请求中发送的消息的MIME类型。

application/json

application/json

application/x-www-form-urlencoded

application/xml

text/plain

自定义MIME类型。

HttpConnections

Amazon EC2 实例中所有应用程序的最大并发连接数。

注意

如果您使用 Elastic Beanstalk 控制台创建环境,则无法在配置文件中设置此选项。控制台使用建议的值覆盖此选项。

50

1100

ConnectTimeout

等待成功连接到应用程序的时长(单位:秒)。

5

160

InactivityTimeout

在与应用程序的现有连接上等待响应的时长(单位:秒)。

消息会重新处理,直到守护程序从工作线程环境层中的应用程序收到 200 (OK) 响应或 RetentionPeriod 过期。

299

136000

VisibilityTimeout

从 Amazon SQS 队列传入的消息被锁定以待处理的时间,以秒为单位。在配置的时长之后,再次使消息在队列中可见,以供任何其他守护程序读取。

300

043200

ErrorVisibilityTimeout

在处理尝试失败并出现明显错误后,Elastic Beanstalk 向SQS亚马逊队列返回消息之前经过的时间(以秒为单位)。

2

043200

RetentionPeriod

消息有效和等待主动处理的时长(单位:秒)

345600

601209600

MaxRetries

Elastic Beanstalk 在将消息移动到死信队列之前,尝试向处理消息的 Web 应用程序发送消息的最大尝试次数。

10

1100

aws:elasticbeanstalk:trafficsplitting

为您的环境配置流量拆分部署。

当您将 aws:elasticbeanstalk:command 命名空间的 DeploymentPolicy 选项设置为 TrafficSplitting 时,将应用此命名空间。有关部署策略的更多信息,请参阅部署策略和设置

命名空间: aws:elasticbeanstalk:trafficsplitting
名称 描述 默认 有效值

NewVersionPercent

对于运行您正在部署的新应用程序版本的环境实例,Elastic Beanstalk 转移到这些实例的传入客户端流量的初始百分比。

10

1100

EvaluationTime

在初始正常部署之后,Elastic Beanstalk 等待的时间段(以分钟为单位),在经过该时间后,会继续将所有传入的客户端流量转移到正在部署的新应用程序版本。

5

3600

aws:elasticbeanstalk:xray

运行 AWS X-Ray 守护程序以中继来自 X-Ray 集成应用程序的跟踪信息。

命名空间: aws:elasticbeanstalk:xray
名称 描述 默认 有效值

XRayEnabled

设为 true 可在环境中的实例上运行 X-Ray 守护程序。

false

true

false

aws:elb:healthcheck

为经典负载均衡器配置运行状况检查。

命名空间: aws:elb:healthcheck
名称 描述 默认 有效值

HealthyThreshold

Elastic Load Balancing 更改实例运行状况状态前的连续成功请求数。

3

210

Interval

Elastic Load Balancing 检查应用程序的 Amazon EC2 实例运行状况的时间间隔。

10

5300

Timeout

Elastic Load Balancing 在将实例视为无响应之前等待的时间(单位:秒)

5

260

UnhealthyThreshold

Elastic Load Balancing 更改实例运行状况状态前的连续失败请求数。

5

210

(已弃用)Target

运行状况检查发送到的后端实例上的目标。请改为在 Application Healthcheck URL 命名空间中使用 aws:elasticbeanstalk:application

TCP:80

格式中的目标 PROTOCOL:PORT/PATH

aws:elb:loadbalancer

配置您环境的经典负载均衡器。

此命名空间中的多个选项已不再受支持,以支持 aws:elb:listener 命名空间中特定于侦听器的选项。使用这些不再受支持的选项,您只能在标准端口上配置两个侦听器(一个安全一个不安全)。

命名空间: aws:elb:loadbalancer
名称 描述 默认值 有效值

CrossZone

将负载均衡器配置为在所有可用区中的所有实例间 (而不是仅在每个区域中) 均匀地路由流量。

false

true

false

SecurityGroups

将您创建的一个或多个安全组分配到负载均衡器。

一个或多个安全组IDs。

ManagedSecurityGroup

将现有安全组分配给环境的负载均衡器,而不是创建一个新安全组。要使用此设置,请更新此命名空间中的 SecurityGroups 设置以包含安全组的 ID,然后删除自动创建的安全组 ID(如果已创建)。

为了允许流量从负载均衡器流向您的环境EC2实例,Elastic Beanstalk 向实例的安全组添加了一条规则,允许来自托管安全组的入站流量。

安全组 ID。

(已弃用)LoadBalancerHTTPPort

不安全的侦听器要侦听的端口。

80

OFF

80

(已弃用)LoadBalancerPortProtocol

不安全的侦听器上使用的协议。

HTTP

HTTP

TCP

(已弃用)LoadBalancerHTTPSPort

安全的侦听器要侦听的端口。

OFF

OFF

443

8443

(已弃用)LoadBalancerSSLPortProtocol

安全的侦听器上使用的协议。

HTTPS

HTTPS

SSL

(已弃用)SSLCertificateId

要绑定到安全侦听器的SSL证书的 Amazon 资源名称 (ARN)。

aws:elb:listener

在经典负载均衡器上配置默认侦听器(端口 80)。

命名空间: aws:elb:listener
名称 描述 默认值 有效值
ListenerProtocol 侦听器使用的协议。 HTTP HTTP TCP
InstancePort 此侦听器用于与EC2实例通信的端口。 80 165535
InstanceProtocol

此侦听器用于与EC2实例通信的协议。

它必须位于与 ListenerProtocol 相同的 Internet 协议层中。其安全级别也必须与使用与该侦听器相同的 InstancePort 的任何其他侦听器相同。

例如,如果 ListenerProtocolHTTPS (应用程序层,使用安全连接),您可以将 InstanceProtocol 设置为 HTTP (也位于应用程序层,使用不安全的连接)。此外,如果将 InstancePort 设置为 80,您必须在将 InstanceProtocol 设置为 HTTP 的所有其他侦听器中将 InstancePort 设置为 80

HTTP (当 ListenerProtocolHTTP 时)

TCP (当 ListenerProtocolTCP 时)

HTTPHTTPSListenerProtocolHTTPHTTPS

TCPSSLListenerProtocolTCPSSL

PolicyNames 应用于该侦听器的端口的策略名称的逗号分隔列表。我们建议您改用aws:elb:policies命名空间 LoadBalancerPorts 选项。
ListenerEnabled 指定是否启用该侦听器。如果指定 false,则此侦听器不包含在负载均衡器中。 true

true

false

aws:elb:listener:listener_port

在经典负载均衡器上配置其他侦听器。

命名空间: aws:elb:listener:listener_port
名称 描述 默认值 有效值

ListenerProtocol

侦听器使用的协议。 HTTP HTTP HTTPS TCP SSL

InstancePort

此侦听器用于与EC2实例通信的端口。 listener_port. 165535

InstanceProtocol

此侦听器用于与EC2实例通信的协议。

它必须位于与 ListenerProtocol 相同的 Internet 协议层中。其安全级别也必须与使用与该侦听器相同的 InstancePort 的任何其他侦听器相同。

例如,如果 ListenerProtocolHTTPS (应用程序层,使用安全连接),您可以将 InstanceProtocol 设置为 HTTP (也位于应用程序层,使用不安全的连接)。此外,如果将 InstancePort 设置为 80,您必须在将 InstanceProtocol 设置为 HTTP 的所有其他侦听器中将 InstancePort 设置为 80

HTTPListenerProtocolHTTPHTTPS

TCPListenerProtocolTCPSSL

HTTPHTTPSListenerProtocolHTTPHTTPS

TCPSSLListenerProtocolTCPSSL

PolicyNames

应用于该侦听器的端口的策略名称的逗号分隔列表。我们建议您改用aws:elb:policies命名空间 LoadBalancerPorts 选项。

SSLCertificateId

要绑定到侦听器的SSL证书的 Amazon 资源名称 (ARN)。

ListenerEnabled

指定是否启用该侦听器。如果指定 false,则此侦听器不包含在负载均衡器中。 如果设置了任何其他选项,则为 true;否则为 false true false

aws:elb:policies

修改经典负载均衡器的默认粘性和全局负载均衡器策略。

命名空间: aws:elb:policies
名称 描述 默认 有效值

ConnectionDrainingEnabled

指定负载均衡器是否维持与已运行状况不佳或取消注册的实例之间的现有连接以完成正在进行的请求。

false

true

false

ConnectionDrainingTimeout

在强制关闭连接之前,负载均衡器在连接耗尽过程中维持与实例之间的现有连接的最大秒数。

注意

如果您使用 Elastic Beanstalk 控制台创建环境,则无法在配置文件中设置此选项。控制台使用建议的值覆盖此选项。

20

13600

ConnectionSettingIdleTimeout

负载均衡器等待通过连接发送或接收任何数据的时间(单位:秒)。如果此时段后未发送或接收任何数据,则负载均衡器将关闭连接。

60

13600

LoadBalancerPorts

应用默认策略 (AWSEB-ELB-StickinessPolicy) 的侦听器端口的逗号分隔列表。

您可以使用 :all 指示所有侦听器端口

Stickiness Cookie Expiration

每个 Cookie 的有效时间,以秒为单位。使用默认策略 (AWSEB-ELB-StickinessPolicy)。

0

01000000

Stickiness Policy

将一个用户会话绑定到某一特定的服务器实例,以便系统将用户在此会话期间发出的所有请求都发送到同一服务器实例。使用默认策略 (AWSEB-ELB-StickinessPolicy)。

false

true false

aws:elb:policies:policy_name

为经典负载均衡器创建其他负载均衡器策略。

命名空间: aws:elb:policies:policy_name
名称 描述 默认 有效值

CookieName

应用程序生成的 Cookie 的名称,用于控制 AppCookieStickinessPolicyType 策略的会话生存期。此策略只能与HTTP/HTTPS监听器相关联。

InstancePorts

应用此策略的实例端口的逗号分隔列表。

端口列表或 :all

LoadBalancerPorts

应用此策略的侦听器端口的逗号分隔列表。

端口列表或 :all

ProxyProtocol

对于ProxyProtocolPolicyType策略,指定是否包含原始TCP消息请求的 IP 地址和端口。此策略只能与TCP/SSL监听器相关联。

true false

PublicKey

对后端服务器进行身份验证时要使用的 PublicKeyPolicyType 策略的公有密钥的内容。此策略不能直接应用于后端服务器或侦听器。必须作为 BackendServerAuthenticationPolicyType 策略的一部分。

PublicKeyPolicyNames

控制后端服务器身份验证的 PublicKeyPolicyType 策略的策略名称(来自 BackendServerAuthenticationPolicyType 策略)的逗号分隔列表。此策略只能与使用 HTTPS /的后端服务器关联SSL。

SSLProtocols

要为策略启用的以逗号分隔的SSL协议列表,该SSLNegotiationPolicyType策略定义了负载均衡器接受的密码和协议。此策略只能与HTTPS/SSL监听器相关联。

SSLReferencePolicy

符合安全最佳实践的预定义 AWS 安全策略的名称,您要为定义负载均衡器接受的密码和协议的SSLNegotiationPolicyType策略激活该策略。此策略只能与HTTPS/SSL监听器相关联。

Stickiness Cookie Expiration

每个 Cookie 的有效时间,以秒为单位。

0

01000000

Stickiness Policy

将一个用户会话绑定到某一特定的服务器实例,以便系统将用户在此会话期间发出的所有请求都发送到同一服务器实例。

false

true false

aws:elbv2:listener:default

在 Application Load Balancer 或 Network Load Balancer 上配置默认侦听器(端口 80)。

此命名空间不适用于使用共享负载均衡器的环境。共享的负载均衡器没有默认侦听器。

命名空间: aws:elbv2:listener:default
名称 描述 默认 有效值

DefaultProcess

无规则匹配时将流量转发到的流程的名称。

default

过程名称。

ListenerEnabled

设置为 false 可禁用侦听器。您可以使用此选项对端口 80 禁用默认侦听器。

true

true

false

Protocol

要处理的流量的协议。

使用应用程序负载均衡器:HTTP

使用网络负载均衡器:TCP

使用应用程序负载均衡器:HTTPHTTPS

使用网络负载均衡器:TCP

Rules

应用于侦听器的规则的列表

此选项仅适用于带 Application Load Balancer 的环境。

逗号分隔的规则名称列表。

SSLCertificateArns

要绑定到侦听器的SSL证书的 Amazon 资源名称 (ARN)。

此选项仅适用于带 Application Load Balancer 的环境。

存储在IAM或中的证书的ACM。ARN

SSLPolicy

指定要应用于监听器的安全策略。

此选项仅适用于带 Application Load Balancer 的环境。

无(ELB默认)

负载均衡器安全策略的名称。

aws:elbv2:listener:listener_port

在 Application Load Balancer 或 Network Load Balancer 上配置其他侦听器。

注意

对于共享 Application Load Balancer,您只能指定 Rule 选项。其他选项不适用于共享的负载均衡器。

命名空间: aws:elbv2:listener:listener_port
名称 描述 默认 有效值

DefaultProcess

无规则匹配时将流量转发到的流程的名称。

default

过程名称。

ListenerEnabled

设置为 false 可禁用侦听器。您可以使用此选项对端口 80 禁用默认侦听器。

true

true

false

Protocol

要处理的流量的协议。

使用应用程序负载均衡器:HTTP

使用网络负载均衡器:TCP

使用应用程序负载均衡器:HTTPHTTPS

使用网络负载均衡器:TCP

Rules

要应用于侦听器的规则的列表

此选项仅适用于带 Application Load Balancer 的环境。

如果您的环境使用共享的 Application Load Balancer,并且您没有为任何侦听器指定此选项,则 Elastic Beanstalk 自动将 default 规则与端口 80 侦听器关联。

逗号分隔的规则名称列表。

SSLCertificateArns

要绑定到侦听器的SSL证书的 Amazon 资源名称 (ARN)。

此选项仅适用于带 Application Load Balancer 的环境。

存储在IAM或中的证书的ACM。ARN

SSLPolicy

指定要应用于监听器的安全策略。

此选项仅适用于带 Application Load Balancer 的环境。

无(ELB默认)

负载均衡器安全策略的名称。

aws:elbv2:listenerrule:rule_name

为 Application Load Balancer 定义侦听器规则。如果请求与规则中的主机名或路径匹配,则负载均衡器将请求转发到指定的进程。要使用规则,请使用 Rules 命名空间中的 aws:elbv2:listener:listener_port 选项将其添加到侦听器中。

注意

此命名空间不适用于使用网络负载均衡器的环境。

命名空间: aws:elbv2:listenerrule:rule_name
名称 描述 默认 有效值

HostHeaders

要匹配的主机名列表。例如,my.example.com

专用负载均衡器:无

共享负载均衡器:环境的 CNAME

每个名称最多可以包含 128 个字符。模式可包含大写和小写字母、数字、连字符 (–) 以及最多三个通配符(* 匹配零个或多个字符;? 恰好匹配一个字符)。您可以列出多个名称,每个名称用逗号分隔。Application Load Balancer 最多支持五个 HostHeaderPathPattern 规则组合。

有关更多信息,请参阅 Application Load Balancer 用户指南中的主机条件

PathPatterns

要匹配的路径模式(例如,/img/*)。

此选项仅适用于使用应用程序负载均衡器的环境。

每个模式最多可包含 128 个字符。模式可包含大写和小写字母、数字、连字符 (–) 以及最多三个通配符(* 匹配零个或多个字符;? 恰好匹配一个字符)。您可以添加多个逗号分隔的路径模式。Application Load Balancer 最多支持五个 HostHeaderPathPattern 规则组合。

有关更多信息,请参阅 Application Load Balancer 用户指南中的路径条件

Priority

多个规则匹配时此规则的优先顺序。较小的数字优先。任何两个规则的优先级不能相同。

利用共享的负载均衡器,Elastic Beanstalk 将规则优先级视为跨共享环境的相对优先级,并在创建过程中将其映射到绝对优先级。

1

11000

Process

此规则与请求匹配时要将流量转发到的流程的名称。

default

过程名称。

aws:elbv2:loadbalancer

配置 Application Load Balancer。

对于共享的负载均衡器,只有 SharedLoadBalancerSecurityGroups 选项有效。

注意

此命名空间不适用于带 Network Load Balancer 的环境。

命名空间: aws:elbv2:loadbalancer
名称 描述 默认 有效值

AccessLogsS3Bucket

存储访问日志的 Amazon S3 存储桶。存储桶必须与环境处于同一区域并授予负载均衡器的写入访问权限。

存储桶名称。

AccessLogsS3Enabled

启用访问日志存储。

false

true

false

AccessLogsS3Prefix

放在访问日志名称前的前缀。默认情况下,负载均衡器会将日志上传到您指定的存储桶 AWSLogs 中名为的目录。指定前缀以将该 AWSLogs 目录放在另一个目录中。

IdleTimeout

在关闭到客户端和实例的连接之前,等待请求完成的时间(单位:秒)。

13600

ManagedSecurityGroup

将现有安全组分配给环境的负载均衡器,而不是创建一个新安全组。要使用此设置,请更新此命名空间中的 SecurityGroups 设置以包括安全组的 ID,并删除自动创建的安全组 ID (如果存在)。

为了允许流量从负载均衡器流向您的环境中的EC2实例,Elastic Beanstalk 会向您的实例的安全组添加一条规则,允许来自托管安全组的入站流量。

Elastic Beanstalks 为您的负载均衡器闯进的安全组。

安全组 ID。

SecurityGroups

附加到负载均衡器的安全组的列表。

对于共享的负载均衡器,如果您未指定此值,则 Elastic Beanstalk 将检查其管理的现有安全组是否已连接到负载均衡器。如果没有连接到负载均衡器,Elastic Beanstalk 将创建一个安全组并将其附加到负载均衡器。当最后一个共享负载均衡器的环境终止时,Elastic Beanstalk 将删除此安全组。

负载均衡器安全组用于设置 Amazon EC2 实例安全组入口规则。

Elastic Beanstalks 为您的负载均衡器创建的安全组。

以逗号分隔的安全组列表。IDs

SharedLoadBalancer

共享负载均衡器的 Amazon 资源名称 (ARN)。此选项仅与 Application Load Balancer 相关。当 aws:elasticbeanstalk:environment 命名空间的 LoadBalancerIsShared 选项设置为 true 时,这是必需的。创建环境ARN后,您无法更改共享负载均衡器。

有效值的条件:

  • 它必须是环境所在 AWS 区域中有效的活动负载均衡器。

  • 它必须与环境位于同一个亚马逊虚拟私有云 (AmazonVPC) 中。

  • 它不能是由 Elastic Beanstalk 创建为另一环境的专用负载均衡器的负载均衡器。您可以使用前缀 awseb- 标识这些专用负载均衡器。

例如:

arn:aws:elasticloadbalancing:us-east-2:123456789012:loadbalancer/app/FrontEndLB/0dbf78d8ad96abbc

ARN符合此处描述的所有条件的有效负载均衡器。

aws:rds:dbinstance

配置连接的 Amazon RDS 数据库实例。

命名空间: aws:rds:dbinstance
名称 描述 默认 有效值

DBAllocatedStorage

分配的数据库存储大小 (以吉字节为单位来指定)。

我的SQL:5

Oracle:10

sqlserver-se:200

sqlserver-ex:30

sqlserver-web:30

我的SQL:5-1024

Oracle:10-1024

sqlserver:无法修改

DBDeletionPolicy

指定在环境终止时保留、删除或创建数据库实例还是为数据库实例拍摄快照。

此选项与 HasCoupledDatabase 结合使用,也是此命名空间的一个选项。

警告

删除数据库实例会导致数据永久丢失。

Delete

Delete

Retain

Snapshot

DBEngine

要用于此实例的数据库引擎的名称。

mysql

mysql

oracle-se1

sqlserver-ex

sqlserver-web

sqlserver-se

postgres

DBEngineVersion

数据库引擎的版本号。

5.5

DBInstanceClass

数据库实例类型。

db.t2.micro

db.m1.large适用于未在 Amazon 中运行的环境VPC)

有关更多信息,请参阅 Amazon Relational Database Service 用户指南中的数据库实例类

DBPassword

数据库实例的主用户密码。

DBSnapshotIdentifier

要用来恢复数据库的数据库快照的标识符。

DBUser

数据库实例的主用户名称。

ebroot

HasCoupledDatabase

指定数据库实例是否与环境耦合。如果切换为 true,Elastic Beanstalk 会创建一个与您的环境耦合的新数据库实例。如果切换为 false,Elastic Beanstalk 开始将数据库实例与您的环境解耦。

此选项与 DBDeletionPolicy 结合使用,也是此命名空间的一个选项。

注意

注意:如果在解耦前一个数据库之后将此值切换回 true ,Elastic Beanstalk 将使用前一个数据库选项设置创建一个新的数据库。但是,为了维护环境的安全性,它不会保留现有的 DBUserDBPassword 设置。您需要再次指定 DBUserDBPassword

false

true

false

MultiAZDatabase

指定是否需要创建数据库实例的多可用区部署。有关使用 Amazon Relational Database Service (RDS) 进行多可用区部署的更多信息,请参阅亚马逊关系数据库服务用户指南中的区域和可用区

false

true

false