

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

# 目标群体的粘性
<a name="target-group-stickiness"></a>

当您使用具有目标组粘性的 Application Load Balancer 时：
+ Application Load Balancer 使用[目标组权重](https://aws.amazon.com/premiumsupport/knowledge-center/elb-make-weighted-target-groups-for-alb/)来确定如何在目标组之间平衡传入流量。
+ 默认情况下，Application Load Balancer 使用循环方法[将请求路由到目标目标组中的 EC2 实例](https://docs.aws.amazon.com/elasticloadbalancing/latest/application/load-balancer-target-groups.html#modify-routing-algorithm)。

**模板：**使用 CloudFormation 模板`targetgroupstickiness.yml`（包含在[示例代码.zip 文件](samples/stickiness.zip)中）来尝试目标群体的粘性。

## 常见使用案例
<a name="tg-stickiness-use-cases"></a>

在以下场景中使用目标群体的粘性：
+ 负载均衡器分配了多个目标组，来自客户端的流量应始终如一地路由到该目标组内的实例。
+ 蓝/绿部署。

## basic.yml 的代码发生了变化
<a name="tg-stickiness-code-changes"></a>

对监听器进行了单一更改：我们修改了 Application Load Balancer 的默认操作，以指定两个权重相等的目标组（`TG1`和`TG2`），并使用粘性配置。


****  

|  |  | 
| --- |--- |
| basic.yml | targetgroupstickiness.yml | 
| <pre>Listener1:<br />  Type: 'AWS::ElasticLoadBalancingV2::Listener'<br />  Properties:<br />    LoadBalancerArn: !Ref ALB<br />    Protocol: HTTP<br />    Port: 80<br />    DefaultActions:<br />      - TargetGroupArn: !Ref TG1<br />        Type: forward</pre> | <pre>Listener1:<br />  Type: 'AWS::ElasticLoadBalancingV2::Listener'<br />  Properties:<br />    LoadBalancerArn: !Ref ALB<br />    Protocol: HTTP<br />    Port: 80<br />    DefaultActions:<br />      - ForwardConfig:<br />          TargetGroups:<br />            - TargetGroupArn: !Ref TG1<br />              Weight: 1<br />            - TargetGroupArn: !Ref TG2<br />              Weight: 1<br />          TargetGroupStickinessConfig:<br />              DurationSeconds: 10<br />              Enabled: true<br />        Type: forward</pre> | 

## 步骤
<a name="tg-stickiness-steps"></a>

**备注**  
NAT 网关的费用很小。
与单个 EC2 EC2实例相比，多个实例耗尽免费套餐的小时数更快。

1. 在实验室环境`targetgroupstickiness.yml`中部署 CloudFormation 模板。

1. 等待，直到目标组实例的运行状况从**初始**变为正**常**。

1. 使用 HTTP (TCP/80) 在网络浏览器中导航到 Application Load Balancer 网址。

   例如：`http://alb-123456789.us-east-1.elb.amazonaws.com/`

   该网页显示以下内容之一：**实例 1- TG1**、**实例 2- TG1**、**实例 3- TG2** 或**实例 4- TG2**。

1. 多次刷新页面。

## 预期结果
<a name="tg-stickiness-results"></a>

**注意**  
本示例中的 CloudFormation 模板将粘性配置为持续 10 秒。

加载网页的实例应在 10 秒的持续时间内停留在目标组（TG1 或 TG2）内，如页面文本所示。

大约 10 秒钟后，粘性就会被释放，目标组实例集可能会发生变化。

## 工作方式
<a name="tg-stickiness-how"></a>
+ 在此示例中，四个 EC2 实例被分成两个目标组，每个目标组有两个实例。这些 EC2 实例安装了 Apache Web 服务器 (`httpd`)，并且每个 EC2实例上的`index.html`页面文本都经过硬编码以区分开来。
+ Application Load Balancer 为用户与目标目标组的会话创建绑定，并附有过期时间。
+ 当您重新加载页面时，Application Load Balancer 会检查绑定是否存在且尚未过期。
  + 如果绑定已过期或不存在，Application Load Balancer 将运行其路由逻辑并确定目标组。
  + 如果绑定尚未过期，Application Load Balancer 会将流量路由到同一个目标组，但不一定要路由到同一个 EC2 实例。