轩辕镜像
轩辕镜像专业版
个人中心搜索镜像
交易
充值流量我的订单
工具
工单支持镜像收录Run 助手IP 归属地密码生成Npm 源Pip 源
帮助
常见问题我要吐槽
其他
关于我们网站地图

官方QQ群: 13763429

轩辕镜像
镜像详情
silintl/ecs-deploy
官方博客使用教程热门镜像工单支持
本站面向开发者与科研用户,提供开源镜像的搜索和下载加速服务。
所有镜像均来源于原始开源仓库,本站不存储、不修改、不传播任何镜像内容。
轩辕镜像 - 国内开发者首选的专业 Docker 镜像下载加速服务平台 - 官方QQ群:13763429 👈点击免费获得技术支持。
本站面向开发者与科研用户,提供开源镜像的搜索和下载加速服务。所有镜像均来源于原始开源仓库,本站不存储、不修改、不传播任何镜像内容。

本站支持搜索的镜像仓库:Docker Hub、gcr.io、ghcr.io、quay.io、k8s.gcr.io、registry.gcr.io、elastic.co、mcr.microsoft.com

ecs-deploy Docker 镜像下载 - 轩辕镜像

ecs-deploy 镜像详细信息和使用指南

ecs-deploy 镜像标签列表和版本信息

ecs-deploy 镜像拉取命令和加速下载

ecs-deploy 镜像使用说明和配置指南

Docker 镜像加速服务 - 轩辕镜像平台

国内开发者首选的 Docker 镜像加速平台

极速拉取 Docker 镜像服务

相关 Docker 镜像推荐

热门 Docker 镜像下载

ecs-deploy
silintl/ecs-deploy
自动构建

ecs-deploy 镜像详细信息

ecs-deploy 镜像标签列表

ecs-deploy 镜像使用说明

ecs-deploy 镜像拉取命令

Docker 镜像加速服务

轩辕镜像平台优势

镜像下载指南

相关 Docker 镜像推荐

用于在Amazon EC2容器服务(ECS)上触发蓝绿部署的简单脚本。
18 收藏0 次下载activesilintl镜像
🚀轩辕镜像专业版更稳定💎一键安装 Docker 配置镜像源
中文简介版本下载
🚀轩辕镜像专业版更稳定💎一键安装 Docker 配置镜像源

ecs-deploy 镜像详细说明

ecs-deploy 使用指南

ecs-deploy 配置说明

ecs-deploy 官方文档

ecs-deploy

概述

ecs-deploy是一个用于在Amazon EC2容器服务(ECS)上实现自动蓝绿部署的脚本。它通过操作ECS的任务定义(Task Definition)和服务(Service)实体,实现零停机部署,确保新任务正常运行后再替换旧任务。

核心功能与特性

  • 支持基于服务或任务定义的部署方式
  • 灵活的AWS凭证配置(访问密钥、环境变量、IAM角色、实例配置文件等)
  • 自定义部署参数(期望任务数、健康检查百分比、超时时间等)
  • 支持更新容器镜像标签,支持多容器任务的标签统一更新
  • 任务定义版本管理,可自动清理旧版本
  • 部署失败时支持自动回滚
  • 支持Fargate启动类型及网络配置
  • 详细的部署状态监控与 verbose 输出

使用场景

  • ECS服务的日常部署与更新
  • 容器镜像版本升级(如从旧标签更新到新标签)
  • 多容器任务的统一标签管理
  • 需要严格控制部署过程(如健康检查、超时设置)的生产环境
  • 自动化CI/CD流程中的ECS部署环节(如与Github Actions集成)

依赖项

  • aws-cli:AWS命令行工具
  • jq:命令行JSON处理器

使用方法

必要参数

以下参数为部署所必需,部分可通过环境变量设置:

参数描述
-k | --aws-access-keyAWS访问密钥ID,也可通过环境变量AWS_ACCESS_KEY_ID设置
-s | --aws-secret-keyAWS密钥,也可通过环境变量AWS_SECRET_ACCESS_KEY设置
-r | --regionAWS区域名称,也可通过环境变量AWS_DEFAULT_REGION设置
-p | --profileAWS配置文件名称,设置后无需单独提供访问密钥和区域
--aws-instance-profile使用当前AWS实例关联的IAM角色,仅在AWS实例内部使用,设置后无需提供访问密钥
-c | --clusterECS集群名称
-n | --service-name要部署的服务名称(与-d二选一)
-d | --task-definition要部署的任务定义名称(与-n二选一)
-i | --image要运行的Docker镜像名称,格式:[域名][:端口][/仓库][/][镜像][:标签],例如:mariadb:latest、private.registry.com/repo/image:tag

