Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
20240201_クラウド利用料を 半額にするために取り組んだ10+のコト
Search
Kazuki Maeda
February 01, 2024
Technology
4
7.1k
20240201_クラウド利用料を 半額にするために取り組んだ10+のコト
第1回 AWSコスト削減 天下一武道会
Kazuki Maeda
February 01, 2024
Tweet
Share
More Decks by Kazuki Maeda
See All by Kazuki Maeda
生成AIによって変わる世界 -可能性とリスクについて考える-
kzkmaeda
2
110
新しいことを組織ではじめる、そしてつづける
kzkmaeda
5
760
20240824_JAWS_PANKRATION_2024
kzkmaeda
0
45
20240416_devopsdaystokyo
kzkmaeda
1
380
20240321_生成AI時代のDevOps
kzkmaeda
2
990
20240222_LangChain_ver0.1.0_LCEL
kzkmaeda
4
360
20231027_Bedrock勉強会
kzkmaeda
3
1.2k
20231011_LangChainコントリビュートのすゝめ
kzkmaeda
0
1.2k
LangChain Japan MeetUp 2023-07-20
kzkmaeda
0
590
Other Decks in Technology
See All in Technology
マルチプロダクトな開発組織で 「開発生産性」に向き合うために試みたこと / Improving Multi-Product Dev Productivity
sugamasao
1
300
Terraform Stacks入門 #HashiTalks
msato
0
350
ドメイン名の終活について - JPAAWG 7th -
mikit
33
20k
VideoMamba: State Space Model for Efficient Video Understanding
chou500
0
190
AWS Lambdaと歩んだ“サーバーレス”と今後 #lambda_10years
yoshidashingo
1
170
いざ、BSC討伐の旅
nikinusu
2
780
ExaDB-D dbaascli で出来ること
oracle4engineer
PRO
0
3.8k
フルカイテン株式会社 採用資料
fullkaiten
0
40k
Why does continuous profiling matter to developers? #appdevelopercon
salaboy
0
190
信頼性に挑む中で拡張できる・得られる1人のスキルセットとは?
ken5scal
2
530
AIチャットボット開発への生成AI活用
ryomrt
0
170
Evangelismo técnico: ¿qué, cómo y por qué?
trishagee
0
360
Featured
See All Featured
Automating Front-end Workflow
addyosmani
1366
200k
How GitHub (no longer) Works
holman
310
140k
Product Roadmaps are Hard
iamctodd
PRO
49
11k
Easily Structure & Communicate Ideas using Wireframe
afnizarnur
191
16k
Build The Right Thing And Hit Your Dates
maggiecrowley
33
2.4k
Designing for humans not robots
tammielis
250
25k
Design and Strategy: How to Deal with People Who Don’t "Get" Design
morganepeng
126
18k
Into the Great Unknown - MozCon
thekraken
32
1.5k
Docker and Python
trallard
40
3.1k
For a Future-Friendly Web
brad_frost
175
9.4k
The Web Performance Landscape in 2024 [PerfNow 2024]
tammyeverts
0
91
Scaling GitHub
holman
458
140k
Transcript
クラウド利用料を 半額にするために取り組んだ10+のコト 第1回 AWSコスト削減 天下一武道会 2024-02-01 @kzk_maeda
自己紹介 Kazuki Maeda 𝕏 @kzk_maeda SRE/DRE/EM @atama plus AWS Community
Builders AWS Startup Community Core Member
10+のコト
結論:いろいろやりました • HerokuからFargate移行 • 開発環境自動停止 • ECS台数最適化 • 不要データの削除 •
Arm移行 • タスク起動高速化 • Pull Through Cache Repository • NATインスタンス化 • RDS Snapshot削除漏れ通知 • secondary region停止 • Backup期間整理 • Amazon MQ→SQS移行 • ログ保管期間整理 • RI/SP購入 • リセラー契約 • ・・・
5分では話せません!🙇
インパクトが大きかった 事例を紹介します
agenda • コスト構造の抽象度を上げる • 具体的な事例 • まとめ
コスト構造の抽象度を上げる
コストを俯瞰してみる • コスト削減に取り組む上で、コスト構造の解像度を上げるために 細かく調べることはよくやりそう
この辺がそれ系 • HerokuからFargate移行 • 開発環境自動停止 • ECS台数最適化 • 不要データの削除 •
Arm移行 • タスク起動高速化 • Pull Through Cache Repository • NATインスタンス化 • RDS Snapshot削除漏れ通知 • secondary regionを普段停止 • Backup期間整理 • Amazon MQ→SQS移行 • EC2→CircleCI移行 • ログ保管期間整理 • RI/SP購入 • リセラー契約 • ・・・
劇的な効果は得づらい・・?
コストを俯瞰してみる • アーキテクチャ全体を俯瞰することで、システム最適化に付随す るコスト最適化も狙える • AWSのコストを下げることだけを目的にするのではなく、システ ム全体のコストを、オペレーションコストも合わせて下げに行く
コストを俯瞰してみる このcomponentは 必要かな?? このサービスで 実現する必要ある?? ※考え方の一例
この辺 • HerokuからFargate移行 • 開発環境自動停止 • ECS台数最適化 • 不要データの削除 •
Arm移行 • タスク起動高速化 • Pull Through Cache Repository • NATインスタンス化 • RDS Snapshot削除漏れ通知 • secondary region停止 • Backup期間整理 • Amazon MQ→SQS移行 • EC2→CircleCI移行 • ログ保管期間整理 • RI/SP購入 • リセラー契約 • ・・・
何を対応すべきか決める • こうして挙がったリアーキテクチャ候補を比較し、 比較検討 • 当然工数もかかるので ROIも検討
具体的な事例
HerokuからECS Fargateへの移行 • Herokuで実装されていたアプリ基盤をFargateに移行 • 年間固定費用であったライセンス費用を、コスト柔軟性が高い構 成に変更することで、年間40%のコストを削減 • その後Savings Plansの活用やAuto
Scaling条件の調整を繰り返 し、さらなるコスト削減を実施
EC2からCircleCIへの移行 • EC2で実行されているデプロイ関連の処理を改修し、 CircleCIの実行インスタンス上に置き換え • 年間数十万のコスト削減に加え、デプロイ時間の短縮、オペレー ションコストの削減など多岐にわたる効果
伝えきれなかった話はこちら • 去年はいろんなコスト削減施策に取り組みました • 詳しくは以下のTech Blogにも記載しているのでよければご覧くだ さい! • atama plusが2023年に取り組んだクラウドインフラコスト削減を
振り返る
全体でこれくらい減りました 50%!!! ※円建比較です
まとめ
まとめ • コスト最適化のために、コスト構造をドリルダウンして検討するだ けでなく、全体を俯瞰した大きな変更ができると、大きな効果を産 める期待値がある • 同時に運用負荷や信頼性の観点でも改善する可能性も • 積極的に構成を見直し、コスト構造を最適化していきましょう!