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
内定者バイトが1ヶ月ちょいでDSPをAmazonECSに乗っけた話
Search
Hiromu Masuda
September 28, 2018
Technology
1
1.3k
内定者バイトが1ヶ月ちょいでDSPをAmazonECSに乗っけた話
DSPサーバーをAmazonECSとFargateを用いて動かした際のアーキテクチャ・デプロイフローについてまとめました。
Hiromu Masuda
September 28, 2018
Tweet
Share
Other Decks in Technology
See All in Technology
QA組織のAI戦略とAIテスト設計システムAITASの実践
sansantech
PRO
1
260
Oracle AI Database@Azure:サービス概要のご紹介
oracle4engineer
PRO
4
1.3k
Zephyr(RTOS)でOpenPLCを実装してみた
iotengineer22
0
160
「活動」は激変する。「ベース」は変わらない ~ 4つの軸で捉える_AI時代ソフトウェア開発マネジメント
sentokun
0
130
AIにより大幅に強化された AWS Transform Customを触ってみる
0air
0
210
ADK + Gemini Enterprise で 外部 API 連携エージェント作るなら OAuth の仕組みを理解しておこう
kaz1437
0
240
JAWS DAYS 2026でAIの「もやっと」感が解消された話
smt7174
1
110
Oracle AI Database@Google Cloud:サービス概要のご紹介
oracle4engineer
PRO
5
1.3k
Physical AI on AWS リファレンスアーキテクチャ / Physical AI on AWS Reference Architecture
aws_shota
1
200
Cursor Subagentsはいいぞ
yug1224
2
120
FlutterでPiP再生を実装した話
s9a17
0
240
Network Firewall Proxyで 自前プロキシを消し去ることができるのか
gusandayo
0
130
Featured
See All Featured
How to Get Subject Matter Experts Bought In and Actively Contributing to SEO & PR Initiatives.
livdayseo
0
91
Agile Actions for Facilitating Distributed Teams - ADO2019
mkilby
0
160
Impact Scores and Hybrid Strategies: The future of link building
tamaranovitovic
0
240
KATA
mclloyd
PRO
35
15k
Side Projects
sachag
455
43k
XXLCSS - How to scale CSS and keep your sanity
sugarenia
249
1.3M
Save Time (by Creating Custom Rails Generators)
garrettdimon
PRO
32
2.6k
Navigating Weather and Climate Data
rabernat
0
150
The AI Revolution Will Not Be Monopolized: How open-source beats economies of scale, even for LLMs
inesmontani
PRO
3
3.2k
Keith and Marios Guide to Fast Websites
keithpitt
413
23k
How to optimise 3,500 product descriptions for ecommerce in one day using ChatGPT
katarinadahlin
PRO
1
3.5k
A designer walks into a library…
pauljervisheath
210
24k
Transcript
内定者バイトが1ヶ月ちょいで DSPをAmazonECSに乗っけた話 増田 大夢|Hiromu Masuda
自己紹介 増田 大夢|HiromuMasuda 東京大学工学部システム創成学科4年 静岡県浜松市出身 趣味:ボディビル・海外旅行 休日の過ごし方:ボディビル・海外旅行
アジェンダ 1. Amazon ECS / Fargate 導入の背景 2. Amazon ECS
/ Fargate とは 3. アーキテクチャ 4. デプロイ 5. 苦労話 6. 最後に
Amazon ECS / Fargate 導入背景
Amazon ECS / Fargate 導入の背景 • 挙動・設定がブラックボックスすぎる • ELB/SGの名前が自動生成で探しづらい •
Blue-Greenデプロイがroute53経由なため、DNSキャッシュがきいてしまい上手く切 り変わらない Elastic Beanstalkの苦労
Amazon ECS / Fargate 導入の背景 • コンテナ化してモダンにしたい • Fargateが東京リージョンでも使えるようになった •
今後EKSが東京リージョンに来た時に移行しやすそう Amazon ECS / Fargate を選んだ理由
Amazon ECS / Fargate とは
Amazon ECS / Fargate とは Amazon Elastic Container Service (Amazon
ECS) は、Docker コンテナをサポートする 拡張性とパフォーマンスに優れたコンテナオーケストレーションサービスです。これによ り、コンテナ化されたアプリケーションをAWSで簡単に実行およびスケールできます。
Amazon ECS / Fargate とは task / service / cluster
というレイヤー
Amazon ECS / Fargate とは task definition / task とは
docker-composeのようなもの。 task definitionにどのようなイメージを使ってどのようなコンテナを立てるのか、 CPU/メモリの割り当てをどうするか、環境変数・ポートの設定などをしておくと、 taskという形で定義されたコンテ ナの集合体を生成できる。
Amazon ECS / Fargate とは service とは 「指定したtask definitionからtaskを生成する」 という作業をいい感じにやってくれる。taskの希望台数・最大数・
最低数、オートスケールの ルールを設定することで、CPU/メモリの使用量やタスクのステータスを監視しながら 自動でタスクの台数を調節 してくれる。
Amazon ECS / Fargate とは cluster とは taskとserviceをグルーピングする概念
Amazon ECS / Fargate とは Fargate とは サーバレスでコンテナが実行できる技術 であり、タスク(コンテナの実行単位)に割り当てたvCPUとメモリの量に 応じて秒単位での課金でコンテナを実行できる。Fargateを用いれば
EC2インスタンスの管理が不要 になり、オー トスケールに柔軟に対応 できる。
アーキテクチャ
アーキテクチャ ECR cluster: service Fargate task task task DSP task
definition ELB images SSP DSP DSP
アーキテクチャ ECR cluster: service Fargate task task task DSP task
definition ELB images SSP DSP DSP AWS版DockerHub Docker image用レポジトリ
アーキテクチャ ECR cluster: service Fargate task task task DSP task
definition ELB images SSP DSP DSP ECRのimageから task definitionを作成
アーキテクチャ ECR cluster: service Fargate task task task DSP task
definition ELB images SSP DSP DSP serviceは task definitionを用いて taskを生成する
アーキテクチャ ECR cluster: service Fargate task task task DSP task
definition ELB images SSP DSP DSP task内では、 DSP/datadog/flumeの 3つのプロセスが コンテナとして動く
アーキテクチャ ECR cluster: service Fargate task task task DSP task
definition ELB images SSP DSP DSP コンテナは Fargate上で 動いている
アーキテクチャ ECR cluster: service Fargate task task task DSP task
definition ELB images SSP DSP DSP serviceはロードバランサを管理。ELBがリ クエストを 複数のtaskに振り分ける
デプロイ
- ECSにはblue-greenデプロイを実現する機能は存在するが、それ以外はない - デプロイ用ライブラリも「これだ!」というものがない - カナリアデプロイがしたい - そのため、1からデプロイを実装した デプロイ
デプロイ ECR cluster: service Fargate task task DSP task definition
ELB SSP DSP Jenkins カナリアデプロイ
デプロイ ECR cluster: service Fargate task task DSP task definition
ELB SSP DSP Jenkins カナリアデプロイ images 1. push
デプロイ ECR cluster: service Fargate task task DSP task definition
ELB SSP DSP Jenkins カナリアデプロイ images 1. push task definition 2. create
デプロイ ECR cluster: service Fargate task task DSP task definition
ELB SSP DSP Jenkins カナリアデプロイ images 1. push task definition 2. create 3. run task DSP
デプロイ ECR cluster: service Fargate task task DSP task definition
ELB SSP DSP Jenkins カナリアデプロイ images 1. push task definition 2. create task DSP 3. run 4. connect
デプロイ ECR cluster: service Fargate task task DSP task definition
ELB SSP DSP Jenkins 全デプロイ images task definition task DSP
デプロイ ECR cluster: service Fargate task task DSP task definition
ELB SSP DSP Jenkins 全デプロイ images task definition task DSP 1. update
デプロイ ECR cluster: service Fargate task task DSP task definition
ELB SSP DSP Jenkins 全デプロイ images task definition 1. update 2. remove
デプロイ ECR cluster: service Fargate task task DSP task definition
ELB SSP DSP Jenkins ロールバック images task definition
デプロイ ECR cluster: service Fargate task task DSP task definition
ELB SSP DSP Jenkins ロールバック images task definition 1. update
苦労話
苦労話 Fargateに関する周辺ツールのバグが多い 「datadogにDSPのメトリクスが送れない」という問題があった。Fargateを使うとホストに紐づくタグがメトリクスに 引き継がれないという バグが原因。
苦労話 ライブラリ・ツールがFargateに追いついていない 2つくらいしかデプロイ用のライブラリが見つからない上に、それがまだ Fargateに対応できていない 状況。issue もできたばっかり。結局デプロイ用のスクリプトは1から構築した。
苦労話 Fargateで動くコンテナにdocker execできない 「コンテナに入ってみてデバックする」というのが当たり前すぎて、それができず辛かった。
最後に
最後に 現在DSPはECS上で 正常に動いています。 苦労して作り上げてよかったです。