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
プロダクトの成長に伴うAWSの利用サービスとアーキテクチャの変遷
Search
Tomoki Kawajiri
August 26, 2022
Technology
0
800
プロダクトの成長に伴うAWSの利用サービスとアーキテクチャの変遷
https://aws-startup-community.connpass.com/event/247548/
Tomoki Kawajiri
August 26, 2022
Tweet
Share
More Decks by Tomoki Kawajiri
See All by Tomoki Kawajiri
フレームワークのソースコードから知識を深める
weistom
0
800
Other Decks in Technology
See All in Technology
BrainPadプログラミングコンテスト記念LT会2025_社内イベント&問題解説
brainpadpr
1
180
AWS Summit Japan 2025 Community Stage - App workflow automation by AWS Step Functions
matsuihidetoshi
1
300
【5分でわかる】セーフィー エンジニア向け会社紹介
safie_recruit
0
26k
250627 関西Ruby会議08 前夜祭 RejectKaigi「DJ on Ruby Ver.0.1」
msykd
PRO
2
370
ドメイン特化なCLIPモデルとデータセットの紹介
tattaka
1
310
Snowflake Summit 2025全体振り返り / Snowflake Summit 2025 Overall Review
mtpooh
2
440
MySQL5.6から8.4へ 戦いの記録
kyoshidaxx
1
290
KubeCon + CloudNativeCon Japan 2025 Recap
ren510dev
1
290
Github Copilot エージェントモードで試してみた
ochtum
0
130
事業成長の裏側:エンジニア組織と開発生産性の進化 / 20250703 Rinto Ikenoue
shift_evolve
PRO
1
100
Amazon S3標準/ S3 Tables/S3 Express One Zoneを使ったログ分析
shigeruoda
5
580
PHP開発者のためのSOLID原則再入門 #phpcon / PHP Conference Japan 2025
shogogg
4
920
Featured
See All Featured
RailsConf 2023
tenderlove
30
1.1k
The Power of CSS Pseudo Elements
geoffreycrofte
77
5.8k
Designing for Performance
lara
609
69k
The Psychology of Web Performance [Beyond Tellerrand 2023]
tammyeverts
48
2.9k
The MySQL Ecosystem @ GitHub 2015
samlambert
251
13k
Build your cross-platform service in a week with App Engine
jlugia
231
18k
Building Better People: How to give real-time feedback that sticks.
wjessup
367
19k
Measuring & Analyzing Core Web Vitals
bluesmoon
7
500
Let's Do A Bunch of Simple Stuff to Make Websites Faster
chriscoyier
507
140k
The Illustrated Children's Guide to Kubernetes
chrisshort
48
50k
What’s in a name? Adding method to the madness
productmarketing
PRO
23
3.5k
Practical Tips for Bootstrapping Information Extraction Pipelines
honnibal
PRO
20
1.3k
Transcript
プロダクトの成長に伴うAWSの 利用サービスとアーキテクチャの変遷 株式会社おてつたび 川尻智樹
株式会社おてつたび リードエンジニア 川尻 智樹 前職の楽天のアクセラレーションプログラムを きっかけに代表の永岡と出会い、創業当初から プロダクト開発全般に携わる。 現在は Rails と
React、楽天時代はバックエンド メインで Java や Python で開発
Our Vision 日本各地にある本当にいい人、いいもの、い い地域がしっかり評価される世界を創る
短期的・季節的な人手不足で困っている地域の方々と、地域に 興味がある方が出会えるマッチングプラットフォーム おてつたび 登録ユーザー数は2.3万人、 受入先は全国47都道府県 700事業者に拡大
サービス規模拡大の中での取り組み アクセス数増加への 対応 スケーリング パフォーマンス向上 コストの最適化 プロダクト規模拡大 によるボトルネック の解消 利用サービスの増加で
上がったコストの最適 化
インスタンスのオートスケーリング プロダクトローンチ 〜 オートスケーリングの導入
プロダクトローンチ EC2 x 2 と RDS の構成 • ALB と
EC2 x 2 のターゲットグ ループ • ALB には AWS Certificate Manager が発行した証明書を バインド
• EC2 インスタンスは 2 台 ◦ 負荷分散とリスクヘッジのため • データベースは RDS
を利用 ◦ データは一番の資産なので(当たり前ですが)バックアップも可能な RDS でデータ管理 • CloudFront でコンテンツ配信 ◦ CDN による高速配信に加え、アクセスの分散にもつながる
運用を開始してから見えてきた課題 • 突発的なアクセス増加への対応 ◦ TV放映など、メディア露出した時のアクセス数の増加にも耐えうる 体制の構築 • プロダクト規模への対応 ◦ プロダクトの数が増えたこと、プロダクトの規模が大きくなるにつれ
EC2 インスタンスの負荷が高まる
EC2 オートスケーリング • EC2 インスタンスを自動的に追加または削除 することができる ◦ 指定の時間にスケジューリングすることで 予期されるアクセス数増加への体制の構 築
◦ 条件を指定することで一時的な増加にも 対応できる 出典:Amazon EC2 Auto Scaling(需要に合わせてコンピューティング 性能を拡張)| AWS
Application Load Balancer 出典:Application Load Balancer とは? - Elastic Load
Balancing トラフィックを複数のターゲットに分散させる • Listener ごとにルールを指定して アクセスを分散 • ヘルスチェックで有効なインスタン スへアクセスする • モニタリングでトラフィックやインス タンスの状態を監視
None
パフォーマンスの向上 ボトルネックの解消への取り組み
背景 • DB のパフォーマンス悪化 ◦ クエリの数が増えることで CPU 使用率が高まり、アクセススピード が悪化 •
他のプロダクトも影響を受ける ◦ DB の負荷が高まることで他のプロダクトのパフォーマンスも同時に 悪化
取り組み 1 - リードレプリカ プライマリと読み取り専用のレプリカ インスタンスに分ける 出典:Amazon RDS リードレプリカ |
クラウドリレーショナルデータベー ス | アマゾン ウェブ サービス • 読み取りのクエリ(SELECT 文)はレプリ カに投げることでプライマリのパフォー マンスと耐久性向上 • レプリカを増やすことで他プロダクトが 影響を受けなくなる
取り組み 2 - ElastiCache でデータキャッシュ フルマネージドのインメモリキャッシングサービス Redis にデータをキャッシュして DB の負荷軽減とパフォーマンスの向上
• マスターデータなど変更性が低いレコードや取得回数が多いレ コードを一定時間キャッシュ ◦ DB へのアクセスがなくなり負荷軽減 ◦ データを早く取得できるので、アプリケーションのパフォー マンスも向上
取り組み 2 - ElastiCache Redis • プライマリと読み取り専用のレプリカのエンドポイントを使い分ける ◦ 読み取りが多い場合にレプリカを分散させることで負荷を軽減できる 出典:Replication:
Redis (Cluster Mode Disabled) vs. Redis (Cluster Mode Enabled) - Amazon ElastiCache for Redis
取り組み 3 - ALB ターゲットグループを複数管理 出典:Elastic Load Balancing(複数のターゲットにわたる着信トラフィックの分 配)| AWS
アプリケーションへのトラフィックを複数のターゲットに分けることでアクセスの負荷分散 • グループを増やすことでアクセス を分散 • パスベースのルーティングで特定 のアクセスのみ分けることが可能
コスト最適化 利用サービスやインスタンスが増えたことで 上がったコストの最適化 RDS ElastiCache EC2 インスタンス
EC2 リザーブドインスタンス インスタンスタイプ(t3.medium など)とインスタンス数、期間を指定して購入すると、期 間内は料金がオンデマンドインスタンスに比べて最大 72 % も安く利用できる • 踏み台サーバーや
Cron Job 実行のサーバーなど、インスタンスタイプが固定で必 要なインスタンス用に購入すると良い ◦ アクセスの大幅な増減があまり発生しないプロダクトのインスタンスに使用す ることもおすすめ
EC2 スポットインスタンス AWS クラウド内で使用されていない EC2 キャパシティーを利用して、インスタンスを起 動する。オンデマンド料金に比べ最大 90 %割引 需要と供給の変動で利用できるキャパシティーも変わるので、キャパシティーがなくなる
と突然インスタンスは終了する 終了した場合の対応を構築することで運用は可能 出典:Amazon EC2 だけじゃない⼊ 最⼊のコス ト効率を⼊に⼊れるための スポットインスタンス 使いこなし術
EC2 のインスタンスサイズの調整 インスタンスサイズが異なる複数グループを使用することで料金を抑える。 例えば、small サイズのインスタンスのターゲットグループで通常時は運用して、アクセ スが増えるタイミングで medium サイズのグループに切り替えてトラフィックを受けること で、コストを必要最小限に抑えることができる。
EC2 のインスタンスサイズの最適化 モニタリングでトラフィック数や CPU 使用率を参考にすることもできるが、 Jmeter などを使用して負荷テストを行い、限界値を知ることで最適なサイズを知る必要 がある アプリケーション規模が大きくなるとトラフィックは同じでも、インスタンスのメモリや CPU
使用率は高まるので、アプリケーションが起動した状態での限界を知ることがベスト
RDS インスタンスサイズの調整 リードレプリカのインスタンスサイズも必要なタイミングで切り替えることでコストを抑え る。
RDS リードレプリカの分散 読み込み要求を複数の Amazon RDS リードレプリカに分散させる方 法を教えてください。 Route53 に CNAME
で加重レコードを登録して、指定のレプリカへ転送することで複数 のレプリカへ分散させる
None
まとめ EC2 • EC2 オートスケーリングでインスタンスの自動調整 ◦ 条件を登録して自動化 ◦ スケジューリングで予期されるトラフィック増加へ対応する •
ALB でトラフィックの分散 ◦ ターゲットグループの切り替えでインスタンスサイズの調整 ◦ モニタリングで状況把握
まとめ RDS • RDS リードレプリカで負荷分散 • Route 53 に CNAME
で加重レコードを登録することで複数のレプリカを利用 ElastiCache • キャッシュすることで DB への負荷軽減 • アプリケーションのパフォーマンスの加速 • レプリカによる負荷分散
おすすめ • テクニカルサポート ◦ 設定の方法から課題のソリューション提案まで、幅広いサポートをもら えるので、積極的に利用することをおすすめします • スタートアップ支援プログラム ◦ スタートアップ企業への補助プログラムもあるので、申請することをお
すすめします ◦ クレジットの範囲内で利用料が割引
今後の取り組み
コンテナ化 Elastic Container Registry(ECR) と Elastic Container Service(ECS) でコン テナを使用したアプリケーション起動
• ECR にイメージ(ソースコード)を プッシュ • ECS が ECR からプルしてアプリ ケーションを起動
コンテナ化のメリット 運用工数・コストの削減とスピードアップ • デプロイスピードの向上 • コンテナでカプセル化されるので、OS や言語などのバージョンアップ 対応の工数を削減 • 環境要因によるトラブル削減
インスタンス変更の自動化 Amazon CLI を使用した自動化。Lambda で実行することも可能 ちょっとした対応の積み重ねもコストになるので、自動化することで効率化 できる • ALB ターゲットグループの切り替え
• RDS リードレプリカの作成と削除 などなど
エンジニアを募集しています おてつたびでは、新しい旅の形を一緒に作っていく仲間を募集中です! まずはカジュアルにお話ししましょう! • iOS アプリエンジニア • Webフルスタックエンジニア Wantedly 会社概要
Meety
テックブログと SNS の紹介 Zenn Twitter @tomoki_kawajiri 開発チームでテックブログの発信を行っています。 興味ある方は是非フォローお願いします!