$30 off During Our Annual Pro Sale. View Details »
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
안드로이드 9년차 개발자, 프론트엔드 주니어로 커리어 리셋하기
maryang
1
120
ZOZOにおけるAI活用の現在 ~モバイルアプリ開発でのAI活用状況と事例~
zozotech
PRO
9
5.7k
俺流レスポンシブコーディング 2025
tak_dcxi
14
8.9k
AIコーディングエージェント(Manus)
kondai24
0
190
堅牢なフロントエンドテスト基盤を構築するために行った取り組み
shogo4131
8
2.4k
リリース時」テストから「デイリー実行」へ!開発マネージャが取り組んだ、レガシー自動テストのモダン化戦略
goataka
0
130
ローターアクトEクラブ アメリカンナイト:川端 柚菜 氏(Japan O.K. ローターアクトEクラブ 会長):2720 Japan O.K. ロータリーEクラブ2025年12月1日卓話
2720japanoke
0
730
認証・認可の基本を学ぼう後編
kouyuume
0
240
Integrating WordPress and Symfony
alexandresalome
0
160
DevFest Android in Korea 2025 - 개발자 커뮤니티를 통해 얻는 가치
wisemuji
0
150
re:Invent 2025 のイケてるサービスを紹介する
maroon1st
0
120
chocoZAPサービス予約システムをNuxtで内製化した話
rizap_tech
0
160
Featured
See All Featured
Designing Experiences People Love
moore
143
24k
Rebuilding a faster, lazier Slack
samanthasiow
85
9.3k
Connecting the Dots Between Site Speed, User Experience & Your Business [WebExpo 2025]
tammyeverts
10
730
Save Time (by Creating Custom Rails Generators)
garrettdimon
PRO
32
1.8k
10 Git Anti Patterns You Should be Aware of
lemiorhan
PRO
659
61k
Fight the Zombie Pattern Library - RWD Summit 2016
marcelosomers
234
17k
[RailsConf 2023] Rails as a piece of cake
palkan
58
6.2k
Practical Tips for Bootstrapping Information Extraction Pipelines
honnibal
25
1.6k
Helping Users Find Their Own Way: Creating Modern Search Experiences
danielanewman
31
3k
Sharpening the Axe: The Primacy of Toolmaking
bcantrill
46
2.6k
Embracing the Ebb and Flow
colly
88
4.9k
How To Stay Up To Date on Web Technology
chriscoyier
791
250k
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との違い
注:今日はめちゃくちゃトリッキーな 発表しましたが、 普段は実直にやっています
おわり