编写一个CFN模板以通过CloudWatch事件触发Fargate。
创始人
2024-12-05 23:00:55
0

要编写一个CFN模板来触发Fargate任务,可以按照以下步骤进行操作:

  1. 创建一个Amazon Elastic Container Service (ECS)任务定义,其中包含要在Fargate上运行的容器配置。以下是一个示例任务定义:
{
  "family": "my-task",
  "networkMode": "awsvpc",
  "containerDefinitions": [
    {
      "name": "my-container",
      "image": "your-container-image",
      "memory": 512,
      "portMappings": [
        {
          "containerPort": 80,
          "hostPort": 80,
          "protocol": "tcp"
        }
      ]
    }
  ]
}
  1. 创建一个ECS服务,它使用上一步中定义的任务定义。以下是一个示例服务定义:
{
  "cluster": "my-cluster",
  "serviceName": "my-service",
  "taskDefinition": "my-task",
  "desiredCount": 1,
  "launchType": "FARGATE",
  "networkConfiguration": {
    "awsvpcConfiguration": {
      "subnets": ["subnet-12345678"],
      "securityGroups": ["sg-12345678"],
      "assignPublicIp": "ENABLED"
    }
  }
}
  1. 创建一个CloudWatch事件规则,以触发Fargate任务。以下是一个示例事件规则:
{
  "name": "my-event-rule",
  "description": "Trigger Fargate task",
  "eventPattern": {
    "source": ["aws.ecs"],
    "detail-type": ["ECS Task State Change"],
    "detail": {
      "desiredStatus": ["RUNNING"],
      "lastStatus": ["PENDING"]
    }
  },
  "state": "ENABLED",
  "targets": [
    {
      "arn": "arn:aws:ecs:region:account-id:cluster/my-cluster",
      "roleArn": "arn:aws:iam::account-id:role/ecsEventsRole",
      "ecsParameters": {
        "taskDefinitionArn": "arn:aws:ecs:region:account-id:task-definition/my-task"
      }
    }
  ]
}

在上面的示例中,source字段指定了事件的来源为ECS,detail-type字段指定了事件的类型为ECS Task State Change。detail字段中的desiredStatuslastStatus字段指定了事件的过滤条件,只有当任务的期望状态为RUNNING且最后状态为PENDING时,事件才会触发。

  1. 使用CFN模板将上述定义创建为一个CloudFormation堆栈。以下是一个示例CFN模板:
AWSTemplateFormatVersion: '2010-09-09'
Resources:
  MyTaskDefinition:
    Type: AWS::ECS::TaskDefinition
    Properties:
      Family: my-task
      NetworkMode: awsvpc
      Cpu: '256'
      Memory: '512'
      ExecutionRoleArn: !Ref MyExecutionRole
      ContainerDefinitions:
        - Name: my-container
          Image: your-container-image
          Memory: 512
          PortMappings:
            - ContainerPort: 80
              HostPort: 80
              Protocol: tcp
  MyService:
    Type: AWS::ECS::Service
    Properties:
      Cluster: my-cluster
      ServiceName: my-service
      TaskDefinition: !Ref MyTaskDefinition
      DesiredCount: 1
      LaunchType: FARGATE
      NetworkConfiguration:
        AwsvpcConfiguration:
          Subnets:
            - subnet-12345678
          SecurityGroups:
            - sg-12345678
          AssignPublicIp: ENABLED
  MyEventRule:
    Type: AWS::Events::Rule
    Properties:
      Name: my-event-rule
      Description: Trigger Fargate task
      EventPattern:
        source:
          - aws.ecs
        detail-type:
          - ECS Task State Change
        detail:
          desiredStatus:
            - RUNNING
          lastStatus:
            - PENDING
      State: ENABLED
      Targets:
        - Arn: !Sub arn:aws:ecs:${AWS::Region}:${AWS::AccountId}:cluster/my-cluster
          RoleArn: !Ref MyEventRole
          EcsParameters:
            TaskDefinitionArn: !Ref MyTaskDefinition
  MyExecutionRole:
    Type: AWS::IAM::Role
    Properties:
      AssumeRolePolicy

相关内容

热门资讯

银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
AsusVivobook无法开... 首先,我们可以尝试重置BIOS(Basic Input/Output System)来解决这个问题。...
ASM贪吃蛇游戏-解决错误的问... 要解决ASM贪吃蛇游戏中的错误问题,你可以按照以下步骤进行:首先,确定错误的具体表现和问题所在。在贪...
月入8000+的steam搬砖... 大家好,我是阿阳 今天要给大家介绍的是 steam 游戏搬砖项目,目前...