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
Realtime Config with Firestore@Firebase Meetup #8
Search
pochi-sato
December 10, 2018
Programming
660
3
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
Realtime Config with Firestore@Firebase Meetup #8
pochi-sato
December 10, 2018
More Decks by pochi-sato
See All by pochi-sato
JP_Stripes Deep Dive vol. 6 [Stripe Payment Links]
pochisato
0
100
副業しやすい会社/しにくい会社
pochisato
2
670
LINEでプロダクト検討時に知っててほしい5つの武器
pochisato
0
760
ズボラ旅開発のLINE APIとの歩み
pochisato
0
810
Firebase Authenticationでカスタム認証システムをつかう勘所@Firebase Meetup #13
pochisato
6
2.6k
Firestore導入前に検討したかったベスト5@Firebase Meetup #10
pochisato
9
2.4k
Other Decks in Programming
See All in Programming
軽量Java基盤の設計 DIコンテナに頼らない、長期保守と1秒起動の実現 JJUG CCC 2026 Spring
macha64
0
570
AIだと陥りがちなJakarta EE最新技術への移行時の落とし穴と解決策
tnagao7
0
120
Contextとはなにか
chiroruxx
1
370
過去最大のMCPアップデート! 2026-07-28 RC版の謎に迫る
licux
6
390
The ROI of Quarkus for Spring Boot Applications
hollycummins
0
130
Spring Security 実践 ─ GraphQL APIで実務に役立つ 認証・認可 を学ぶ
wagyu
0
260
Lessons from Spec-Driven Development
simas
PRO
0
220
「AIで開発し、AIを届ける」をEvalでつなぐ 〜AIネイティブに始めるプロダクト開発の実践〜 / Connecting "Develop with AI, deliver AI" with Eval
rkaga
4
5.4k
生成AI時代にこそ効くGo | Why Go Works in the Age of Generative AI
mom0tomo
8
3.3k
Claspは野良GASの夢をみるか
takter00
0
210
キャリア迷子上等 ─ "ない道"は自分で作ればいい
16bitidol
3
2.2k
Honoでのサプライチェーン侵害対策 〜 3つのライブラリに学ぶ
yusukebe
7
1.4k
Featured
See All Featured
Responsive Adventures: Dirty Tricks From The Dark Corners of Front-End
smashingmag
254
22k
The Language of Interfaces
destraynor
162
27k
Improving Core Web Vitals using Speculation Rules API
sergeychernyshev
21
1.5k
JAMstack: Web Apps at Ludicrous Speed - All Things Open 2022
reverentgeek
1
480
How to Ace a Technical Interview
jacobian
281
24k
The Art of Delivering Value - GDevCon NA Keynote
reverentgeek
16
2k
Organizational Design Perspectives: An Ontology of Organizational Design Elements
kimpetersen
PRO
1
750
Bash Introduction
62gerente
615
220k
実際に使うSQLの書き方 徹底解説 / pgcon21j-tutorial
soudai
PRO
201
75k
JavaScript: Past, Present, and Future - NDC Porto 2020
reverentgeek
52
6k
sira's awesome portfolio website redesign presentation
elsirapls
0
280
What the history of the web can teach us about the future of AI
inesmontani
PRO
1
620
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との違い
注:今日はめちゃくちゃトリッキーな 発表しましたが、 普段は実直にやっています
おわり