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
ECS移設におけるShoryuken導入の経緯と葛藤について / ginzarails_vol...
Search
リンクアンドモチベーション
PRO
June 18, 2021
Technology
1.2k
1
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
ECS移設におけるShoryuken導入の経緯と葛藤について / ginzarails_vol34_presentation
銀座Rails#34 登壇資料
リンクアンドモチベーション
PRO
June 18, 2021
More Decks by リンクアンドモチベーション
See All by リンクアンドモチベーション
経験より先に、役割がきた —何を学べば、役割に追いつけるか/エンジニアの役割の変化に向き合うConference 2026
lmi
PRO
0
300
AI架電FBでIS新人を3ヶ月で戦力化した話 /ai-feedback-3month-rampup_link-and-motivation
lmi
PRO
0
61
RubyKaigiに参加することで気づいた 「俺、Rubyのこと全然知らなくね?」/ RailsTokyo#4
lmi
PRO
0
87
非エンジニアの私の、AIを動かすコツ ── 振り返る、Whyを伝える、歩み寄る / LT大会&交流会 by QuratedLab
lmi
PRO
0
40
逃げ場をなくしたら見えた景色 — 新人SREがAIで「自分の領域」を作るまで/rookie-sre-no-way-back_link-and-motivation
lmi
PRO
0
100
AI時代の新卒を黄金世代にするために 〜やってよかったこと、まだ足りないこと〜/ai-native-engineers_link-and-motivation
lmi
PRO
0
140
失敗から学ぶ ~サブエージェントの正しい使い方~/subagent-lessons-learned_link-and-motivation
lmi
PRO
0
600
ワクワクは「管理」できないが 「設計」することはできる/designing-excitement--link-and-motivation
lmi
PRO
0
99
IFを定義して、コードとチームを守れ!/protect-code-and-team-link-and-motivation
lmi
PRO
0
460
Other Decks in Technology
See All in Technology
"何を作るか"を任される エンジニアは、どう育つのか
yutaokafuji
1
500
2026.06.13_AI時代に事業会社が「SIer出身エンジニア」を求める理由 / Why Businesses Seek Engineers with a System Integrator Background in the AI Era
jumtech
0
990
製造業のクラウド活用最適解〜AI,DXを加速するデータ基盤の作り方〜
hamadakoji
0
430
Mastering Ruby Box
tagomoris
3
160
2026TECHFRESH畢業分享會 - 葬送的通靈師:化系統與用戶雜訊成行動訊號
line_developers_tw
PRO
0
150
ChatworkとBPaaS 異なる特性で学んだAI機能開発の ベストプラクティス
kubell_hr
2
3.4k
機械学習を「社会実装」するということ 2026年夏版 / Social Implementation of Machine Learning June 2026 Version
moepy_stats
3
840
EventBridge Connection
_kensh
5
680
noUncheckedIndexedAccess、3時間、1万円。 / noUncheckedIndexedAccess, 3 Hours, 10,000 JPY.
kaonavi
1
340
Claude Code×Terraform IaC テンプレート駆動開発
itouhi
1
470
「速く作る」から「正しく作る」へ ─ 生成AI時代の開発フロー改革の ロードマップと実行 ─
starfish719
0
9.5k
2026TECHFRESH畢業分享會 - 原生還是跨平台? App 開發踩坑實錄
line_developers_tw
PRO
0
150
Featured
See All Featured
Learning to Love Humans: Emotional Interface Design
aarron
275
41k
YesSQL, Process and Tooling at Scale
rocio
174
15k
Product Roadmaps are Hard
iamctodd
PRO
55
12k
Site-Speed That Sticks
csswizardry
13
1.2k
What's in a price? How to price your products and services
michaelherold
247
13k
VelocityConf: Rendering Performance Case Studies
addyosmani
333
25k
Kristin Tynski - Automating Marketing Tasks With AI
techseoconnect
PRO
0
270
Groundhog Day: Seeking Process in Gaming for Health
codingconduct
0
200
Typedesign – Prime Four
hannesfritz
42
3.1k
The Myth of the Modular Monolith - Day 2 Keynote - Rails World 2024
eileencodes
28
3.5k
First, design no harm
axbom
PRO
2
1.2k
Exploring the relationship between traditional SERPs and Gen AI search
raygrieselhuber
PRO
2
4k
Transcript
ECS移設におけるShoryuken導入の 経緯と葛藤について 株式会社リンクアンドモチベーション 岸本直樹
自己紹介 氏名: 岸本直樹 出身 経歴 職歴 趣味・特技 愛知県名古屋市 2019年 リンクアンドモチベーション入社
2019年 モチベーションクラウド新機能開発 2020年 SREチーム JOIN 2020年 セキュリティ強化対応 2021年 ECS移設対応 TikTok鑑賞・Apex
今日話すこと ECS移設に伴い、 非同期処理のライブラリを 見直すことになりました。 その過程で起きた 意思決定と課題についてお話します。
ECS移設の背景
ECS移設の背景
ECS移設の背景 ICE BLOCK INK BLOT INTER LINK IDLE LINK 期待:
高 習熟度: 低 | 弱み 期待: 低 習熟度: 低 | やらない 期待: 高 習熟度: 高 | 強み 期待: 低 習熟度: 高 | やらない 2. 変更のリードタイム 1. デプロイ頻度 期待 習熟度 3. 平均修復時間(MTTR) 4. 変更失敗率 14. ソースコードの明確さ 6. インシデントレート Nothing Low Middle High High Middle Low Nothing 7. インシデント再発防止 12. セキュリティリスク 18. 疎結合アーキテクチャ 19. モニタリング 20. セキュリティシフトレフト 8. 生産性に影響する不具合
ECS移設の背景 12. セキュリティリスク Before After リリース作業の リードタイム 2時間-3時間 MTTR(切り戻し) 1時間
リリース作業の リードタイム 30分 ※1/6に短縮 MTTR(切り戻し) 10分 ※1/6に短縮 ▼想定アウトカム/先行指標
ECS移設の背景 12. セキュリティリスク Before After リリース作業の リードタイム 2時間-3時間 MTTR(切り戻し) 1時間
リリース作業の リードタイム 30分 ※1/6に短縮 MTTR(切り戻し) 10分 ※1/6に短縮 ▼想定アウトカム/先行指標 デプロイ頻度 10回/月 メンテナンス時間 6時間/月 デプロイ頻度 20回/月 ※2倍に増加 メンテナンス時間 0時間 ※メンテフリー ▼想定アウトカム/遅行指標
ECS移設における課題 これまでは非同期処理に、 EB用のactive-elastic-jobというgemを利用。 ECS移設に伴い、代替するgemを検討することになる。 https://github.com/active-elastic-job/active-elastic-job
Worker要件整理 主な要件 概要 詳細 ジョブ実行の担保 • リトライ処理 • ロストリスク低減 •
エラーハンドリング パフォーマンス • 最大同時ジョブ処理数の担保 概要 詳細 コスト • 移行コスト • メンテナンスコスト Must Want
非同期処理要件整理 Workerの比較 Worker Queuing リトライ処理 (must) ロストリスク (must) エラーハンドリング (must)
パフォーマンス (want) 移行/運用コスト (want) Sidekiq Redis ◯ △(※) ※Sidekiq Pro では担保される ◯ ◯ △ Resque Redis ☓ ☓ ◯ △ △ Shoryuken AWS SQS ◯ ◯ △(※) ※一部課題あり ◯ ◯ 主にロストリスクとコスト(移行/運用)の観点でShoryukenが選択肢にあがった。
Shoryukenとは?
Shoryukenとは? 概要: 「AWS SQS」からジョブ取り出すワーカーを 簡単に作成することができるGem メリット: ・ジョブが失われるリスクがない ・Active Jobが使える デメリット:
・日本では導入事例や記事が少ない https://github.com/ruby-shoryuken/shoryuken
Shoryuken導入の課題 1.Logging 2. Testing 3. Resource
Shoryuken導入の課題 1.Logging 2. Testing 3. Resource
Shoryuken導入の課題 特定アプリケーションにおけるロギング課題 Active Elastic Job Shoryuken pumaプロセスでエラーをキャッチし、 エラーログをSentryに送信。 sqs daemon
puma EB
Shoryuken導入の課題 特定アプリケーションにおけるロギング課題 Active Elastic Job Shoryuken pumaプロセスでエラーをキャッチし、 エラーログをSentryに送信。 pumaプロセスとは別に、Shoryukenプ ロセスが起動。これまでのエラーハンド
リングではエラーログをSentryに送信で きないことが判明。 sqs daemon puma EB ECS エラー 検知実装 puma
Shoryuken導入の課題 特定アプリケーションにおけるロギング課題 解決方法:エラー発生時にログを出力するよう独自実装 • 関数 • 各エラーに応じて、エラーログ作成
Shoryuken導入の課題 1.Logging 2. Testing 3. Resource
Shoryuken導入の課題 非同期処理のテスト課題 ActiveJobを使用可能→ ActiveJob::TestHelperを使用し、実装 Shoryukenを用いてテストコードを書く際、 Shoryuken Shoryuken pollingから処理実行までを自動テストで担保
Shoryuken導入の課題 1.Logging 2. Testing 3. Resource
Shoryuken導入の課題 リソース効率課題 Shoryukenは1プロセスマルチスレッドベースで設計されているため工夫が必要。
Shoryuken導入の課題 リソース効率課題 Shoryukenは1プロセスマルチスレッドベースで設計されているため工夫が必要。 1. コンテナ数をCPUコア数に合わせる 2.プロセス数をCPUコア数に合わせる プロセス プロセス プロセス インスタンス
コア コア コア CPU docker docker docker データプレーン層 コア コア コア CPU
Shoryuken導入後の結果
Shoryuken導入後の結果 ECS移設後Shoryuken含め、安定稼働 🎉 🎉
Shoryuken導入後の結果 Shoryukenは使いにくい? 1. Shoryuken での設定値の共有がイマイチ 2. 100万トランザクションは簡単に突破しそう 3. 個人で開発された gem
である
Shoryuken導入後の結果
Shoryuken導入後の結果 環境変数を利用することで回避した
Shoryuken導入後の結果
Shoryuken導入後の結果 SQS利用による金額コストは予算内だった
Shoryuken導入後の結果
Shoryuken導入後の結果 複数の企業で利用実績がある
Shoryuken導入後の結果 Shoryukenはオープンソース。 Contributorとして、開発で必要な時は自ら修正できる。
最後に We Are Hiring!! https://www.wantedly.com/companies/lmi