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
Firebaseをフル活用したサーバーエンジニアレス新規事業プロトタイピング
Search
Sponsored
·
SiteGround - Reliable hosting with speed, security, and support you can count on.
→
hosomichi
March 28, 2018
Technology
1
2.6k
Firebaseをフル活用したサーバーエンジニアレス新規事業プロトタイピング
hosomichi
March 28, 2018
Tweet
Share
More Decks by hosomichi
See All by hosomichi
React_Nativeの_ルーティングばなし.pdf
hosomichi
0
2.4k
Elm is a good teacher
hosomichi
2
1.4k
改善React道
hosomichi
3
1.1k
ReactComponentのコンストラクタを追いかけて
hosomichi
8
3.8k
Other Decks in Technology
See All in Technology
学生・新卒・ジュニアから目指すSRE
hiroyaonoe
2
600
茨城の思い出を振り返る ~CDKのセキュリティを添えて~ / 20260201 Mitsutoshi Matsuo
shift_evolve
PRO
1
260
広告の効果検証を題材にした因果推論の精度検証について
zozotech
PRO
0
170
会社紹介資料 / Sansan Company Profile
sansan33
PRO
15
400k
顧客との商談議事録をみんなで読んで顧客解像度を上げよう
shibayu36
0
230
変化するコーディングエージェントとの現実的な付き合い方 〜Cursor安定択説と、ツールに依存しない「資産」〜
empitsu
4
1.4k
SREチームをどう作り、どう育てるか ― Findy横断SREのマネジメント
rvirus0817
0
230
~Everything as Codeを諦めない~ 後からCDK
mu7889yoon
3
340
30万人の同時アクセスに耐えたい!新サービスの盤石なリリースを支える負荷試験 / SRE Kaigi 2026
genda
4
1.3k
プロダクト成長を支える開発基盤とスケールに伴う課題
yuu26
4
1.3k
MCPでつなぐElasticsearchとLLM - 深夜の障害対応を楽にしたい / Bridging Elasticsearch and LLMs with MCP
sashimimochi
0
170
外部キー制約の知っておいて欲しいこと - RDBMSを正しく使うために必要なこと / FOREIGN KEY Night
soudai
PRO
12
5.4k
Featured
See All Featured
The Director’s Chair: Orchestrating AI for Truly Effective Learning
tmiket
1
96
Building a Scalable Design System with Sketch
lauravandoore
463
34k
The untapped power of vector embeddings
frankvandijk
1
1.6k
Tips & Tricks on How to Get Your First Job In Tech
honzajavorek
0
430
Music & Morning Musume
bryan
47
7.1k
The Limits of Empathy - UXLibs8
cassininazir
1
210
Raft: Consensus for Rubyists
vanstee
141
7.3k
RailsConf 2023
tenderlove
30
1.3k
Design of three-dimensional binary manipulators for pick-and-place task avoiding obstacles (IECON2024)
konakalab
0
350
Skip the Path - Find Your Career Trail
mkilby
0
55
Crafting Experiences
bethany
1
48
Ethics towards AI in product and experience design
skipperchong
2
190
Transcript
Firebaseをフル活用した サーバーエンジニアレス 新規事業プロトタイピング 2018/03/27 by @jshosomichi
自己紹介 せきようすけ a.k.a "ほそ道" Fringe81所属 フロントエンドエンジニア 得意技:JavaScript / Elm /
TypeScript / ReactNative
事業企画 実現性検証 事業化Go! いつもはローンチ向け開発をやることが多いのですが ・事業化Go!が出た後の開発 ・拡張性があり安定運用出来る堅牢な基盤 ローンチに 向けた開発
本日お話する新規事業開発は下記、検証段階であります ・事業化Go!が出る前の開発 ・アイデアが事業としてモノになるか検証するためのアプリ ・品質的には最小機能で提供価値の検証が出来ればOK 事業企画 実現性検証 プロトタイピング 事業化Go! ここを 進めたい!
ローンチに 向けた開発
予選を勝ち抜いてきた、事業化の可能性がある3企画。 これらを2ヶ月以内に事業化Go!の判断が出来るよう 検証可能(実際に動く)なプロトタイプを開発せよ。 事業企画 事業企画 事業企画 今回のミッション 実現性検証 プロトタイピング 事業化Go!
まだ利益を生み出せるかが不確実な段階のため、 いったん少ない人数で3つのアプリ開発 in 2ヶ月を行うことに 各プロダクトの 企画者 プログラマ (ワタクシひとり) デザイナ 検証チーム
各プロダクトの 企画者 プログラマ (ワタクシひとり) デザイナ 検証チーム えっ まだ利益を生み出せるかが不確実な段階のため、 いったん少ない人数で3つのアプリ開発 in
2ヶ月を行うことに
プログラマ (ワタクシひとり) さて、3つのプロトタイプ、どうやって作ろう?
プロトタイプの設計時間/デザイン時間も考慮すると 実際コードを書ける時間はより限られてくる。 開発スピードを担保する為の戦略を考ねばなりません。 プログラマ (ワタクシひとり) さて、3つのプロトタイプ、どうやって作ろう?
プログラマ (ワタクシひとり) さて、3つのプロトタイプ、どうやって作ろう? フロントエンド開発 は得意なので 速く作る算段は 立つなぁ プロトタイプの設計時間/デザイン時間も考慮すると 実際コードを書ける時間はより限られてくる。 開発スピードを担保する為の戦略を考ねばなりません。
プロトタイプの設計時間も考慮すると 実際コードを書ける時間はより限られてくる。 開発スピードを担保する為の戦略を考ねばなりません。 プログラマ (ワタクシひとり) さて、3つのプロトタイプ、どうやって作ろう? バックエンドは 学習コストを 下げたいなぁ フロントエンド開発
は得意なので 速く作る算段は 立つなぁ
サーバエンジニアレス開発 with Firebase 強みを活かせる技術選定で戦を略そう!
モバイルアプリが強調されていますが、今回はブラウザです。 FirebaseはブラウザのWebアプリ開発まわりでも JavaScript SDKという形で同様に機能提供してくれています。 ちなみに公式ページのトップでは
今回は下記5つのfirebaseサービスを利用しました 今日はひとつずつ使いっぷりを紹介してまいります
クライアント (ブラウザ) Webサーバ ・HTML ・CSS ・IMG Hosting
Hosting 指定したディレクトリ(省略時public/)配下のファイル群を コマンドひとつでWebサーバの配下に設置してくれます。 検証時にユーザがアクセス出来るURLも用意してくれます。
Hosting 過去にデプロイしたバージョンにもGUI操作で戻すことが出来ま す。
Hosting 自分で仕組みを作っていた ひと昔前の感覚に立ち返ると、 色々と戦を略すことができています。
クライアント (ブラウザ) Webサーバ ・HTML ・CSS ・IMG Authentication 認証 ・サインアップ ・サインイン
・サインアウト
Authentication 色々な認証方法と、アクセス元の制御機能などを提供してくれてい ます。Slack認証などもカスタムでできます。
Authentication エラーコードが内容を細かく判定してくれているので、 ユーザーのメールアドレスが既に登録されているかなども 下記のようにして確認可能でした。
Authentication いちどサインインすると、その状態をブラウザに保存してくれ、 明示的なサインアウトをするまでその状態は保持され続けます。 ※サインイン状態の確認は非同期で行われるので、 画面遷移のハンドリングは自前でちょっと工夫が必要でした。 auth.onAuthStateChangedを呼んでおくと後でuser/errorが入ってくる仕組み
今回用意した認証システムは3プロトタイプでほぼ変更なしで使い回すことができました Authentication
クライアント (ブラウザ) Webサーバ ・HTML ・CSS ・IMG Cloud Firestore 認証 ・サインアップ
・サインイン ・サインアウト DB ・インスタンス群の永続化
Cloud Firestore Databaseは2つの選択肢がありますが Uniposの開発時にRealtime Databaseを使った経験があったので 今回は新しく登場したFirestore(β版)を使ってみようと思いました。
Cloud Firestore にじみ出るパワーアップ感 プロトタイプ開発ならではの冒険しやすさ 公式ドキュメントの比較
Cloud Firestore コレクション-ドキュメント-フィールドの階層で値を保持する。 MongoDBのような構造。 ブラウザコンソール上でクエリを行う仕組みがいずれ出来ると嬉しいです。
Cloud Firestore batchというオブジェクトを引き回すことで、 アトミックトランザクションを行うことができます。 (commitするまではset/updateを繰り返しても保存されない。)
Cloud Firestore 新規にIDを払い出すこともできます。 非同期処理していないので、 完全な一意性を確認・担保しているわけではないと思いますが。 ID被りをフォローしておけば、とても便利に使えます。
Cloud Firestore バリデーションはクライアントサイドとセキュリティルールの合わせ技で行いました 例えば「Cityドキュメントのemailフィールドはユニークでなければならない」 というアプリケーション制約があれば、一度データを取得して有無を確認。 Firestore側にセキュリティルールを設定しておくと 違反時にはエラーを返して保存処理を防ぐことができます。
Cloud Firestore 永続化処理をクライアント側に担わせることで 更に色々な戦を略すことができました。
クライアント (ブラウザ) Webサーバ ・HTML ・CSS ・IMG Cloud Storage 認証 ・サインアップ
・サインイン ・サインアウト ファイルサーバ ・動的画像保存 DB ・インスタンス群の永続化
Cloud Storage システム内で登録される動的画像はCloud Storageに保存。 ディレクトリを切ることも出来ます。
Cloud Storage アップロードするファイル名はクライアント側で 設定する必要があります。 今回はFireStoreを使ってIDを払い出して、 そのIDを画像ファイル名とするなどしていました。
Cloud Storage ダウンロード時、ファイルの場所を示すURLしか持っていない場合は 非同期APIで変換したURLでアクセスする必要があります。 tokenパラメータが付与されたURLが返される
クライアント (ブラウザ) Webサーバ ・HTML ・CSS ・IMG Cloud Functions 認証 ・サインアップ
・サインイン ・サインアウト ファイルサーバ ・動的画像保存 DB ・インスタンス群の永続化 イベントフック処理 ・データ変更を監視して通知送信
Cloud Functions さまざまなトリガーに対して あらかじめデプロイしたJavaScriptコードを実行することが出来ます。 (直接HTTPリクエストを受けるトリガーも作れます)
Cloud Functions 今回のプロトタイプでは主に firestoreのデータ更新をトリガーとしてメールの通知を行っていました。
Cloud Functions 更新前後のデータにアクセスすることが出来るので 完了フラグの状態推移を見極めて、通知を送ることができ、便利です。
Cloud Functions 事前予想ではセットアップの手間がめんどくさいのでは。。などと思っていたので すが、 コマンド一発でデプロイしてすぐに使えるようになりました。簡単! local cloud functions JS
クライアント (ブラウザ) Webサーバ ・HTML ・CSS ・IMG この構成で3プロトタイプの全要件を満たすことができました! 認証 ・サインアップ ・サインイン
・サインアウト ファイルサーバ ・動的画像保存 DB ・インスタンス群の永続化 イベントフック処理 ・データ変更を監視して通知送信
これで、 JavaScript知識を中心とした Noサーバインスタンス Noサーバサイドエンジニア の世界が実現しました
ビュー ロジック IOロジック Firebase ラッパー Firebase サービス API コードの再利用についても戦を略しました① Firebaseアクセスの汎用パターンをラッパー化することで
プロトタイプAのコードをプロトタイプBで再利用 Firebase知識範囲
ビュー ロジック IOロジック Firebase ラッパー Firebase サービス API コードの再利用についても戦を略しました② 画面のロジックとFirebaseにアクセスする層を完全分離することで
ローンチ向け開発に移行した場合も、 ビューロジックはそのまま使うことができるようにしています。 外部アクセス知識範囲
略せる戦を略し倒し、 結果的にフロントエンジニアひとり体制で ・手を動かす時間は4週間 ・1プロジェクト目: 2週間 ・2プロジェクト目以降:1週間 3つのプロトタイプを構築しきることができました! かなり良いペース!(のはず)
Firebaseのおかげで これからのプロトタイプも 「任しとけ!」 と自信を持って言うことが出来そうです ありがとう、Firebase!