可选参数

参数描述
-a | --aws-assume-role用于ecs-deploy操作的AWS角色ARN
-D | --desired-count服务中要保持运行的任务实例数量
-m | --min部署期间运行中任务的最小健康百分比(默认:100)
-M | --max部署期间运行中任务的最大百分比(默认:200)
-t | --timeout部署超时时间(默认:90秒)
-e | --tag-env-var从环境变量获取镜像标签,覆盖-i中指定的标签
-to | --tag-only应用于任务中所有镜像的新标签,覆盖-i中指定的标签(适用于多容器任务)
--max-definitions保留的任务定义修订版数量,超过则注销最旧版本(需≥1,仅在部署成功后执行)
--task-definition-file用作部署任务定义的文件路径
--enable-rollback若超时前新版本未运行,则回滚任务定义
--use-latest-task-def使用最新创建的任务定义作为基础,而非最后使用的版本
--force-new-deployment强制服务进行新部署(默认:false)
--skip-deployments-check跳过部署检查,适用于需要长时间终止旧任务的服务
--run-task立即运行创建的任务,设置后无需提供服务名称
--wait-for-success等待任务执行完成并返回退出码0
--launch-type任务启动类型(参考AWS ECS文档)
--platform-versionFargate平台版本(参考AWS ECS文档)
--network-configuration任务网络配置(awsvpc网络模式必需,参考AWS ECS文档)
--copy-task-definition-tags将现有任务定义标签复制到新修订版
-v | --verbose详细输出模式
--version显示版本信息

示例

简单服务部署(使用环境变量配置AWS参数)

ecs-deploy -c production1 -n doorman-service -i docker.repo.com/doorman:latest

完整参数部署

ecs-deploy -k ABC123 -s SECRETKEY -r us-east-1 -c production1 -n doorman-service -i docker.repo.com/doorman -m 50 -M 100 -t 240 -D 2 -e CI_TIMESTAMP -v

更新任务定义镜像

ecs-deploy -d open-door-task -i docker.repo.com/doorman:17

使用AWS配置文件部署

ecs-deploy -p PROFILE -c production1 -n doorman-service -i docker.repo.com/doorman -t 240 -e CI_TIMESTAMP -v

多容器任务标签更新

ecs-deploy -c staging -n core-service -to 0.1.899 -i ignore

工作原理

  1. 拉取任务定义:获取当前服务使用的任务定义JSON(或使用--use-latest-task-def获取最新创建的任务定义)
  2. 编辑任务定义:根据指定的镜像参数更新容器镜像标签(支持多容器任务中匹配仓库名的镜像)
  3. 创建新版本:注册修改后的任务定义,生成新修订版
  4. 更新服务:将服务配置更新为使用新版本任务定义
  5. 监控部署状态:查询AWS API,等待服务成功创建新任务并确认部署完成

即使任务定义内容未变更,ECS服务仍会执行蓝绿部署。脚本通过更新容器镜像标签确保部署的差异性,支持静态标签(如latest)或动态标签(如CI构建时间戳)。

AWS IAM策略配置

以下是适用于ecs-deploy的IAM策略示例:

{
  "Version": "2012-10-17",
  "Statement": [
    {
      "Effect": "Allow",
      "Action": [
        "ecs:DeregisterTaskDefinition",
        "ecs:DescribeServices",
        "ecs:DescribeTaskDefinition",
        "ecs:DescribeTasks",
        "ecs:ListTasks",
        "ecs:ListTaskDefinitions",
        "ecs:RegisterTaskDefinition",
        "ecs:StartTask",
        "ecs:StopTask",
        "ecs:UpdateService",
        "iam:PassRole"
      ],
      "Resource": "*"
    }
  ]
}

故障排除

  • AWS凭证错误:若未正确配置AWS凭证,会出现类似"You must specify a region"的错误,需检查环境变量或参数是否正确设置AWS访问密钥、密钥和区域。
  • 部署超时:若服务长时间未完成部署,可增加-t(超时时间)参数值,或使用--skip-deployments-check跳过部署检查。
  • 镜像拉取失败:确保镜像路径正确且ECS任务执行角色有权限访问镜像仓库。

测试

使用bats进行自动化测试,主要验证本地数据解析和处理逻辑。新功能或PR应尽可能提供测试用例。

Github Actions支持

可集成到Github Actions工作流中,示例配置如下:

