[教程] 如何提速 AWS Codebuild (从每次 30~40分钟优化到5分钟以下)
AWS 中国区(北京)
![[教程] 如何提速 AWS Codebuild (从每次 30~40分钟优化到5分钟以下)](/content/images/size/w2000/2020/02/codebuild2.jpg)
这篇文章讲什么
如何优化 AWS 中国区的 CodeBuild 速度
这篇文章对谁有用
使用 AWS Codebuild 的程序员
有什么用
看怎么提速
先讲结论(TLDR; 太长不看)
最有效的解决办法是:https://github.com/aws/aws-codebuild-docker-images/issues/26#issuecomment-370177343
data:image/s3,"s3://crabby-images/89ea7/89ea786738470b988934b934026cb9bb13809c9a" alt=""
我是这样写的:
data:image/s3,"s3://crabby-images/14ff3/14ff3b1daa0ac986e6ed12e63d1c765ad476b79e" alt=""
核心点:
- 这个 buildspec.yml 是指令 Codebuild 怎么进行 Build 的配置文件
- 在 pre_build 里面 docker pull
- 在 build 里面 docker build --cache-from
这就可以了
结论说完了,如果想关掉文章可以关了。如果你关心细节可以继续往下看
前言
我最近(2020年2月)在远程工作,给一家北京的公司干活。
公司产品用到了 AWS 中国区的各种工具,比如 ECS, ECR, Codebuild 等等。
整体部署流程是:
- 触发 Codebuild, Codebuild 会去 Github 把代码拿到,最后 build 出一个 Docker Image
- 把这个 Docker image 推到 AWS ECR
- 触发 AWS ECS, 从而达到线上更新的效果
额外信息
之前的工程师是美国人,
2019年6月开始做这个项目。
2020年2月我们中国工程师接手项目。
部署的时候发现了问题
data:image/s3,"s3://crabby-images/67941/6794137d5d45c21b2c5e72e1bbd9062c5c3dc922" alt=""
data:image/s3,"s3://crabby-images/67fdd/67fdd54eda9566580622cdeaee975828b9b3a101" alt=""
总结两点:
- "失败"和"已停止"挺多的
- 哪怕"成功",时间范围也非常大,短的有7分50秒,最长的有1小时19分钟。
问题在哪里?
部署太久了,需要提速。最好是每次5分钟以下。
解决办法1:启用 AWS Codebuild 自带的缓存(没用)
(截止至2020年2月17号)
如果你去网上搜怎么提速,
会看到这篇文章:
data:image/s3,"s3://crabby-images/02d42/02d423c2574c5557e0acecb67a5101339e53c104" alt=""
打开是这样的:
data:image/s3,"s3://crabby-images/64523/645237bd0cedcae1b5bd2378c8db0d1694d826f2" alt=""
然后它会告诉你启用缓存:
data:image/s3,"s3://crabby-images/4ae8d/4ae8d1e186216d52a196b93c5ed5db6eb9f9aee4" alt=""
如果用中文版的 AWS。
这里找:
data:image/s3,"s3://crabby-images/cdcdc/cdcdccc71c466be648ae3d86ea6256279178e382" alt=""
data:image/s3,"s3://crabby-images/45bd3/45bd30f55fe053b2f0dab1e2239d8a88d8ae8bd2" alt=""
实测结果是:用处不大
如果两次 build 间隔很短,只有几分钟,那么这个缓存就会生效。
具体这个缓存会存在多久,官方没有给出具体参数。
data:image/s3,"s3://crabby-images/2a453/2a4539809bc611aac1e2806c3a5f85ef85a00c98" alt=""
27分钟29秒这个。结束时间是2020-2-13 4:19
data:image/s3,"s3://crabby-images/3eba9/3eba92c5593c2358d66ff4ab4b0045f8b515307c" alt=""
1分3秒这个。开始时间是2020-2-13 4:21
data:image/s3,"s3://crabby-images/a1b65/a1b65e755dfd05c1248a665d9bdd88a48af9ec82" alt=""
27分钟29秒和1分30秒的这两次 Build。间隔才 3 分钟。
我们再来看看之后的 Build:
data:image/s3,"s3://crabby-images/6912e/6912e882c526865ea17441e9b8e3fabaa13f86ab" alt=""
34分钟14秒这个。开始时间是 2020-2-13 7:20。晚上7点。
data:image/s3,"s3://crabby-images/6661a/6661ab4502fc2ab94bce4e7aec6e7f95d7053f07" alt=""
可以得出:
间隔3分钟,缓存有效。
间隔3小时,缓存没了。
结论:
这方法没什么用,我们每次部署都是间隔好几天的。
因为肯定是本地开发完了才部署线上测试环境嘛。
有效的解决办法
在文章一开头就说了。我也就不重复了。
这里提供下 buildspec.yml
方便复制粘贴
https://gist.github.com/1c7/b0b0c0e25521da8adf5d068fc210a3bd
证明有效
data:image/s3,"s3://crabby-images/66c40/66c40ac7d542d4c826af88d2f71356601b43c572" alt=""
最近3次 Build 都在5分钟以下了,
而且还隔了2天。说明这个方法是有效的。