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