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
bank engineer night#02
Search
Bank, Inc
October 11, 2018
Technology
2.8k
2
Share
bank engineer night#02
Bank, Inc
October 11, 2018
More Decks by Bank, Inc
See All by Bank, Inc
BANK「PRの7RULES」
bankinc220
2
5.2k
send-push-notification-with-knative.pdf
bankinc220
0
2.2k
bank engineer night#02
bankinc220
0
2.1k
bank engineer night#02
bankinc220
1
2.6k
CASH を支える Google Kubernetes Engine
bankinc220
0
2.7k
PRLT
bankinc220
1
78
travelnow
bankinc220
0
110
heybanknight
bankinc220
1
130
How CASH works!〜CASHのシステム構成〜
bankinc220
1
1k
Other Decks in Technology
See All in Technology
Generative UI × A2UI で AI エージェントを作った話 AI-DLC も使ってみた!
kmiya84377
1
170
Gradle×GitHub_ActionsでCI時間を約50%短縮 ジョブ分割の設計と落とし穴 / Cutting CI Time by ~50% with Gradle and GitHub Actions: Job-Splitting Design and Pitfalls
takatty
0
140
Kiro CLI v2.0.0がやってきた!
kentapapa
0
100
食べログのサーキットブレーカー導入を振り返って
atpons
0
110
Anthropic AIネイティブ・スタートアップ構築のプレイブック を理解する
nagatsu
0
180
生成AIに振り回されない 〜確率論と決定論の使い分け〜
shukob
0
110
イベントで大活躍する電子ペーパー名札 〜その3〜 / ビジュアルプログラミングIoTLT vol.23
you
PRO
0
140
AIコーディングエージェントの活用で、コードは静かに肥大化した
yosukeshinoda
1
360
データ基盤構築・運用の現場から 〜 Snowflake Intelligence 導入で変わった、データ活用の未来 〜
wonohe
0
180
基礎から解説!Icebergで紐解くSnowflake×Databricks連携の現在地
cm_yasuhara
0
310
Claude Codeですべての日常業務を爆速化しよう!
minorun365
PRO
15
13k
AIのために、AIを使った、Effect-TSからの脱却 〜テストを活用した安全なリファクタリングの進め方〜
bitkey
PRO
1
570
Featured
See All Featured
Digital Projects Gone Horribly Wrong (And the UX Pros Who Still Save the Day) - Dean Schuster
uxyall
0
1.5k
SEO Brein meetup: CTRL+C is not how to scale international SEO
lindahogenes
1
2.7k
Chrome DevTools: State of the Union 2024 - Debugging React & Beyond
addyosmani
10
1.2k
CSS Pre-Processors: Stylus, Less & Sass
bermonpainter
360
30k
Fireside Chat
paigeccino
42
3.9k
Creating an realtime collaboration tool: Agile Flush - .NET Oxford
marcduiker
35
2.4k
First, design no harm
axbom
PRO
2
1.2k
Mozcon NYC 2025: Stop Losing SEO Traffic
samtorres
0
240
How Fast Is Fast Enough? [PerfNow 2025]
tammyeverts
3
580
The Art of Delivering Value - GDevCon NA Keynote
reverentgeek
16
2k
The Hidden Cost of Media on the Web [PixelPalooza 2025]
tammyeverts
2
310
A brief & incomplete history of UX Design for the World Wide Web: 1989–2019
jct
2
380
Transcript
スピード狂エンジニアたちの開発 速度を保つインフラとは Bank,Inc 高橋 拓也
自己紹介 - 高橋拓也 - サーバサイドとクラウドインフラ - Kubernetes が好き - 糖質制限中
本日の内容 とある取り組みをベースに, 手が速い人達を押さえつけない ための学びを教えます
開発チーム この1年で一気に エンジニアが増えた
開発チーム 初期リリース時: 数人
開発チーム 現在: 15 ~ 20人くらい
開発チーム 昔ながらの開発フローが だんだん通用しなくなる
開発チーム 数人 ~ 10人時代
開発チーム どうやって開発していたか?
開発チーム どうやって開発していたか? Staging 環境
開発チーム ステージング API ローカル ローカル ローカル
開発チーム ステージングで 動作試したい! ステージング API ローカル ローカル ローカル
開発チーム ステージングで 動作試したい! ステージング API ローカル ローカル ローカル
開発チーム ステージング API ローカル ローカル ローカル
開発チーム ステージングで 動作試したい! ステージング API ローカル ローカル ローカル ステージングで 動作試したい!
開発チーム ステージングで 動作試したい! ステージング API ローカル ローカル ローカル ステージングで 動作試したい!
開発チーム ステージングで 動作試したい! ステージング API ローカル ローカル ローカル ステージングで 動作試したい!
開発チーム ステージングで 動作試したい! ステージング API ローカル ローカル ローカル ステージングで 動作試したい!
優しい世界
開発チーム 数人ならこれでもよかった
開発チーム 人数が増えてくると
開発チーム ステージング API ローカル ローカル ローカル ローカル ローカル ローカル ローカル
ローカル ローカル ローカル
開発チーム ステージング API ローカル ローカル ローカル ローカル ローカル ローカル ローカル
ローカル ローカル ローカル ステージングで 動作試したい! ステージングで 動作試したい! ステージングで 動作試したい! ステージングで 動作試したい!
開発チーム ステージング API ローカル ローカル ローカル ローカル ローカル ローカル ローカル
ローカル ローカル ローカル ステージングで 動作試したい! ステージングで 動作試したい! ステージングで 動作試したい! ステージングで 動作試したい! ステージング 戦国時代
開発チーム そこで作成された
開発チーム そこで作成された Staging2
開発チーム ステージング API ローカル ローカル ローカル ローカル ローカル ローカル ローカル
ローカル ローカル ローカル ステージングで 動作試したい! ステージングで 動作試したい! ステージングで 動作試したい! ステージングで 動作試したい! ステージング API
開発チーム ステージング API ローカル ローカル ローカル ローカル ローカル ローカル ローカル
ローカル ローカル ローカル ステージングで 動作試したい! ステージングで 動作試したい! ステージングで 動作試したい! ステージングで 動作試したい! ステージング API なんとかなった
開発チーム ぼくがバンクに入った頃 (5月)
開発チーム ステージング API ローカル ローカル ローカル ローカル ローカル ローカル ローカル
ローカル ローカル ローカル ステージングで 動作試したい! ステージングで 動作試したい! ステージングで 動作試したい! ステージングで 動作試したい! ステージング API ローカル ローカル ローカル ローカル ローカル ローカル ローカル ステージングで 動作試したい! ステージングで 動作試したい! ステージングで 動作試したい!
開発チーム ステージング API ローカル ローカル ローカル ローカル ローカル ローカル ローカル
ローカル ローカル ローカル ステージングで 動作試したい! ステージングで 動作試したい! ステージングで 動作試したい! ステージングで 動作試したい! ステージング API ローカル ローカル ローカル ローカル ローカル ローカル ローカル ステージングで 動作試したい! ステージングで 動作試したい! ステージングで 動作試したい! どうにもならない
開発チーム ステージング API ローカル 一人ひとりの専用APIを
開発チーム ステージング API ローカル 無限に スケールできるように ステージング API ローカル ステージング
API ローカル ステージング API ローカル ステージング API ローカル ステージング API ローカル ステージング API ローカル ステージング API ローカル ステージング API ローカル ステージング API ローカル
開発チーム ステージング API ローカル 無限ステージング ステージング API ローカル ステージング API
ローカル ステージング API ローカル ステージング API ローカル ステージング API ローカル ステージング API ローカル ステージング API ローカル ステージング API ローカル ステージング API ローカル
開発チーム 昼会で熱望されていた ローカル ほしい
開発チーム 入社2週目ぼく 「つくれそう」
開発チーム 入社2週目ぼく 「つくれそう」 つくった
開発チーム 機能提供を とにかく急いだ
開発チーム 1. CI が通ったら自動デプロイ 2. プルリク番号の名前がつく 3. pr-100-api.domain.com でアクセス
開発チーム 良くない構成も 混じった
開発チーム 1. ひとつのDBインスタンスを共有 2. スクリプトは .circleci/config.yaml
開発チーム 良くない構成も 混じったけど 動く
開発チーム ステージング API ローカル ねんがんの むげんすてーじんぐを てにいれた! ステージング API ローカル
ステージング API ローカル ステージング API ローカル ステージング API ローカル ステージング API ローカル ステージング API ローカル ステージング API ローカル ステージング API ローカル ステージング API ローカル
開発チーム リリースから 1ヶ月後
開発チーム みんなの開発は どうなったか?
開発チーム ステージング API ローカル ローカル ローカル ローカル ローカル ローカル ローカル
ローカル ローカル ローカル ステージングで 動作試したい! ステージングで 動作試したい! ステージングで 動作試したい! ステージングで 動作試したい! ステージング API ローカル ローカル ローカル ローカル ローカル ローカル ローカル ステージングで 動作試したい! ステージングで 動作試したい! ステージングで 動作試したい! むげん
開発チーム ステージング API ローカル ローカル ローカル ローカル ローカル ローカル ローカル
ローカル ローカル ローカル ステージングで 動作試したい! ステージングで 動作試したい! ステージングで 動作試したい! ステージングで 動作試したい! ステージング API ローカル ローカル ローカル ローカル ローカル ローカル ローカル ステージングで 動作試したい! ステージングで 動作試したい! ステージングで 動作試したい! 無限ステージング 使われない問題
開発チーム なんでみんな 使ってくれないの
開発チーム 使い勝手がよくなかった
開発チーム 今まで
開発チーム ステージングで 動作試したい! ステージング API ローカル ローカル ローカル
開発チーム ステージングで 動作試したい! ステージング API ローカル ローカル ローカル 1ステップ
開発チーム ステージングで 動作試したい! ステージング API ローカル ローカル ローカル 1分
開発チーム 無限ステージング
開発チーム ブランチをGitHubにプッシュして,プルリ クを発行して,CircleCI が通りきるまで 待って,CircleCIがきちんと通ったか確認 して,プルリク番号を確かめて,APIが使 えるようになるまで待って,アプリのエン ドポイントを書き換えて,アプリをビルドし て,動作確認する
開発チーム ブランチをGitHubにプッシュして,プルリ クを発行して,CircleCI が通りきるまで 待って,CircleCIがきちんと通ったか確認 して,プルリク番号を確かめて,APIが使 えるようになるまで待って,アプリのエン ドポイントを書き換えて,アプリをビルドし て,動作確認する 手順が多い
開発チーム ブランチをGitHubにプッシュして,プルリ クを発行して,CircleCI が通りきるまで 待って,CircleCIがきちんと通ったか確認 して,プルリク番号を確かめて,APIが使 えるようになるまで待って,アプリのエン ドポイントを書き換えて,アプリをビルドし て,動作確認する
開発チーム ブランチをGitHubにプッシュして,プルリ クを発行して,CircleCI が通りきるまで 待って,CircleCIがきちんと通ったか確認 して,プルリク番号を確かめて,APIが使 えるようになるまで待って,アプリのエン ドポイントを書き換えて,アプリをビルドし て,動作確認する CI
完了を待たないといけない
開発チーム ブランチをGitHubにプッシュして,プルリ クを発行して,CircleCI が通りきるまで 待って,CircleCIがきちんと通ったか確認 して,プルリク番号を確かめて,APIが使 えるようになるまで待って,アプリのエン ドポイントを書き換えて,アプリをビルドし て,動作確認する 自分の使いたいタイミングで
使えない
開発チーム ブランチをGitHubにプッシュして,プルリ クを発行して,CircleCI が通りきるまで 待って,CircleCIがきちんと通ったか確認 して,プルリク番号を確かめて,APIが使 えるようになるまで待って,アプリのエン ドポイントを書き換えて,アプリをビルドし て,動作確認する
開発チーム ブランチをGitHubにプッシュして,プルリ クを発行して,CircleCI が通りきるまで 待って,CircleCIがきちんと通ったか確認 して,プルリク番号を確かめて,APIが使 えるようになるまで待って,アプリのエン ドポイントを書き換えて,アプリをビルドし て,動作確認する 5分
開発チーム ブランチをGitHubにプッシュして,プルリ クを発行して,CircleCI が通りきるまで 待って,CircleCIがきちんと通ったか確認 して,プルリク番号を確かめて,APIが使 えるようになるまで待って,アプリのエン ドポイントを書き換えて,アプリをビルドし て,動作確認する 5分
開発チーム ブランチをGitHubにプッシュして,プルリ クを発行して,CircleCI が通りきるまで 待って,CircleCIがきちんと通ったか確認 して,プルリク番号を確かめて,APIが使 えるようになるまで待って,アプリのエン ドポイントを書き換えて,アプリをビルドし て,動作確認する 10分
開発チーム ブランチをGitHubにプッシュして,プルリ クを発行して,CircleCI が通りきるまで 待って,CircleCIがきちんと通ったか確認 して,プルリク番号を確かめて,APIが使 えるようになるまで待って,アプリのエン ドポイントを書き換えて,アプリをビルドし て,動作確認する 合計20分
開発チーム ブランチをGitHubにプッシュして,プルリ クを発行して,CircleCI が通りきるまで 待って,CircleCIがきちんと通ったか確認 して,プルリク番号を確かめて,APIが使 えるようになるまで待って,アプリのエン ドポイントを書き換えて,アプリをビルドし て,動作確認する APIが使えるようになるまで
めちゃめちゃ時間がかかる
開発チーム うちのチームは スピード命
開発チーム コレじゃ使われない...
開発チーム 直そう
開発チーム ステージング API ローカル 無限ステージング改 ステージング API ローカル ステージング API
ローカル ステージング API ローカル ステージング API ローカル ステージング API ローカル ステージング API ローカル ステージング API ローカル ステージング API ローカル ステージング API ローカル
開発チーム ブランチをGitHubにプッシュして,プルリ クを発行して,CircleCI が通りきるまで 待って,CircleCIがきちんと通ったか確認 して,プルリク番号を確かめて,APIが使 えるようになるまで待って,アプリのエン ドポイントを書き換えて,アプリをビルドし て,動作確認する 5分
開発チーム CI 完了を待たないといけない問題
開発チーム 既存のデプロイフローに 載せた
開発チーム ステージングデプロイ プロダクションデプロイ
開発チーム 無限ステージング
開発チーム https://watashino-api.domain.com 任意の名前で作成可能にした
開発チーム ブランチをGitHubにプッシュして,プルリ クを発行して,CircleCI が通りきるまで 待って,CircleCIがきちんと通ったか確認 して,プルリク番号を確かめて,APIが使 えるようになるまで待って,アプリのエン ドポイントを書き換えて,アプリをビルドし て,動作確認する 5分
開発チーム アプリをビルドしないと いけない問題
開発チーム URL を配信するエンドポイントを 作って
開発チーム ベータ版に参照機能を 作ってもらった
開発チーム ベータ版に参照機能を 作ってもらった アプリビルドが不要に!
開発チーム ブランチをGitHubにプッシュして,プルリ クを発行して,CircleCI が通りきるまで 待って,CircleCIがきちんと通ったか確認 して,プルリク番号を確かめて,APIが使 えるようになるまで待って,アプリのエン ドポイントを書き換えて,アプリをビルドし て,動作確認する 10分
開発チーム そもそも UP が 遅すぎる問題
インフラ構成で頑張って 10分から10秒にした 開発チーム
開発チーム 詳しくは Google Cloud Next ‘18 in Tokyo の 発表を見てください
(スライド32Pあたり) https://speakerdeck.com/bankinc220/cash-wozhi-eru-google-kubernetes-engine https://www.youtube.com/watch?v=b2tq_f3ZWdE
開発チーム ブランチをGitHubにプッシュして,プルリ クを発行して,CircleCI が通りきるまで 待って,CircleCIがきちんと通ったか確認 して,プルリク番号を確かめて,APIが使 えるようになるまで待って,アプリのエン ドポイントを書き換えて,アプリをビルドし て,動作確認する
開発チーム ブランチをGitHubにプッシュして,プルリ クを発行して,CircleCI が通りきるまで 待って,CircleCIがきちんと通ったか確認 して,プルリク番号を確かめて,APIが使 えるようになるまで待って,アプリのエン ドポイントを書き換えて,アプリをビルドし て,動作確認する デメリットすべて解決
♀
開発チーム だんだんと みんな使ってくれるようになった
開発チーム この作業で学んだこと
開発チーム 開発作業が 遅くなるのは悪
開発チーム 最初のままだったら きっと誰も使ってくれなかった
開発チーム この作業で学んだこと
開発チーム ユーザーに選択肢を残す
開発チーム ユーザーに選択肢を残す
開発チーム ユーザーに選択肢を残す 実は昔のステージングは まだまだ現役
開発チーム ホントは捨てたい
開発チーム でも,使っているユーザーがいる
開発チーム 共有ステージングの方が 開発速度が速い人がいる
開発チーム 多様性
開発チーム ステージング API ローカル 全力で シェアは奪いに行く ステージング API ローカル ステージング
API ローカル ステージング API ローカル ステージング API ローカル ステージング API ローカル ステージング API ローカル ステージング API ローカル ステージング API ローカル ステージング API ローカル
開発チーム この作業で学んだこと
開発チーム 他人のワークフローを 無理やり変えない
開発チーム だって嫌だもん
開発チーム 無限ステージング利用を 強制することもできた
開発チーム 使われない理由が わかっているか?
開発チーム 使われるようになる努力を 怠ってるんじゃないか?
開発チーム 常に自分に 問いかけよう
開発チーム まとめ
開発チーム インフラは あくまで裏方
開発チーム 開発者の気持ちになって サポートに徹する!
開発チーム (個人的意見です)
おしまい