deploy_to_ecs:
  name: '通过蓝绿部署将更新的容器镜像部署到ECS服务'
  runs-on: ubuntu-18.04
  steps:
  - uses: silinternational/ecs-deploy@master
    env:
      AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }}
      AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
      AWS_DEFAULT_REGION: 'us-east-1'
    with:
      aws_access_key_cmd: '--aws-access-key'
      aws_access_key: ${{ secrets.AWS_ACCESS_KEY_ID }}
      aws_secret_key_cmd: '--aws-secret-key'
      aws_secret_key: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
      cluster_cmd: '--cluster'
      cluster: 'cluster-name'
      image_cmd: '--image'
      image: '{amazon_id}.dkr.ecr.us-east-1.amazonaws.com/cluster-name/image_name:latest'
      region_cmd: '--region'
      region: 'us-east-1'
      service_name_cmd: '--service-name'
      service_name: 'aws-service-name'
      timeout_cmd: '--timeout'
      timeout: '360'
查看更多 ecs-deploy 相关镜像 →
fabfuel/ecs-deploy logo
fabfuel/ecs-deploy
by fabfuel
用于AWS ECS部署、扩展和任务运行的CLI工具,简化复杂部署操作,支持任务定义管理、版本更新、服务扩缩容及一次性任务执行。
1M+ pulls
上次更新:7 个月前

常见问题

轩辕镜像免费版与专业版有什么区别?

免费版仅支持 Docker Hub 加速,不承诺可用性和速度;专业版支持更多镜像源,保证可用性和稳定速度,提供优先客服响应。

轩辕镜像免费版与专业版有分别支持哪些镜像?

免费版仅支持 docker.io;专业版支持 docker.io、gcr.io、ghcr.io、registry.k8s.io、nvcr.io、quay.io、mcr.microsoft.com、docker.elastic.co 等。

流量耗尽错误提示

当返回 402 Payment Required 错误时,表示流量已耗尽,需要充值流量包以恢复服务。

410 错误问题

通常由 Docker 版本过低导致,需要升级到 20.x 或更高版本以支持 V2 协议。

manifest unknown 错误

先检查 Docker 版本,版本过低则升级;版本正常则验证镜像信息是否正确。

镜像拉取成功后,如何去掉轩辕镜像域名前缀?

使用 docker tag 命令为镜像打上新标签,去掉域名前缀,使镜像名称更简洁。

查看全部问题→

轩辕镜像下载加速使用手册

探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式

🔐

登录方式进行 Docker 镜像下载加速教程

通过 Docker 登录方式配置轩辕镜像加速服务,包含7个详细步骤

🐧

Linux Docker 镜像下载加速教程

在 Linux 系统上配置轩辕镜像源,支持主流发行版

🖥️

Windows/Mac Docker 镜像下载加速教程

在 Docker Desktop 中配置轩辕镜像加速,适用于桌面系统

📦

Docker Compose 镜像下载加速教程

在 Docker Compose 中使用轩辕镜像加速,支持容器编排

📋

K8s containerd 镜像下载加速教程

在 k8s 中配置 containerd 使用轩辕镜像加速

🔧

宝塔面板 Docker 镜像下载加速教程

在宝塔面板中配置轩辕镜像加速,提升服务器管理效率

💾

群晖 NAS Docker 镜像下载加速教程

在 Synology 群晖NAS系统中配置轩辕镜像加速

🐂

飞牛fnOS Docker 镜像下载加速教程

在飞牛fnOS系统中配置轩辕镜像加速

📱

极空间 NAS Docker 镜像下载加速教程

在极空间NAS中配置轩辕镜像加速

⚡

爱快路由 ikuai Docker 镜像下载加速教程

在爱快ikuai系统中配置轩辕镜像加速

🔗

绿联 NAS Docker 镜像下载加速教程

在绿联NAS系统中配置轩辕镜像加速

🌐

威联通 NAS Docker 镜像下载加速教程

在威联通NAS系统中配置轩辕镜像加速

📦

Podman Docker 镜像下载加速教程

在 Podman 中配置轩辕镜像加速,支持多系统

📚

ghcr、Quay、nvcr、k8s、gcr 等仓库下载镜像加速教程

配置轩辕镜像加速9大主流镜像仓库,包含详细配置步骤

🚀

专属域名方式进行 Docker 镜像下载加速教程

无需登录即可使用轩辕镜像加速服务,更加便捷高效

需要其他帮助?请查看我们的 常见问题 或 官方QQ群: 13763429

商务:17300950906
|©2024-2025 源码跳动
商务合作电话:17300950906|Copyright © 2024-2025 杭州源码跳动科技有限公司. All rights reserved.