#amazon-web-services #amazon-cloudformation #aws-load-balancer
#amazon-веб-сервисы #aws-cloudformation #amazon-elb
Вопрос:
У меня есть некоторая CloudFormation для средства балансировки сетевой нагрузки.
PrivateNetworkLoadBalancerSG:
Type: AWS::EC2::SecurityGroup
Properties:
GroupDescription: Access to the internal network load balancer
VpcId: !Ref 'VPC'
PrivateNetworkLoadBalancerIngressFromECS:
Type: AWS::EC2::SecurityGroupIngress
Properties:
Description: Only accept traffic from a container in the container host security group
GroupId: !Ref 'PrivateNetworkLoadBalancerSG'
IpProtocol: -1
SourceSecurityGroupId: !Ref 'EcsHostSecurityGroup'
PrivateNetworkLoadBalancer:
Type: AWS::ElasticLoadBalancingV2::LoadBalancer
Properties:
Type: network
Scheme: internal
Subnets:
- !Ref PrivateSubnetOne
- !Ref PrivateSubnetTwo
DummyTargetGroupPrivateNetwork:
Type: AWS::ElasticLoadBalancingV2::TargetGroup
Properties:
Name: !Join ['-', [!Ref 'AWS::StackName', 'drop-3']]
Port: 6379
Protocol: TCP
# UnhealthyThresholdCount: 2
VpcId: !Ref 'VPC'
И некоторые инструкции по настройке контейнера Redis docker в ECS.
RedisService:
Type: AWS::ECS::Service
Properties:
Cluster: !ImportValue "privatevpc:ClusterName"
DesiredCount: 1
TaskDefinition: !Ref RedisTaskDefinition
RedisTaskDefinition:
Type: AWS::ECS::TaskDefinition
Properties:
Family: redis
ContainerDefinitions:
- Name: redis
Essential: true
Image: "redis:latest"
Memory: 512
PortMappings:
- ContainerPort: 6379
HostPort: 6379
LogConfiguration:
LogDriver: awslogs
Options:
awslogs-group: !Ref CloudWatchLogsGroup
awslogs-region: !Ref AWS::Region
RedisTargetGroup:
Type: AWS::ElasticLoadBalancingV2::TargetGroup
Properties:
VpcId: !ImportValue "privatevpc:VPCId"
Port: 6379
Protocol: TCP
HealthCheckProtocol: TCP
RedisLoadBalancerListener:
Type: AWS::ElasticLoadBalancingV2::Listener
Properties:
DefaultActions:
- Type: forward
TargetGroupArn: !Ref RedisTargetGroup
LoadBalancerArn: !ImportValue "privatevpc:PrivateNetworkLoadBalancer"
Port: 6379
Protocol: TCP
Но мне вручную приходится добавлять экземпляр EC2, на котором развернут мой RedisService, в качестве цели для RedisTargetGroup через веб-консоль AWS. Есть идеи, как я могу заставить CloudFormation сделать это за меня?
Комментарии:
1.Я думаю, вы можете руководствоваться некоторыми примерами, где они создают несколько ресурсов Cloudformation, подобных тем, которые вам нужны: link1 link2 link3
2. С этого я и начал.
3. Необходимо добавить автоматическое масштабирование. Вы пробовали это?
Ответ №1:
Я думаю, вам нужно добавить LoadBalancers
свойство в RedisService
. ECS должен автоматически добавлять нужные экземпляры EC2 в указанную целевую группу.
Например:
RedisService:
Type: AWS::ECS::Service
Properties:
Cluster: !ImportValue "privatevpc:ClusterName"
DesiredCount: 1
TaskDefinition: !Ref RedisTaskDefinition
LoadBalancers:
- ContainerName: redis
ContainerPort: 6379
TargetGroupArn: !Ref RedisTargetGroup