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
stand.fmにGraphQLを導入して、半年。〜導入経緯や技術選択、現状や将来について〜
Search
Sponsored
·
Ship Features Fearlessly
Turn features on and off without deploys. Used by thousands of Ruby developers.
→
Spice-Z
March 03, 2022
Programming
2.4k
3
Share
stand.fmにGraphQLを導入して、半年。〜導入経緯や技術選択、現状や将来について〜
こちらの発表で使用した資料です
https://standfm.connpass.com/event/239750/
Spice-Z
March 03, 2022
More Decks by Spice-Z
See All by Spice-Z
Native Module入門記録
spicez
3
970
NuxtでSSR時にGoogleOptimize(ABテストツール)を使いたい
spicez
1
1.1k
"transform" Why do we have to use it in CSS animation
spicez
0
5.2k
Other Decks in Programming
See All in Programming
セキュリティの専門家じゃなくてもできる。「セキュリティ意識」をアップデートして サプライチェーン攻撃への耐性を高めよう。
tk3fftk
5
620
軽量Java基盤の設計 DIコンテナに頼らない、長期保守と1秒起動の実現 JJUG CCC 2026 Spring
macha64
0
450
Stage 3 Decorators でできること / できないこと / TSKaigi 2026
susisu
1
1.5k
[2026年度第1回ORセミナー] 計画最適化ベンチャーと競技プログラミング人材
terryu16
0
240
AI駆動開発勉強会 広島支部 第一回勉強会 AI駆動開発概要とワークショップ
hayatoshimiu
0
440
不変条件と整合性境界—ビジネスが決める設計判断と実現パターン / Invariants and Consistency Boundaries
nrslib
13
3.4k
Javaの型とAI時代に型が大事な理由 / java types and type in AI era
kishida
2
100
AIチームを指揮するOSS「TAKT」活用術 / How to Use “TAKT,” an OSS Tool for Orchestrating AI Teams
nrslib
6
820
LLM本来の能力を解き放つサンドボックス技術とAI民主化への適用
yukukotani
3
2.7k
Language Server 使ってる? 〜VSCode と Zed の場合〜 / Are you using a Language Server? ~For VS Code and Zed~
handlename
0
360
net-httpのHTTP/2対応について
naruse
0
440
並列実装の現場、2ヶ月間実務でAIを使い倒したAIもPCも私も限界が近い
ming_ayami
0
110
Featured
See All Featured
Groundhog Day: Seeking Process in Gaming for Health
codingconduct
0
200
Self-Hosted WebAssembly Runtime for Runtime-Neutral Checkpoint/Restore in Edge–Cloud Continuum
chikuwait
0
560
From Legacy to Launchpad: Building Startup-Ready Communities
dugsong
0
220
Keith and Marios Guide to Fast Websites
keithpitt
413
23k
The Curse of the Amulet
leimatthew05
1
13k
Unsuck your backbone
ammeep
672
58k
Fantastic passwords and where to find them - at NoRuKo
philnash
52
3.7k
Breaking role norms: Why Content Design is so much more than writing copy - Taylor Woolridge
uxyall
0
310
Stop Working from a Prison Cell
hatefulcrawdad
274
21k
Getting science done with accelerated Python computing platforms
jacobtomlinson
2
220
Building an army of robots
kneath
306
46k
jQuery: Nuts, Bolts and Bling
dougneiner
66
8.5k
Transcript
に GraphQLを導入して、半年。 〜導入経緯や技術選択、現状や将来について〜 by spice(@rabspice) on 2022/03/03 @ TECH STAND
#7 GraphQL
自己紹介 @rabspice ・2021年6月stand.fm入社 ・React Native / React / express などで
アプリ/ Web / バックエンド を実装している ・マリオカート(switch)をほぼ毎日やってる (やってる人いたらフレンドになりましょう) spice (Yugo Ogura)
stand.fmでは 2021年10月頃から GraphQLを使い始めました。 今回は ・GraphQLの導入理由 ・技術選定話 ・実際に導入しての苦労話 についてお話しします! ※時間がないのであんまり深ぼれなさそう。 聞きたことがあったらQ&Aセクションで
目次 1. GraphQL導入の理由 2. ライブラリの技術選定理由 3. 「新機能はGraphQLでやってみよう!」の苦労 4. 現状とこれから 0.
stand.fmのアーキテクチャ
stand.fmの アーキテクチャ
stand.fmのアーキテクチャ App Web React Native React Redux app server web
server DB 音声系 処理 課金系 処理 その他色々な処理 ※ 全てJSなので、1人がフロント~バックエンド実装を担当することもしばしば
目次 1. GraphQL導入の理由 2. ライブラリの技術選定理由 3. 「新機能はGraphQLでやってみよう!」の苦労 4. 現状とこれから 0.
stand.fmのアーキテクチャ
GraphQL導入の理由
・既存のRedux Storeをアプリ上で効率的に使うことが難しかった ・APIコールのキャッシュとして使いたいけど、複雑すぎて開発コスト高い GraphQL導入の理由
・コンポーネントの依存するデータが追いにくく、バグが頻発していた ・undefined参照でアプリが落ちるとか ・既存のRedux Storeをアプリ上で効率的に使うことが難しかった ・APIコールのキャッシュとして使いたいけど、複雑すぎて開発コスト高い GraphQL導入の理由
・コンポーネントの依存するデータが追いにくく、バグが頻発していた ・undefined参照でアプリが落ちるとか ・既存のRedux Storeをアプリ上で効率的に使うことが難しかった ・APIコールのキャッシュとして使いたいけど、複雑すぎて開発コスト高い GraphQL導入の理由 ・クライアントからサーバーサイドにビジネスロジックを寄せたい ・本来ならAPIを変更すべきところを、アプリ側の変更で吸収しがち ・見通しが悪かったりテストが描きにくかったり
Q. GraphQLじゃなくてもよかったのでは? リファクタ がんばる SWR や React Query GraphQL (with
Relay) APIの キャッシュ コンポーネント の依存データ 整理 ビジネス ロジック をサーバーに
目次 1. GraphQL導入の理由 2. ライブラリの技術選定理由 3. 「新機能はGraphQLでやってみよう!」の苦労 4. 現状とこれから 0.
stand.fmのアーキテクチャ
ライブラリの 技術選定理由
採用したGraphQL関連ライブラリ Apollo Federation Rover CLI DataLoader graphql-codegen Relay
Apollo Gateway GraphQL関連部分のアーキテクチャ App Web app server web server Core
Server Relay Rover CLI graphql-codegen Dataloader schema/型生成
Q. なぜ Relay ? 「コンポーネントが必要なデータの定義を 同ファイルに書くことを強制しやすい」のが良い。 (Apollo Clientはデフォルトでやりにくい)
コンポーネントファイルの中に 必要なデータの定義を書く 実際にデータを使う時は Relayが用意するhooksで データを取り出す 子
子 親 親でもRelayのhooksを使って データを取り出す 子にはデータが含まれるオブ ジェクトを渡す 子コンポーネントで必要な Fragment(データの定義) を必ず展開
このあたりのRelayのコンセプトは、 公式ドキュメントの 「Principles And Architecture > Thinking in Relay」 に書いてあります。
https://relay.dev/docs/principles-and-architecture/thinking-in-relay/
Q. Relayのサーバー仕様を満たすの面倒では 言うほどでもなさそうです また、これによりクライアント側で便利なRelayの関数がたくさん使えるので メリットがかなり上回ってる感じがあります
Q. なぜ Apollo Server ・JSのGraphQLサーバーライブラリは他に目ぼしいものがなさそうだった ・RelayとApollo Serverの組み合わせは特に問題ないです ・既存のサーバーの構成に則りたい ・今後複数のGraphQLサーバー組み合わせたい Apollo
Server Apollo Federation
目次 1. GraphQL導入の理由 2. ライブラリの技術選定理由 3. 「新機能はGraphQLでやってみよう!」の苦労 4. 現状とこれから 0.
stand.fmのアーキテクチャ
新機能はGraphQL でやってみよう! の苦労
0から学んで実装はとにかく時間がかかった ・最初の数人がとにかく頑張って数個の機能を実装したけど大変 ・サーバー側/アプリ側の実装のパラダイムシフト ・何も考えないとRESTの設計に引きづられてGraphQLの理解が進まない
0から学んで実装はとにかく時間がかかった ・⇨ slackに#z-graphqlを作り、知見の集約 ・⇨ドキュメント読む会を開催して全体で理解しやすく ・https://graphql.org/learn/ ⇨ GraphQL自体 ・https://www.apollographql.com/docs/apollo-server/ ⇨ サーバー実装
・https://relay.dev/ ⇨ フロント実装 ・⇨ 初めて実装する人は、ペアプロで学習コストを下げたり
・組織内に知見が少なくて参考になるコードも少ない ➡ 工数増加で実装に遅れが💦 ・工数増加は一時的で、将来回収できるコストだとエンジニアは認識 ・代表「長期的にメリットあるなら大丈夫です。やりましょう。」 ・エンジニア「❤」 実装工数の一時的な増加
目次 1. GraphQL導入の理由 2. ライブラリの技術選定理由 3. 「新機能はGraphQLでやってみよう!」の苦労 4. 現状とこれから 0.
stand.fmのアーキテクチャ
現状とこれから
現状とこれから ・新機能は基本GraphQLで開発 ・既存機能は適宜GraphQLで置き換えている ・Relayを使いながらReduxからうまく脱却する ・エラーハンドリングや負荷対策 ・Relay関連の知見についてはたくさんブログを書きたいと思っています(!)
質問があれば Q&Aセクション or Meety で! Thank you !