ecstop:我的 CLI 工具,可轻松停止 ECS 资源
介绍
2024 年 12 月 20 日,我开发并发布了一个名为 ecstop 的 CLI 工具,它“快速批量停止 ECS 资源”。
https://github.com/t-kikuc/ecstop
名称 ecstop 是 ECS Stop 的组合。我将其发音为“ee-c-stop”。
在这篇文章中,我将介绍 ecstop 的概述、理念和未来前景。
3行总结
- ecstop 可以快速批量停止 ECS 服务、任务和容器实例(EC2)。
- 主要目的是轻松降低开发环境的成本。
- brew install t-kikuc/tap/ecstop 后,无需任何配置文件即可立即使用。
发展背景
我经常在测试 ECS 本身或开发/测试 PipeCD 时创建 ECS 资源。
由于 ECS 对运行任务和容器实例收费,因此我想停止未使用的任务和容器实例。
由于是为了测试,我不想删除集群或服务。他们是免费的。
但是,由于我创建了很多资源,从AWS控制台一一停止它们很麻烦。
-
要从控制台停止某个服务,您需要进入 ECS 控制台,选择该服务并“更新”,将每个服务的任务数设置为 0 并“确认更新”。
IaC 和部署工具是为生产使用而设计的,需要仔细更改配置文件,不适合“快速停止多个资源”。
我一直使用shell脚本/Go来批量阻止它们,但我经常忘记如何调用它们。
因此,我决定制作一个合适的 CLI 工具。
安装
您可以使用以下命令安装 ecstop(自制):
$ brew install t-kikuc/tap/ecstop
要启用自动完成功能,请参阅此处。
特征
有关选项的详细信息,请参阅 README。
1. 零规模服务
$ ecstop services --cluster xxx
这会将 xxx 集群中所有服务的desiredCount设置为0。这也会自动停止链接到服务的任务。
2. 停止任务
$ ecstop tasks --cluster xxx --standalone
--standalone 标志停止未链接到服务的任务。
这适用于组前缀不是 service 的任务:.
要停止与服务链接的任务,请使用 ecstop 服务,因为即使在 ecstop 任务停止后,服务也可以启动新任务。
3.停止容器实例(EC2)
$ ecstop instances --cluster xxx
这将停止(≠终止)链接到 xxx 集群的所有容器实例。
4.执行以上三合一命令
$ ecstop all --cluster xxx
此命令相当于:
$ brew install t-kikuc/tap/ecstop
其他有用的标志
- --all-cluster:代替 --cluster xxx,对区域中的所有 ECS 集群执行停止操作。
- --profile yyy:您可以指定AWS配置文件。
- --region zzz: 可以指定AWS区域。
哲学
1. 不可删除
ecstop 不会删除不必要的 ECR 图像或任务定义。
虽然任务和容器实例(EC2)的运营成本很高,但ECR镜像相对便宜,而且任务定义是免费的,所以我忽略了它们。服务和集群本身也是免费的,因此不会被删除。
因此,我没有在工具名称中包含“clean”或“delete”。
如果“我想删除它,因为它没有被使用并且碍眼”,从 AWS 控制台选择多个项目并在人工判断后删除它们会更容易。
此外,为了清理 ECR 图像,最好使用由 fujiwara-san 创建的名为 ecrm 的工具。
https://github.com/fujiwara/ecrm
2. 专门针对批量操作
我已最小化“要停止哪些资源”的选择器选项。
AWS控制台足以停止单个资源,并且在测试环境(不是登台等)中,不应该有任何“绝对不能停止”的资源。尤其是在晚上,我们要阻止它们。
前景
- 我想在 AWS 上定期执行 ecstop 作为计划进程(例如,每天 24:00)。
- 每次AWS认证从本地调用都很麻烦。
- 我正在考虑为 EventBridge Lambda 创建 IaC。
- 由于是测试环境,完成通知似乎没有必要。我不确定错误通知。
- 目前,我没有任何“我想添加此选项”。
- 如果有任何要求,我会考虑。
我使用的主要工具
ecstop 基于典型的 Go CLI 开发堆栈。
- Golang
- 眼镜蛇
- GoReleaser
- 自制水龙头
结论
这是我第一次发布 CLI 工具,我学到了很多东西,包括如何定义哲学。
如果您有任何反馈或要求,请通过 https://github.com/t-kikuc/ecstop 告诉我。
其实我正在开发另一个与ECS外部部署相关的CLI工具,计划很快发布。
以上是ecstop:我的 CLI 工具,可轻松停止 ECS 资源的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

Go语言在构建高效且可扩展的系统中表现出色,其优势包括:1.高性能:编译成机器码,运行速度快;2.并发编程:通过goroutines和channels简化多任务处理;3.简洁性:语法简洁,降低学习和维护成本;4.跨平台:支持跨平台编译,方便部署。

Golang在并发性上优于C ,而C 在原始速度上优于Golang。1)Golang通过goroutine和channel实现高效并发,适合处理大量并发任务。2)C 通过编译器优化和标准库,提供接近硬件的高性能,适合需要极致优化的应用。

Golang和C 在性能竞赛中的表现各有优势:1)Golang适合高并发和快速开发,2)C 提供更高性能和细粒度控制。选择应基于项目需求和团队技术栈。

Golang在性能和可扩展性方面优于Python。1)Golang的编译型特性和高效并发模型使其在高并发场景下表现出色。2)Python作为解释型语言,执行速度较慢,但通过工具如Cython可优化性能。

Golang和Python各有优势:Golang适合高性能和并发编程,Python适用于数据科学和Web开发。 Golang以其并发模型和高效性能着称,Python则以简洁语法和丰富库生态系统着称。

C 更适合需要直接控制硬件资源和高性能优化的场景,而Golang更适合需要快速开发和高并发处理的场景。1.C 的优势在于其接近硬件的特性和高度的优化能力,适合游戏开发等高性能需求。2.Golang的优势在于其简洁的语法和天然的并发支持,适合高并发服务开发。

GoimpactsdevelopmentPositationalityThroughSpeed,效率和模拟性。1)速度:gocompilesquicklyandrunseff,ifealforlargeprojects.2)效率:效率:ITScomprehenSevestAndArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdEcceSteral Depentencies,增强开发的简单性:3)SimpleflovelmentIcties:3)简单性。

Golang和C 在性能上的差异主要体现在内存管理、编译优化和运行时效率等方面。1)Golang的垃圾回收机制方便但可能影响性能,2)C 的手动内存管理和编译器优化在递归计算中表现更为高效。
