Link
Embed
Share
Beginning
This slide
Copy link URL
Copy link URL
Copy iframe embed code
Copy iframe embed code
Copy javascript embed code
Copy javascript embed code
Share
Tweet
Share
Tweet
Slide 1
Slide 1 text
copyright Fringe81 Co.,Ltd. 2017/11/28 author @chidakiyo GCPでNoAdmした話 酔いどれGCPUG
Slide 2
Slide 2 text
copyright Fringe81 Co.,Ltd. まずは自己紹介
Slide 3
Slide 3 text
copyright Fringe81 Co.,Ltd. 自己紹介 ● @chidakiyo ● Fringe81という会社で働いています。 ● 普段はR&Dをしていたり、新規事業のプロト作ったり している人です。 ● 筋トレ好きです。 ● Appengine 昔から触ってました。 よいどれ
Slide 4
Slide 4 text
copyright Fringe81 Co.,Ltd. NoAdmとは? ● 管理系の画面を「開発せずに作る」 ● アプリケーションの運用に必要なダッシュボードなど の機能をアプリケーション側で作り込まず、かつ、フ ルマネージドに実現したいという思いつきからの造語 です。
Slide 5
Slide 5 text
copyright Fringe81 Co.,Ltd. 今日話すこと/話さないこと ● NoAdmを実現した流れを話します ● あまり細かい技術の話はしません
Slide 6
Slide 6 text
copyright Fringe81 Co.,Ltd. [前提情報] Uniposというサービスをやってま す
Slide 7
Slide 7 text
copyright Fringe81 Co.,Ltd. [前提情報] Uniposの構成
Slide 8
Slide 8 text
copyright Fringe81 Co.,Ltd. 運用にあたってこんなオーダーが... 1. Datastore内のデータで顧客へのレポートを作りたい 2. カスタマーサクセスチームの非エンジニアでも手軽に 利用状況などを分析したい
Slide 9
Slide 9 text
copyright Fringe81 Co.,Ltd. ちなみに、Datastoreって、 ● エンティティのJoinができない ● 集約関数がない(sum, count, etc.) ● 全文検索できない 「うーん、 SQLで書きたい・・・」 みたいな気持ちに
Slide 10
Slide 10 text
copyright Fringe81 Co.,Ltd. 考えたこと ● DatastoreのデータをBigQueryに同期す ることで、SQLをつかって色々見れそう!
Slide 11
Slide 11 text
copyright Fringe81 Co.,Ltd. ではやってみることにした
Slide 12
Slide 12 text
copyright Fringe81 Co.,Ltd. DatastoreをBigQueryに同期するステップ 1. DatastoreをGCSへバックアップする 2. バックアップファイルをBQに投入する
Slide 13
Slide 13 text
copyright Fringe81 Co.,Ltd. 1) DatastoreをGCSへバックアップする ● 自作の chidakiyo/datastore-backup を利用して各 kindをGCS上にバックアップ Qiitaも書いてます : https://qiita.com/chidakiyo/items/bb2e49c6f99b7210fa0f
Slide 14
Slide 14 text
copyright Fringe81 Co.,Ltd. 2) バックアップファイルをBQに投入する ● favclip/ds2bqを利用 ● GCSに書き込まれたバックアップのOCN (Object Change Notification)をトリガにds2bqで バックアップファイルをBQに投入
Slide 15
Slide 15 text
copyright Fringe81 Co.,Ltd. これで SQLを利用し、データへ柔軟にアクセス できるようになった!
Slide 16
Slide 16 text
copyright Fringe81 Co.,Ltd. SQLを実行できることで実現できたコト ● 日毎の企業別の投稿数の推移 ● 日毎の貰ったポイント、送ったポイント ● アカウントごとの投稿数/送った貰ったポイント ● などなど、、、 SQLで好きなように分析できる! かなりいい感じ!
Slide 17
Slide 17 text
copyright Fringe81 Co.,Ltd. 悲しいお知らせ
Slide 18
Slide 18 text
copyright Fringe81 Co.,Ltd. 昨日判明した衝撃の事実・・・ ● 今日紹介したDatastoreのバックアップ手法は古代の 手法となりつつあるようで、トレンディーなエンジニア のみなさまにおかれましては、gcloud beta datastore exportのご利用を検討してみてください! (涙 ● 昨日、GCPUGのSlackで気づきました・・・ 参考 : https://cloud.google.com/datastore/docs/export-import-entities
Slide 19
Slide 19 text
copyright Fringe81 Co.,Ltd. ここからNoAdm的な話
Slide 20
Slide 20 text
copyright Fringe81 Co.,Ltd. SRE本でいう Toil を撲滅する ● 顧客向けのレポート作成のためにExcelポチポチ ● 利用状況の分析のための情報をDatastoreからの データ取得ポチポチ Toilとは「苦労」や「長く続く骨折り仕事」のような意味があり、 SRE本では、手作業である、繰り返される、自動化可能である、戦術的である、長期的な 価値を持たない、サービスの成長に対し O(n)である、の1つ以上に当てはまれば Toilであ る可能性が高いと書かれています。
Slide 21
Slide 21 text
copyright Fringe81 Co.,Ltd. SRE本でいう Toil を撲滅する ● 顧客向けのレポート作成のためにExcelポチポチ ● 利用状況の分析のための情報をDatastoreからの データ取得ポチポチ こんな苦労は撲滅!!
Slide 22
Slide 22 text
copyright Fringe81 Co.,Ltd. NoAdmとして実現したこと(1) ● 顧客向けのレポートはDatastudioで
Slide 23
Slide 23 text
copyright Fringe81 Co.,Ltd. NoAdmとして実現したこと(1) ● 構成
Slide 24
Slide 24 text
copyright Fringe81 Co.,Ltd. NoAdmとして実現したこと(1) ● Datastudioを新規作成する
Slide 25
Slide 25 text
copyright Fringe81 Co.,Ltd. NoAdmとして実現したこと(1) ● BigQueryのテーブルを選択して接続を作成する
Slide 26
Slide 26 text
copyright Fringe81 Co.,Ltd. NoAdmとして実現したこと(1) ● グラフを配置するとすぐに見える!
Slide 27
Slide 27 text
copyright Fringe81 Co.,Ltd. やばい、簡単!!
Slide 28
Slide 28 text
copyright Fringe81 Co.,Ltd. Datastudio、何と接続できる? ● BQだけではなく、色々なデータに簡単に接続できる (CloudSQL, AdWords, MySQL, PostgreSQL, GoogleSpreadSheet, etc..) ● コミュニティコネクタと言うものがありさらにいろいろな データソースに接続できます
Slide 29
Slide 29 text
copyright Fringe81 Co.,Ltd. Datastudioを利用して嬉しいこと ● 顧客ごとに見たい指標をカスタマイズしたレポートの 提供が容易にできる ● サーバコスト不要 ● SQL書けなくてもグラフが作れる ● G Suiteの権限で共有ができるので管理しやすい
Slide 30
Slide 30 text
copyright Fringe81 Co.,Ltd. Datastudioでハマった/困ったこと ● データソースの編集権限がシェアできないので、複数 人での編集が出来ない。
Slide 31
Slide 31 text
copyright Fringe81 Co.,Ltd. NoAdmとして実現したこと(2) ● アプリケーションの毎日確認したい情報のグラフを Slackに通知。
Slide 32
Slide 32 text
copyright Fringe81 Co.,Ltd. NoAdmとして実現したこと(2) ● 構成
Slide 33
Slide 33 text
copyright Fringe81 Co.,Ltd. NoAdmとして実現したこと(2) 細かい内容は今年の Advent Calendarで。
Slide 34
Slide 34 text
copyright Fringe81 Co.,Ltd. Slackへのグラフ通知で嬉しいこと ● グラフが毎朝決まった形でSlackに投稿され、Slack 上ですぐに議論が始められる ● コミュニケーションツール上にレポートされるので、 チーム内の意識のすり合わせの時間が減らせる
Slide 35
Slide 35 text
copyright Fringe81 Co.,Ltd. GASのSlack通知でハマったこと/困ったこと ● GASのリソース使いすぎるとCPU時間が長すぎます メールがGoogleから来て、止められることがある。 ● GASの処理は6分以内に終わらせる必要がある。
Slide 36
Slide 36 text
copyright Fringe81 Co.,Ltd. 実現するためにその他にやったこと。 ● 非エンジニアがSQLを実行するのが容易な環境をつ くり、非エンジニアもSQLを書けるように。(社内で非 エンジニア向けSQL教室を毎日行った)
Slide 37
Slide 37 text
copyright Fringe81 Co.,Ltd. 実現して個人的に嬉しいこと ● 「こんな情報が欲しいのでデータベースから情報取得 してもらえますか?」とお願いされることがないので、 早く家に帰って筋トレができるw
Slide 38
Slide 38 text
copyright Fringe81 Co.,Ltd. BQ連携構成で良かった点 ● Datastoreのバックアップを起点にNoAdm側は構成 されているため、疎結合でアプリケーション側に影響 を与えない ● アプリケーション側への影響が少ないため、運用の便 利ツールを比較的容易に作りやすい ● 初期の開発の工数を減らすことができた
Slide 39
Slide 39 text
copyright Fringe81 Co.,Ltd. さいごに ● GCPはいろいろ便利に使えるツールがたくさんある ので便利に使ってラクしましょう!
Slide 40
Slide 40 text
copyright Fringe81 Co.,Ltd. 一緒にGCPの話でわいわいできる 仲間を募集しています!
Slide 41
Slide 41 text
copyright Fringe81 Co.,Ltd. 一緒にGCPの話でわいわいできる 仲間を募集しています! 筋トレ好きな人 も!
Slide 42
Slide 42 text
copyright Fringe81 Co.,Ltd. ご清聴ありがとうございました。
Slide 43
Slide 43 text
copyright Fringe81 Co.,Ltd. 参考: [まだBIツールで消耗してるの? ~ サーバレス・KPI分析ダッシュボードをGAS + Slackで] http://blog.yamotty.com/entry/20161114/1479079800 [BigQueryを簡単にグラフにするGoogle Apps Script] http://toreta.blog.jp/archives/20649904.html