Upgrade to PRO for Only $50/Year—Limited-Time Offer! 🔥
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
Realtime Config with Firestore@Firebase Meetup #8
Search
pochi-sato
December 10, 2018
Programming
3
610
Realtime Config with Firestore@Firebase Meetup #8
pochi-sato
December 10, 2018
Tweet
Share
More Decks by pochi-sato
See All by pochi-sato
JP_Stripes Deep Dive vol. 6 [Stripe Payment Links]
pochisato
0
89
副業しやすい会社/しにくい会社
pochisato
2
640
LINEでプロダクト検討時に知っててほしい5つの武器
pochisato
0
730
ズボラ旅開発のLINE APIとの歩み
pochisato
0
790
Firebase Authenticationでカスタム認証システムをつかう勘所@Firebase Meetup #13
pochisato
6
2.6k
Firestore導入前に検討したかったベスト5@Firebase Meetup #10
pochisato
9
2.3k
Other Decks in Programming
See All in Programming
S3 VectorsとStrands Agentsを利用したAgentic RAGシステムの構築
tosuri13
6
290
20 years of Symfony, what's next?
fabpot
2
330
tparseでgo testの出力を見やすくする
utgwkk
1
160
全員アーキテクトで挑む、 巨大で高密度なドメインの紐解き方
agatan
8
19k
tsgolintはいかにしてtypescript-goの非公開APIを呼び出しているのか
syumai
5
1.9k
Microservices Platforms: When Team Topologies Meets Microservices Patterns
cer
PRO
1
970
Rediscover the Console - SymfonyCon Amsterdam 2025
chalasr
2
150
CloudNative Days Winter 2025: 一週間で作る低レイヤコンテナランタイム
ternbusty
7
2k
リリース時」テストから「デイリー実行」へ!開発マネージャが取り組んだ、レガシー自動テストのモダン化戦略
goataka
0
110
チームをチームにするEM
hitode909
0
260
TUIライブラリつくってみた / i-just-make-TUI-library
kazto
1
330
ZOZOにおけるAI活用の現在 ~モバイルアプリ開発でのAI活用状況と事例~
zozotech
PRO
8
5.2k
Featured
See All Featured
The Myth of the Modular Monolith - Day 2 Keynote - Rails World 2024
eileencodes
26
3.2k
Code Reviewing Like a Champion
maltzj
527
40k
The Hidden Cost of Media on the Web [PixelPalooza 2025]
tammyeverts
1
88
Art, The Web, and Tiny UX
lynnandtonic
303
21k
Context Engineering - Making Every Token Count
addyosmani
9
480
個人開発の失敗を避けるイケてる考え方 / tips for indie hackers
panda_program
120
20k
Let's Do A Bunch of Simple Stuff to Make Websites Faster
chriscoyier
508
140k
Templates, Plugins, & Blocks: Oh My! Creating the theme that thinks of everything
marktimemedia
31
2.6k
Thoughts on Productivity
jonyablonski
73
5k
JavaScript: Past, Present, and Future - NDC Porto 2020
reverentgeek
52
5.7k
Visualization
eitanlees
150
16k
CoffeeScript is Beautiful & I Never Want to Write Plain JavaScript Again
sstephenson
162
15k
Transcript
リアルタイムコンフィグを Firestoreで
自己紹介 • さとう たくと(ぽち) • 営業→エンジニア→人事→いま!! @pitown
自己紹介 • さいきんは、この記事にいました。。
None
None
None
自己紹介 今はHotspringでおしごとしてま す。 2人目のエンジニアとしてやって ます。 3人目ぜひ!! しごとは、「ズボラ旅」というもの をつくっています。
自己紹介 ーズボラ旅ー LINEで旅行の相談ができるサー ビスです。 おすすめの提案をもらって、 そのまま予約まで。 ズボラな人程キモチいいです よかったら使ってね!
自己紹介 そんなことより、みんなスマブラがアツいので、ただふつうにあそ びにきてください ぼくのガノンドロフが火を吹きます ここにがのんどろふの絵を描きたい なぁ
では本題
リアルタイムコンフィグを Firestoreで
まじめそうなタイトルですが、 かなり変態的なtipsになります
リアルタイムコンフィグを Firestoreで • リアルタイムに書き換わるコンフィグ • Firestoreの管理画面からも書き換えられちゃう、型のミスもな い • 1分でバリューがでる!!
こんなシーンありませんか • 定数なんだけれど、時期的要因やタイミングで変わってしまう データを扱う • →定数にしたらビルドしないといけないし、DBに入れるにし たらちょっと重い • 本当は管理画面に入れて、Bizに調整して欲しい •
でも管理画面にする余裕もない • →まずはDBオペで繋ぐか、、、の流れ
こんなシーンありませんか わりと、キャンペーンの文言やパラメータなどで よくあるきがします
これをFirestoreをつかって かんたんに解決します
しかも、1分でバリュー!!
1分でバリューをだしている ようす
1分でバリューをだしている ようす
裏では何をやっていたか
Firestore console(スマホ)
バリュー発揮していたときはこんなかん じでした
バリューはっき中!! _人人人人人人_ > バリュー <  ̄Y^Y^Y^Y^Y ̄ _人人人人人人_ > バリュー <  ̄Y^Y^Y^Y^Y ̄ _人人人人人人_ > バリュー <  ̄Y^Y^Y^Y^Y ̄
寝っ転がっててもバリュー
ではちゃんと説明していきます
背景 • 定数なんだけれど、時期的要因やタイミングで変わってしまう データを扱う • →定数にしたらビルドしないといけないし、DBに入れるにし たらちょっと重い • 本当は管理画面に入れて、Bizに調整して欲しい •
でも管理画面にする余裕もない • →まずはDBオペで繋ぐか、、、の流れ
背景 DBオペもしたくない!でもハードコー ディングしたらもっと辛い! 開発工数もない!! でもリアルタイムで書き換わって欲し い! できるだけ安全に更新したい!
しかたないので考えた
おもいついたもの • 案1: スプレッドシート x Google App Script • 案2:
ファイルにデータおいて数秒ごとにキャッシュ取得 • 案3: DBにデータおいて数秒ごとにキャッシュ取得 • 案4: Firestore + Cloud Function + PubSub • 案5: Firestoreだけ
案1: スプレッドシート x Google App Script カジュアルすぎてこわい。
案1: スプレッドシート x Google App Script まだまだカジュアルすぎるなぁ..
案2: ファイルから取得してキャッシュ わりと賢明。このリクエスト回数要らんけれども
案3: DBから取得してキャッシュ これもわりと賢明。アレっコンソールつかえるかも、、?
案4: Firestore + Cloud Function + PubSub まさに求めるものなんだけど、ちょっと設計がデカイ
None
案5: Firestoreだけ あれ??いける、、?いけるのでは、、、???
使用した環境 • Firestore • GAE x Node.js x Firebase Admin
Node.js SDK • →リアルタイムアップデートを取得
データを入れる 1個それ用のコレクションつくって、1つドキュメントをつくればok
実装する ドキュメントを直指定して、onSnapshot、おわり!
かんたんでしょ??
必要なところに全力投球できるように、 略せるものは略していけたらいいですね!
なお、いちおう注意事項 (変態的なので用法はきをつけよう)
気をつけること1 • このコンフィグで1コレクションに複数のドキュメントをつくった ら、BigQueryに一括エクスポートしたときに『スキーマがありま せん』と怒られました • スキーマ無視してたので正論すぎる • 1コレクション1ドキュメントだけだったら大丈夫そう(ためして ない)
• 一括エクスポートではなく、コレクションごとにエクスポートし たらできるけど、一括エクスポートできるようにしておいた方 がいいよ
気をつけること2 • リアルタイムアップデート、いつまでコネクション張りっぱなしで いけるかな?とやっていたけれども、24時間やってると、しくっ たりします。 • なので、本番で使うのであれば、cronなりなんなり、定期的に つなぎ直しにいくようにしたら良いです ←でunsubscribeした後、またonSnapshotでつなぎ直す
最後に、Remote Configとの違い
注:今日はめちゃくちゃトリッキーな 発表しましたが、 普段は実直にやっています
おわり