Suche senden
Hochladen
アプリを成長させるためのログ取りとログ解析に必要なこと
•
51 gefällt mir
•
28,535 views
Takao Sumitomo
Folgen
DroidKaigi2018の講演の「アプリを成長させるためのログ取りとログ解析に必要なこと」の発表資料です。
Weniger lesen
Mehr lesen
Technologie
Melden
Teilen
Melden
Teilen
1 von 120
Jetzt herunterladen
Downloaden Sie, um offline zu lesen
Empfohlen
世界一わかりやすいClean Architecture
世界一わかりやすいClean Architecture
Atsushi Nakamura
マイクロにしすぎた結果がこれだよ!
マイクロにしすぎた結果がこれだよ!
mosa siru
シリコンバレーの「何が」凄いのか
シリコンバレーの「何が」凄いのか
Atsushi Nakada
オブジェクト指向できていますか?
オブジェクト指向できていますか?
Moriharu Ohzu
フロー効率性とリソース効率性について #xpjug
フロー効率性とリソース効率性について #xpjug
Itsuki Kuroda
SPAセキュリティ入門~PHP Conference Japan 2021
SPAセキュリティ入門~PHP Conference Japan 2021
Hiroshi Tokumaru
テスト文字列に「うんこ」と入れるな
テスト文字列に「うんこ」と入れるな
Kentaro Matsui
EventStormingワークショップ 〜かつてない図書館をモデリングしてみよう〜
EventStormingワークショップ 〜かつてない図書館をモデリングしてみよう〜
TIS Inc.
Empfohlen
世界一わかりやすいClean Architecture
世界一わかりやすいClean Architecture
Atsushi Nakamura
マイクロにしすぎた結果がこれだよ!
マイクロにしすぎた結果がこれだよ!
mosa siru
シリコンバレーの「何が」凄いのか
シリコンバレーの「何が」凄いのか
Atsushi Nakada
オブジェクト指向できていますか?
オブジェクト指向できていますか?
Moriharu Ohzu
フロー効率性とリソース効率性について #xpjug
フロー効率性とリソース効率性について #xpjug
Itsuki Kuroda
SPAセキュリティ入門~PHP Conference Japan 2021
SPAセキュリティ入門~PHP Conference Japan 2021
Hiroshi Tokumaru
テスト文字列に「うんこ」と入れるな
テスト文字列に「うんこ」と入れるな
Kentaro Matsui
EventStormingワークショップ 〜かつてない図書館をモデリングしてみよう〜
EventStormingワークショップ 〜かつてない図書館をモデリングしてみよう〜
TIS Inc.
Pythonによる黒魔術入門
Pythonによる黒魔術入門
大樹 小倉
CEDEC 2018 最速のC#の書き方 - C#大統一理論へ向けて性能的課題を払拭する
CEDEC 2018 最速のC#の書き方 - C#大統一理論へ向けて性能的課題を払拭する
Yoshifumi Kawai
協調フィルタリング入門
協調フィルタリング入門
hoxo_m
オブジェクト指向エクササイズのススメ
オブジェクト指向エクササイズのススメ
Yoji Kanno
エンジニアの個人ブランディングと技術組織
エンジニアの個人ブランディングと技術組織
Takafumi ONAKA
例外設計における大罪
例外設計における大罪
Takuto Wada
WebRTCを利用した遠隔リアルタイム映像処理フレームワークの実装
WebRTCを利用した遠隔リアルタイム映像処理フレームワークの実装
tnoho
Marp Tutorial
Marp Tutorial
Rui Watanabe
Pythonはどうやってlen関数で長さを手にいれているの?
Pythonはどうやってlen関数で長さを手にいれているの?
Takayuki Shimizukawa
オブジェクト指向の設計と実装の学び方のコツ
オブジェクト指向の設計と実装の学び方のコツ
増田 亨
PlaySQLAlchemy: SQLAlchemy入門
PlaySQLAlchemy: SQLAlchemy入門
泰 増田
機械学習で泣かないためのコード設計
機械学習で泣かないためのコード設計
Takahiro Kubo
それはYAGNIか? それとも思考停止か?
それはYAGNIか? それとも思考停止か?
Yoshitaka Kawashima
分散学習のあれこれ~データパラレルからモデルパラレルまで~
分散学習のあれこれ~データパラレルからモデルパラレルまで~
Hideki Tsunashima
ChatGPT 人間のフィードバックから強化学習した対話AI
ChatGPT 人間のフィードバックから強化学習した対話AI
Shota Imai
Python 3.9からの新定番zoneinfoを使いこなそう
Python 3.9からの新定番zoneinfoを使いこなそう
Ryuji Tsutsui
脱RESTful API設計の提案
脱RESTful API設計の提案
樽八 仲川
「速」を落とさないコードレビュー
「速」を落とさないコードレビュー
Takafumi ONAKA
Akkaとは。アクターモデル とは。
Akkaとは。アクターモデル とは。
Kenjiro Kubota
イミュータブルデータモデルの極意
イミュータブルデータモデルの極意
Yoshitaka Kawashima
(beta)アプリを成長させるためのログ取りとログ解析に必要なこと
(beta)アプリを成長させるためのログ取りとログ解析に必要なこと
Takao Sumitomo
LoRaWANとAzure IoT Hub接続ハンズオン
LoRaWANとAzure IoT Hub接続ハンズオン
Tomokazu Kizawa
Weitere ähnliche Inhalte
Was ist angesagt?
Pythonによる黒魔術入門
Pythonによる黒魔術入門
大樹 小倉
CEDEC 2018 最速のC#の書き方 - C#大統一理論へ向けて性能的課題を払拭する
CEDEC 2018 最速のC#の書き方 - C#大統一理論へ向けて性能的課題を払拭する
Yoshifumi Kawai
協調フィルタリング入門
協調フィルタリング入門
hoxo_m
オブジェクト指向エクササイズのススメ
オブジェクト指向エクササイズのススメ
Yoji Kanno
エンジニアの個人ブランディングと技術組織
エンジニアの個人ブランディングと技術組織
Takafumi ONAKA
例外設計における大罪
例外設計における大罪
Takuto Wada
WebRTCを利用した遠隔リアルタイム映像処理フレームワークの実装
WebRTCを利用した遠隔リアルタイム映像処理フレームワークの実装
tnoho
Marp Tutorial
Marp Tutorial
Rui Watanabe
Pythonはどうやってlen関数で長さを手にいれているの?
Pythonはどうやってlen関数で長さを手にいれているの?
Takayuki Shimizukawa
オブジェクト指向の設計と実装の学び方のコツ
オブジェクト指向の設計と実装の学び方のコツ
増田 亨
PlaySQLAlchemy: SQLAlchemy入門
PlaySQLAlchemy: SQLAlchemy入門
泰 増田
機械学習で泣かないためのコード設計
機械学習で泣かないためのコード設計
Takahiro Kubo
それはYAGNIか? それとも思考停止か?
それはYAGNIか? それとも思考停止か?
Yoshitaka Kawashima
分散学習のあれこれ~データパラレルからモデルパラレルまで~
分散学習のあれこれ~データパラレルからモデルパラレルまで~
Hideki Tsunashima
ChatGPT 人間のフィードバックから強化学習した対話AI
ChatGPT 人間のフィードバックから強化学習した対話AI
Shota Imai
Python 3.9からの新定番zoneinfoを使いこなそう
Python 3.9からの新定番zoneinfoを使いこなそう
Ryuji Tsutsui
脱RESTful API設計の提案
脱RESTful API設計の提案
樽八 仲川
「速」を落とさないコードレビュー
「速」を落とさないコードレビュー
Takafumi ONAKA
Akkaとは。アクターモデル とは。
Akkaとは。アクターモデル とは。
Kenjiro Kubota
イミュータブルデータモデルの極意
イミュータブルデータモデルの極意
Yoshitaka Kawashima
Was ist angesagt?
(20)
Pythonによる黒魔術入門
Pythonによる黒魔術入門
CEDEC 2018 最速のC#の書き方 - C#大統一理論へ向けて性能的課題を払拭する
CEDEC 2018 最速のC#の書き方 - C#大統一理論へ向けて性能的課題を払拭する
協調フィルタリング入門
協調フィルタリング入門
オブジェクト指向エクササイズのススメ
オブジェクト指向エクササイズのススメ
エンジニアの個人ブランディングと技術組織
エンジニアの個人ブランディングと技術組織
例外設計における大罪
例外設計における大罪
WebRTCを利用した遠隔リアルタイム映像処理フレームワークの実装
WebRTCを利用した遠隔リアルタイム映像処理フレームワークの実装
Marp Tutorial
Marp Tutorial
Pythonはどうやってlen関数で長さを手にいれているの?
Pythonはどうやってlen関数で長さを手にいれているの?
オブジェクト指向の設計と実装の学び方のコツ
オブジェクト指向の設計と実装の学び方のコツ
PlaySQLAlchemy: SQLAlchemy入門
PlaySQLAlchemy: SQLAlchemy入門
機械学習で泣かないためのコード設計
機械学習で泣かないためのコード設計
それはYAGNIか? それとも思考停止か?
それはYAGNIか? それとも思考停止か?
分散学習のあれこれ~データパラレルからモデルパラレルまで~
分散学習のあれこれ~データパラレルからモデルパラレルまで~
ChatGPT 人間のフィードバックから強化学習した対話AI
ChatGPT 人間のフィードバックから強化学習した対話AI
Python 3.9からの新定番zoneinfoを使いこなそう
Python 3.9からの新定番zoneinfoを使いこなそう
脱RESTful API設計の提案
脱RESTful API設計の提案
「速」を落とさないコードレビュー
「速」を落とさないコードレビュー
Akkaとは。アクターモデル とは。
Akkaとは。アクターモデル とは。
イミュータブルデータモデルの極意
イミュータブルデータモデルの極意
Ähnlich wie アプリを成長させるためのログ取りとログ解析に必要なこと
(beta)アプリを成長させるためのログ取りとログ解析に必要なこと
(beta)アプリを成長させるためのログ取りとログ解析に必要なこと
Takao Sumitomo
LoRaWANとAzure IoT Hub接続ハンズオン
LoRaWANとAzure IoT Hub接続ハンズオン
Tomokazu Kizawa
Redash pythonで業務分析
Redash pythonで業務分析
創史 花村
JAWS-UG IoT専門支部 講演資料 IoT Analyticsによる構築事例説明
JAWS-UG IoT専門支部 講演資料 IoT Analyticsによる構築事例説明
Akira Tateishi
詳説 Data api mtddc 拡張版 v3対応
詳説 Data api mtddc 拡張版 v3対応
Yuji Takayama
日本発オープンソース!! スケールアウト型データベース GridDB入門 ~ GitHubからダウンロードして使ってみましょう ~
日本発オープンソース!! スケールアウト型データベース GridDB入門 ~ GitHubからダウンロードして使ってみましょう ~
griddb
FirebaseAnalytics_BigQuery_Datastudio
FirebaseAnalytics_BigQuery_Datastudio
さとる なかむら
Data apiで実現 進化するwebの世界
Data apiで実現 進化するwebの世界
Yuji Takayama
『機械学習 (AI/ML) の基礎と Microsoft の AI | 2019/04/02 Global AI Nights Fukui
『機械学習 (AI/ML) の基礎と Microsoft の AI | 2019/04/02 Global AI Nights Fukui
Fujio Kojima
再考: お買い得物件を機械学習で見つける方法
再考: お買い得物件を機械学習で見つける方法
智志 片桐
Redmineosaka 20 talk_crosspoints
Redmineosaka 20 talk_crosspoints
Shinji Tamura
マイクロソフトの AI プラットフォーム & Cognitive Services 概要 ~ Ignite 2020 Recap
マイクロソフトの AI プラットフォーム & Cognitive Services 概要 ~ Ignite 2020 Recap
Ayako Omori
初めての Data api cms どうでしょう - 大阪夏の陣
初めての Data api cms どうでしょう - 大阪夏の陣
Yuji Takayama
DeNA のデータ活用を支える BigQuery データの民主化とガバナンス強化の軌跡 | Google Cloud INSIDE Games & App...
DeNA のデータ活用を支える BigQuery データの民主化とガバナンス強化の軌跡 | Google Cloud INSIDE Games & App...
Google Cloud Platform - Japan
HTML5でFirefox OSアプリを作ろう
HTML5でFirefox OSアプリを作ろう
Takao Sumitomo
ITを使った今時の聖地巡礼ユーザー分析 in 沼津
ITを使った今時の聖地巡礼ユーザー分析 in 沼津
Junichi Noda
クラウドではじめるリアルタイムデータ分析 #seccamp
クラウドではじめるリアルタイムデータ分析 #seccamp
Masahiro NAKAYAMA
AWS Security JAWS 経済的にハニーポットのログ分析をするためのベストプラクティス?
AWS Security JAWS 経済的にハニーポットのログ分析をするためのベストプラクティス?
Masamitsu Maehara
Preview: 世界中のゲーム分析をしてきたPlayFabが大進化!一緒に裏側の最新データ探索の仕組みを覗いてみよう
Preview: 世界中のゲーム分析をしてきたPlayFabが大進化!一緒に裏側の最新データ探索の仕組みを覗いてみよう
Daisuke Masubuchi
DataEngConf NYC’18 セッションサマリー #1
DataEngConf NYC’18 セッションサマリー #1
gree_tech
Ähnlich wie アプリを成長させるためのログ取りとログ解析に必要なこと
(20)
(beta)アプリを成長させるためのログ取りとログ解析に必要なこと
(beta)アプリを成長させるためのログ取りとログ解析に必要なこと
LoRaWANとAzure IoT Hub接続ハンズオン
LoRaWANとAzure IoT Hub接続ハンズオン
Redash pythonで業務分析
Redash pythonで業務分析
JAWS-UG IoT専門支部 講演資料 IoT Analyticsによる構築事例説明
JAWS-UG IoT専門支部 講演資料 IoT Analyticsによる構築事例説明
詳説 Data api mtddc 拡張版 v3対応
詳説 Data api mtddc 拡張版 v3対応
日本発オープンソース!! スケールアウト型データベース GridDB入門 ~ GitHubからダウンロードして使ってみましょう ~
日本発オープンソース!! スケールアウト型データベース GridDB入門 ~ GitHubからダウンロードして使ってみましょう ~
FirebaseAnalytics_BigQuery_Datastudio
FirebaseAnalytics_BigQuery_Datastudio
Data apiで実現 進化するwebの世界
Data apiで実現 進化するwebの世界
『機械学習 (AI/ML) の基礎と Microsoft の AI | 2019/04/02 Global AI Nights Fukui
『機械学習 (AI/ML) の基礎と Microsoft の AI | 2019/04/02 Global AI Nights Fukui
再考: お買い得物件を機械学習で見つける方法
再考: お買い得物件を機械学習で見つける方法
Redmineosaka 20 talk_crosspoints
Redmineosaka 20 talk_crosspoints
マイクロソフトの AI プラットフォーム & Cognitive Services 概要 ~ Ignite 2020 Recap
マイクロソフトの AI プラットフォーム & Cognitive Services 概要 ~ Ignite 2020 Recap
初めての Data api cms どうでしょう - 大阪夏の陣
初めての Data api cms どうでしょう - 大阪夏の陣
DeNA のデータ活用を支える BigQuery データの民主化とガバナンス強化の軌跡 | Google Cloud INSIDE Games & App...
DeNA のデータ活用を支える BigQuery データの民主化とガバナンス強化の軌跡 | Google Cloud INSIDE Games & App...
HTML5でFirefox OSアプリを作ろう
HTML5でFirefox OSアプリを作ろう
ITを使った今時の聖地巡礼ユーザー分析 in 沼津
ITを使った今時の聖地巡礼ユーザー分析 in 沼津
クラウドではじめるリアルタイムデータ分析 #seccamp
クラウドではじめるリアルタイムデータ分析 #seccamp
AWS Security JAWS 経済的にハニーポットのログ分析をするためのベストプラクティス?
AWS Security JAWS 経済的にハニーポットのログ分析をするためのベストプラクティス?
Preview: 世界中のゲーム分析をしてきたPlayFabが大進化!一緒に裏側の最新データ探索の仕組みを覗いてみよう
Preview: 世界中のゲーム分析をしてきたPlayFabが大進化!一緒に裏側の最新データ探索の仕組みを覗いてみよう
DataEngConf NYC’18 セッションサマリー #1
DataEngConf NYC’18 セッションサマリー #1
Mehr von Takao Sumitomo
僕は上スワイプでBottomSheetを出したかっただけなんだ
僕は上スワイプでBottomSheetを出したかっただけなんだ
Takao Sumitomo
sharedUserIdを使った俺得開発ツールの作り方
sharedUserIdを使った俺得開発ツールの作り方
Takao Sumitomo
CIのビルドを通知する仕組みをAndroidとFirestoreで作った話
CIのビルドを通知する仕組みをAndroidとFirestoreで作った話
Takao Sumitomo
Camera API 1と2が混在するプロダクトの開発で 泣いたこととそのワークアラウンド
Camera API 1と2が混在するプロダクトの開発で 泣いたこととそのワークアラウンド
Takao Sumitomo
高速でトライ&エラーを するために気をつけてること
高速でトライ&エラーを するために気をつけてること
Takao Sumitomo
Maker Faire Bay Areaに行きたかったのでGoogle I/Oに行ってきた
Maker Faire Bay Areaに行きたかったのでGoogle I/Oに行ってきた
Takao Sumitomo
Viewを動的に変化させるアプローチ
Viewを動的に変化させるアプローチ
Takao Sumitomo
プロダクトを育てるのにGoogleのサービスが助けてくれること
プロダクトを育てるのにGoogleのサービスが助けてくれること
Takao Sumitomo
AdapterToolboxでRecyclerViewを楽にする
AdapterToolboxでRecyclerViewを楽にする
Takao Sumitomo
エンジニアがプロダクト育成を始めるまでにやったこと
エンジニアがプロダクト育成を始めるまでにやったこと
Takao Sumitomo
Wantedlyのテスト事情
Wantedlyのテスト事情
Takao Sumitomo
用途に合わせたアニメーションの実装方法
用途に合わせたアニメーションの実装方法
Takao Sumitomo
Uml速習会
Uml速習会
Takao Sumitomo
potatotips (iOS/Android開発Tips共有会) 第19回 資料
potatotips (iOS/Android開発Tips共有会) 第19回 資料
Takao Sumitomo
SQLiteDatabaseを無理矢理覗く
SQLiteDatabaseを無理矢理覗く
Takao Sumitomo
開発を効率的に進めるられるまでの道程
開発を効率的に進めるられるまでの道程
Takao Sumitomo
テストがあればなんとかなる〜効率化までの道程〜
テストがあればなんとかなる〜効率化までの道程〜
Takao Sumitomo
勉強会資料 データ構造とアルゴリズム
勉強会資料 データ構造とアルゴリズム
Takao Sumitomo
勉強会資料 Uml概要
勉強会資料 Uml概要
Takao Sumitomo
Firefox OSの何が嬉しいか
Firefox OSの何が嬉しいか
Takao Sumitomo
Mehr von Takao Sumitomo
(20)
僕は上スワイプでBottomSheetを出したかっただけなんだ
僕は上スワイプでBottomSheetを出したかっただけなんだ
sharedUserIdを使った俺得開発ツールの作り方
sharedUserIdを使った俺得開発ツールの作り方
CIのビルドを通知する仕組みをAndroidとFirestoreで作った話
CIのビルドを通知する仕組みをAndroidとFirestoreで作った話
Camera API 1と2が混在するプロダクトの開発で 泣いたこととそのワークアラウンド
Camera API 1と2が混在するプロダクトの開発で 泣いたこととそのワークアラウンド
高速でトライ&エラーを するために気をつけてること
高速でトライ&エラーを するために気をつけてること
Maker Faire Bay Areaに行きたかったのでGoogle I/Oに行ってきた
Maker Faire Bay Areaに行きたかったのでGoogle I/Oに行ってきた
Viewを動的に変化させるアプローチ
Viewを動的に変化させるアプローチ
プロダクトを育てるのにGoogleのサービスが助けてくれること
プロダクトを育てるのにGoogleのサービスが助けてくれること
AdapterToolboxでRecyclerViewを楽にする
AdapterToolboxでRecyclerViewを楽にする
エンジニアがプロダクト育成を始めるまでにやったこと
エンジニアがプロダクト育成を始めるまでにやったこと
Wantedlyのテスト事情
Wantedlyのテスト事情
用途に合わせたアニメーションの実装方法
用途に合わせたアニメーションの実装方法
Uml速習会
Uml速習会
potatotips (iOS/Android開発Tips共有会) 第19回 資料
potatotips (iOS/Android開発Tips共有会) 第19回 資料
SQLiteDatabaseを無理矢理覗く
SQLiteDatabaseを無理矢理覗く
開発を効率的に進めるられるまでの道程
開発を効率的に進めるられるまでの道程
テストがあればなんとかなる〜効率化までの道程〜
テストがあればなんとかなる〜効率化までの道程〜
勉強会資料 データ構造とアルゴリズム
勉強会資料 データ構造とアルゴリズム
勉強会資料 Uml概要
勉強会資料 Uml概要
Firefox OSの何が嬉しいか
Firefox OSの何が嬉しいか
Kürzlich hochgeladen
LoRaWAN スマート距離検出デバイスDS20L日本語マニュアル
LoRaWAN スマート距離検出デバイスDS20L日本語マニュアル
CRI Japan, Inc.
論文紹介: The Surprising Effectiveness of PPO in Cooperative Multi-Agent Games
論文紹介: The Surprising Effectiveness of PPO in Cooperative Multi-Agent Games
atsushi061452
新人研修 後半 2024/04/26の勉強会で発表されたものです。
新人研修 後半 2024/04/26の勉強会で発表されたものです。
iPride Co., Ltd.
Utilizing Ballerina for Cloud Native Integrations
Utilizing Ballerina for Cloud Native Integrations
WSO2
論文紹介:Video-GroundingDINO: Towards Open-Vocabulary Spatio-Temporal Video Groun...
論文紹介:Video-GroundingDINO: Towards Open-Vocabulary Spatio-Temporal Video Groun...
Toru Tamaki
NewSQLの可用性構成パターン(OCHaCafe Season 8 #4 発表資料)
NewSQLの可用性構成パターン(OCHaCafe Season 8 #4 発表資料)
NTT DATA Technology & Innovation
論文紹介:Selective Structured State-Spaces for Long-Form Video Understanding
論文紹介:Selective Structured State-Spaces for Long-Form Video Understanding
Toru Tamaki
LoRaWANスマート距離検出センサー DS20L カタログ LiDARデバイス
LoRaWANスマート距離検出センサー DS20L カタログ LiDARデバイス
CRI Japan, Inc.
Observabilityは従来型の監視と何が違うのか(キンドリルジャパン社内勉強会:2022年10月27日発表)
Observabilityは従来型の監視と何が違うのか(キンドリルジャパン社内勉強会:2022年10月27日発表)
Hiroshi Tomioka
Amazon SES を勉強してみる その22024/04/26の勉強会で発表されたものです。
Amazon SES を勉強してみる その22024/04/26の勉強会で発表されたものです。
iPride Co., Ltd.
Amazon SES を勉強してみる その32024/04/26の勉強会で発表されたものです。
Amazon SES を勉強してみる その32024/04/26の勉強会で発表されたものです。
iPride Co., Ltd.
知識ゼロの営業マンでもできた!超速で初心者を脱する、悪魔的学習ステップ3選.pptx
知識ゼロの営業マンでもできた!超速で初心者を脱する、悪魔的学習ステップ3選.pptx
sn679259
Kürzlich hochgeladen
(12)
LoRaWAN スマート距離検出デバイスDS20L日本語マニュアル
LoRaWAN スマート距離検出デバイスDS20L日本語マニュアル
論文紹介: The Surprising Effectiveness of PPO in Cooperative Multi-Agent Games
論文紹介: The Surprising Effectiveness of PPO in Cooperative Multi-Agent Games
新人研修 後半 2024/04/26の勉強会で発表されたものです。
新人研修 後半 2024/04/26の勉強会で発表されたものです。
Utilizing Ballerina for Cloud Native Integrations
Utilizing Ballerina for Cloud Native Integrations
論文紹介:Video-GroundingDINO: Towards Open-Vocabulary Spatio-Temporal Video Groun...
論文紹介:Video-GroundingDINO: Towards Open-Vocabulary Spatio-Temporal Video Groun...
NewSQLの可用性構成パターン(OCHaCafe Season 8 #4 発表資料)
NewSQLの可用性構成パターン(OCHaCafe Season 8 #4 発表資料)
論文紹介:Selective Structured State-Spaces for Long-Form Video Understanding
論文紹介:Selective Structured State-Spaces for Long-Form Video Understanding
LoRaWANスマート距離検出センサー DS20L カタログ LiDARデバイス
LoRaWANスマート距離検出センサー DS20L カタログ LiDARデバイス
Observabilityは従来型の監視と何が違うのか(キンドリルジャパン社内勉強会:2022年10月27日発表)
Observabilityは従来型の監視と何が違うのか(キンドリルジャパン社内勉強会:2022年10月27日発表)
Amazon SES を勉強してみる その22024/04/26の勉強会で発表されたものです。
Amazon SES を勉強してみる その22024/04/26の勉強会で発表されたものです。
Amazon SES を勉強してみる その32024/04/26の勉強会で発表されたものです。
Amazon SES を勉強してみる その32024/04/26の勉強会で発表されたものです。
知識ゼロの営業マンでもできた!超速で初心者を脱する、悪魔的学習ステップ3選.pptx
知識ゼロの営業マンでもできた!超速で初心者を脱する、悪魔的学習ステップ3選.pptx
アプリを成長させるためのログ取りとログ解析に必要なこと
1.
DroidKaigi 2018 @cattaka_net アプリを成長させるための ログ取りとログ解析に必要なこと Takao
Sumitomo
2.
DroidKaigi 2018 @cattaka_net2 自己紹介
3.
DroidKaigi 2018 @cattaka_net3 自己紹介 ● 住友
孝郎(Takao Sumitomo) ● たぶんAndroidアプリ開発者 ● 職歴的なもの – SIer的なこと – メーカー的なこと ● – 2014年12月〜 所属
4.
DroidKaigi 2018 @cattaka_net4 Wantedlyプロフィール
5.
DroidKaigi 2018 @cattaka_net5 触ったことあるもの プログラム Java,
C++, Ruby, PHP, Python データベース Oracle, Sqlite3, PostgreSQL, MySQL, Realm プラットフォーム等 Android, Linux(Debian), MFC, Struts 設計 UML, Excel方眼紙
6.
DroidKaigi 2018 @cattaka_net6 Javaが好き
7.
DroidKaigi 2018 @cattaka_net7 今日のお話に至った経緯
8.
DroidKaigi 2018 @cattaka_net8 Wantedlyにジョインする前 ● いっぱいいろんなものを作った ● 作るだけならどうにかできる
9.
DroidKaigi 2018 @cattaka_net9 不思議なことをいう人達がいた ● 良いものを作れば自然とユーザーは増える ● 面白いものを作ればバイラルで広がる 本当にそうなのか?
10.
DroidKaigi 2018 @cattaka_net10 そんな中でWantedlyにジョインした
11.
DroidKaigi 2018 @cattaka_net11 ジョイン直後 アプリを良くしていきましょう! (どうやったらいいんだろう...)
12.
DroidKaigi 2018 @cattaka_net12 最初にやったこと ● Google
Analyticsを見た – 当時はまだFirebase Analyticsはなかった ● TreasureData(ログ収集サービス)を見た ほとんどWebのログ 体系化されてなくて読み取れない わかるのはせいぜいインストール数とアクティブユーザー数
13.
DroidKaigi 2018 @cattaka_net13 そもそも何をもって良くなったいう? ● 指標は? ● その指標の数字を出すためには? うん、さっぱりわからん
14.
DroidKaigi 2018 @cattaka_net14 Wantedly
Visitの例を考える
15.
DroidKaigi 2018 @cattaka_net15 最も簡単な指標 ● マッチングアプリ –
応募ボタンを押す
16.
DroidKaigi 2018 @cattaka_net16 1
2 3 4 5 0.00% 10.00% 20.00% 30.00% 40.00% 50.00% 60.00% 70.00% 80.00% 90.00% 100.00% 応募にたどり着くまでのファネル それまでの過程は? ● 1: インストール ● 2: ユーザー登録 ● 3: 探す操作をする ● 4: 詳細画面を開く ● 5: 応募を押す こんな感じ??
17.
DroidKaigi 2018 @cattaka_net17 その過程を追うには? ● インストール –
ユーザーIDごとの最初のイベントを探す ● ユーザー登録 – Web側かアプリ側のログ ● 探す操作をする – アプリ側のログ
18.
DroidKaigi 2018 @cattaka_net18 その過程を追うには? ● 詳細画面を開く –
アプリ側のログ – キャッシュされるとWeb側のログじゃわからない ● 応募を押す – Web側のログ ログがWeb側とアプリ側に散らばってる、、、
19.
DroidKaigi 2018 @cattaka_net19 あ、、、これ闇雲にやっても無理だ、、、
20.
DroidKaigi 2018 @cattaka_net20 そのためにやったことのお話です
21.
DroidKaigi 2018 @cattaka_net21 どんな指標があるのか?
22.
DroidKaigi 2018 @cattaka_net22 エンジニアリング的な指標 ● クラッシュ率 ● ANR発生率 ● レンダリング時間 ● APIのレスポンス時間 Android
Vitals で確認できる
23.
DroidKaigi 2018 @cattaka_net23 非エンジニアリング的な指標 Google
Play Console, Firebase Analytics で確認できる
24.
DroidKaigi 2018 @cattaka_net24 インストール数 ● 単純にインストール数
25.
DroidKaigi 2018 @cattaka_net25 アクティブユーザー数 ● DAU
: Daily Active User – 1日のユニークユーザー数 ● WAU : Weekly Active User – 7日間のユニークユーザー数 ● MAU : Monthly Active User – 1ヶ月のユニークユーザー数 – 流派によって28日だったり31日だったりする 単純に掛け算ではないので注意
26.
DroidKaigi 2018 @cattaka_net26 リテンション率 ● 継続率とも呼ばれる ● コホート分析とも呼ばれる –
(厳密には違うけど) ● 期間ごとにユーザーを分けて見る
27.
DroidKaigi 2018 @cattaka_net27 リテンション率 Firebase
Analyics – demo projectより
28.
DroidKaigi 2018 @cattaka_net28 リテンション率 ● 多機能なアプリの場合 –
機能ごとのリテンション率が無いと どの機能がユーザーを繋ぎ止めてるか追えない
29.
DroidKaigi 2018 @cattaka_net29 コンバージョン率 ● ユーザーの中でコンバージョンした率 ● コンバージョン –
そのプロダクトの成果 – たとえば ● ECサービスなら何かが売れた ● マッチングサービスならマッチングが成立した プロダクトによって異なる
30.
DroidKaigi 2018 @cattaka_net30 必要なインフラ
31.
DroidKaigi 2018 @cattaka_net31 簡単な構成 ● ログ収集サービス ● データストア ● 抽出環境 ● 可視化
32.
DroidKaigi 2018 @cattaka_net32 具体的なサービスやプロダクト ログ収集系 データストア 抽出環境 可視化 Firebase Analytics ※1 Google BigQuery Google
Data Studio(β) ExcelR Domo Fluentd 普通の RDBMS Treasure Data Hadoop ※1:Firebase Analyticsは一部可視化機能がある
33.
DroidKaigi 2018 @cattaka_net33 ログ収集系 Treasure Data Google BigQuery 最近のWantedlyの構成の紹介 データストア 抽出環境 可視化 Firebase Analytics Excel Domo 普通の RDBMS アプリ
34.
DroidKaigi 2018 @cattaka_net34 ここまでで、お気づきの方も いらっしゃるかも知れませんが...
35.
DroidKaigi 2018 @cattaka_net35 アプリの実装の話が1つも出てません
36.
DroidKaigi 2018 @cattaka_net36 最近のWantedlyの構成の紹介 ログ収集系 Treasure Data Google BigQuery データストア 抽出環境 可視化 Firebase Analytics Excel Domo 普通の RDBMS アプリ この2つを考えるのに、 中間層の理解が必要だった
37.
DroidKaigi 2018 @cattaka_net37 初めてやるなら ● Firebase
Analytics ● Google BigQuery ● Excel の組み合わせから始めると無難
38.
DroidKaigi 2018 @cattaka_net38 アプリで取るログの種類
39.
DroidKaigi 2018 @cattaka_net39 アプリで取るログの種類 ● イベントログ –
Viewの操作 ● タップやスワイプ – 直接的なコンバージョン ● スクリーンログ – 画面名 – 遷移先の画面名 – 滞在時間
40.
DroidKaigi 2018 @cattaka_net40 イベントログ
41.
DroidKaigi 2018 @cattaka_net41 イベントログの項目 ● ユーザー識別子 ● 画面名 –
アプリによってはActivity + Fragment ● イベント名 – タップ / ロングタップ / スワイプなど ● イベントの追加属性 – View ID / アイテムのIDなど – 内部実装はJSONが良いかも(?)
42.
DroidKaigi 2018 @cattaka_net42 イベントログの例 ユーザー 識別子 画面名 イベント名 イベントの 追加属性画面の 追加属性 time
user_id screen screen_params event event_params 1234 ListActivity click {"view_id": "title", "item_id": 432} 1234 DetailActivity {"item_id": 432} press_back 1234 ListActivity click {"view_id": "title", "item_id": 234} 1234 DetailActivity {"item_id": 234} click {"view_id": "apply"} 1234 DetailActivity {"item_id": 234} cvt_apply {"item_id": 234} 2018/02/09 12:30 2018/02/09 12:31 2018/02/09 12:32 2018/02/09 12:33 2018/02/09 12:33
43.
DroidKaigi 2018 @cattaka_net43 イベントログのアプローチ ● 自動的にできれば理想だけど、、、 –
touchイベントをフックすればできなくはない – 付加情報を追加せざるを得ないケースが多い – 過度に冗長になることがある – デザイン的な事情の独自実装に対応できない 要所要所に丹精込めて埋める
44.
DroidKaigi 2018 @cattaka_net44 Viewの操作
vs コンバージョン ● どっちが解析しやすいか? – Viewの操作として記録 – コンバージョンとして記録 ● ツールに寄る – FAはコンバージョンが扱いやすい time user_id screen screen_params event event_params 1234 DetailActivity {"item_id": 234} click {"view_id": "apply"} 1234 DetailActivity {"item_id": 234} cvt_apply {"item_id": 234} 2018/02/09 12:33 2018/02/09 12:33 ※:2つはユーザーの操作としては同じ 重要な指標だから両方取る
45.
DroidKaigi 2018 @cattaka_net45 ライブラリごとの実装の違い
46.
DroidKaigi 2018 @cattaka_net46 イベントログの実装:Treasure
Data Map<String, Object> event = new HashMap<>(); event.put("user_id", userId); event.put("activity", activityName); event.put("fragment", fragmentName); event.put("event", "select_cotent"); event.put("item_id", itemId); event.put("name", name); TreasureData.sharedInstance() .addEvent("event_log", event); ユーザー識別子 画面 イベント名 追加属性 全部自分でやる!
47.
DroidKaigi 2018 @cattaka_net47 イベントログの実装:Firebase
Analytics Bundle bundle = new Bundle(); bundle.putLong (FirebaseAnalytics.Param.ITEM_ID, itemId); bundle.putString (FirebaseAnalytics.Param.ITEM_NAME, name); bundle.putString (FirebaseAnalytics.Param.CONTENT_TYPE, "image"); mFirebaseAnalytics.logEvent( FirebaseAnalytics.Event.SELECT_CONTENT, bundle); ↓追加属性 ↑イベント名 画面やユーザー識別子はやってくれる
48.
DroidKaigi 2018 @cattaka_net48 イベントログの実装:Google
Analytics mTracker.send(new HitBuilders.EventBuilder() .setCategory(category.category) .setAction("select_content") .setNonInteraction(false) .build()); ↑イベント名 画面やユーザー識別子はやってくれる
49.
DroidKaigi 2018 @cattaka_net49 ライブラリごとの実装の違い ● TD,
FA, GAでそれぞれ微妙に違う ● 特に画面とイベントの紐付けが異なる
50.
DroidKaigi 2018 @cattaka_net50 スクリーンログ
51.
DroidKaigi 2018 @cattaka_net51 スクリーンログの項目 ● 画面遷移が追えるくらい取る ● アプリからの離脱もわかるようにする リスト画面 商品画面 item_id=3 関連商品 item_id=3 商品画面 item_id=7 アプリを起動 アプリから離脱
52.
DroidKaigi 2018 @cattaka_net52 スクリーンログの項目 ● ユーザー識別子 ● 画面名 –
アプリによっては Activity + Fragment – 追加の属性 ● 次の画面名 ● 滞在時間 – ミリ秒やナノ秒
53.
DroidKaigi 2018 @cattaka_net53 スクリーンログの例 画面名 画面の 追加属性 次の画面の 追加属性 次の画面名
滞在時間 time user_id screen screen_params next_screen next_params duration 1234 ListActivity DetailActivity {"item_id": 432} 46231 1234 DetailActivity {"item_id": 432} ListActivity 82323 1234 ListActivity DetailActivity {"item_id": 234} 53341 1234 DetailActivity {"item_id": 234} 72652 2018/02/09 12:30 2018/02/09 12:31 2018/02/09 12:32 2018/02/09 12:33
54.
DroidKaigi 2018 @cattaka_net54 スクリーンログのアプローチ ● ActivityやFragment単位で取る ● トラッカーを埋める場所 –
onStart / onResume – onStop / onPause ● onStart 〜 onStop で滞在時間が出せる – FAは滞在時間は自動でやってくれる
55.
DroidKaigi 2018 @cattaka_net55 ライブラリごとの実装の違い
56.
DroidKaigi 2018 @cattaka_net56 スクリーンログの実装:Treasure
Data Map<String, Object> event = new HashMap<>(); event.put("user_id", userId); event.put("activity", activity); event.put("fragment", fragment); event.put("params", params); event.put("next_activity", nextActivityName); event.put("next_fragment", nextFragmentName); event.put("next_params", nextParams); event.put("duration", duration); TreasureData.sharedInstance() .addEvent("screen_log", event); 全部自分でやる! ユーザー識別子 画面 次の画面 滞在時間 ※:onStopなどに書く
57.
DroidKaigi 2018 @cattaka_net57 スクリーンログの実装:Firebase Analytics mFirebaseAnalytics.setCurrentScreen( activity,
// Activity "DetailActivity", // screenName null // screenClassOverride ); 滞在時間や次の画面の遷移、 ユーザー識別子はやってくれる ←画面名 ※:onStartなどに書く
58.
DroidKaigi 2018 @cattaka_net58 スクリーンログの実装:Google
Analytics mTracker.setScreenName("DetailActivity"); mTracker.send( new HitBuilders.ScreenViewBuilder().build()); ←画面名 ※:onStartなどに書く
59.
DroidKaigi 2018 @cattaka_net59 トラッカーの実装Tips
60.
DroidKaigi 2018 @cattaka_net60 トラッカーのコードは簡潔安全にしたい
61.
DroidKaigi 2018 @cattaka_net61 WHY ● 機能の実装者の負荷を減らしたい ● トラッカー起因のクラッシュは0にしたい ● トラッカーはミスなく動いてほしい
62.
DroidKaigi 2018 @cattaka_net62 FAでベタで書いたときの問題 Bundle
bundle = new Bundle(); bundle.putLong ( "item_id", id ); bundle.putString( "item_name", name ); mFirebaseAnalytics.logEvent("select_content", bundle); イベント名を定数にしたい 属性名を定数にしたい 値を型安全にしたい これらは一度コードに散らばると回収不可能になる
63.
DroidKaigi 2018 @cattaka_net63 アプローチ ● トラッカー用の便利メソッドを作る –
イベントをenum化する – 属性をGenericsで型のある定数にする – Generics芸を使った便利メソッドを作る
64.
DroidKaigi 2018 @cattaka_net64 イベントをenum化する public
enum Event { SELECT_CONTENT("select_content"), CLICK("click"), // TODO: イベントはここに追加していく ; public final String key; Event(String key) { this.key = key; } }
65.
DroidKaigi 2018 @cattaka_net65 属性をGenericsで型のある定数にする public
class Param<T> { public static final Param<Long> ITEM_ID = new Param<>("item_id", BaseBundle::putLong); public static final Param<String> ITEM_NAME = new Param<>("item_name", BaseBundle::putString); String key; IFunc<T> putFunc; private Param(String key, IFunc<T> putFunc) { this.key = key; this.putFunc = putFunc; } public interface IFunc<V> { void put(Bundle dest, String key, V value); } }
66.
DroidKaigi 2018 @cattaka_net66 Generics芸を使った便利メソッドを作る public
<V1, V2> void logEvent( Event event, Param<V1> k1, V1 v1, Param<V2> k2, V2 v2 ) { Bundle bundle = new Bundle(); k1.putFunc.put(bundle, k1.key, v1); k2.putFunc.put(bundle, k2.key, v2); mFirebaseAnalytics.logEvent(event.key, bundle); } // イベント名 // 属性1 // 値1 // 属性2 // 値2 型安全が守られる 型安全が守られる
67.
DroidKaigi 2018 @cattaka_net67 便利メソッドを使った場合 MyTracker.getInstance().logEvent( Event.SELECT_CONTENT, Param.ITEM_ID,
id, Param.ITEM_NAME, name); ● だいぶ短くなった ● イベント名と属性名が定数化された ● 属性の値が型安全になった
68.
DroidKaigi 2018 @cattaka_net68 このアプローチの課題の考察 ● メソッドチェーンの方が良くない? ● 属性の個数は可変だよね?
69.
DroidKaigi 2018 @cattaka_net69 メソッドチェーンの方が良くない? MyTracker.getInstance() .logEvent(Event.SELECT_CONTENT) .put(
Param.ITEM_ID, id ) .put( Param.ITEM_NAME, name ) .send(); たしかに、いいかもしれない、、、けど、、、 これを忘れる事故が起こる
70.
DroidKaigi 2018 @cattaka_net70 属性の個数は可変だよね? ● 諦めて属性の 数ごとに作る ● RxJavaも 似たことをしてる ● 0〜7個あれば 実用十分 public
<V1, V2, V3, V4, V5, V6> void logEvent( Event event, Param<V1> k1, V1 v1, Param<V2> k2, V2 v2, Param<V3> k3, V3 v3, Param<V4> k4, V4 v4, Param<V5> k5, V5 v5, Param<V6> k6, V6 v6 ) { Bundle bundle = new Bundle(); k1.putFunc.put(bundle, k1.key, v1); k2.putFunc.put(bundle, k2.key, v2); k3.putFunc.put(bundle, k3.key, v3); k4.putFunc.put(bundle, k4.key, v4); k5.putFunc.put(bundle, k5.key, v5); k6.putFunc.put(bundle, k6.key, v6); mFirebaseAnalytics.logEvent(event.key, bundle); } 例:属性が6つの場合
71.
DroidKaigi 2018 @cattaka_net71 僕の結論 ● 便利メソッドが泥臭くなるのは諦める ● 機能の実装者の負担を下げることを最優先
72.
DroidKaigi 2018 @cattaka_net72 複数のライブラリを使うときのアプローチ
73.
DroidKaigi 2018 @cattaka_net73 ログ収集サービスは何個入れる? ● 本発表でも既に複数が出ている –
Firebase Analytics – Google Analytics – Treasure Data ● 他にも広告用のものも使うことがある ● 理想は1つに絞るべきだが、そうも行かない
74.
DroidKaigi 2018 @cattaka_net74 複数のログ収集サービスへの送り分けは? ● 専用の便利クラスを作る Firebase Analytics Treasure Data Google Analytics 便利クラスイベント 個別にコードを書くと長くなるので 送り分けのコードはここにまとめる 後々、どんな計測系サービスを使うかわからないので、 1つしか使わない場合も作っておいたほうが良い
75.
DroidKaigi 2018 @cattaka_net75 スクリーンログのトラッカー
76.
DroidKaigi 2018 @cattaka_net76 個別にコードを入れるのは大変 ● 対策1 –
BaseActivity や BaseFragment を作る ● onStart や onStop などに仕込む public class BaseFragment extends Fragment { @Override public void onStart() { super.onStart(); MyTracker.getInstance().logScreen(this); } } ↑画面用のメソッド
77.
DroidKaigi 2018 @cattaka_net77 個別にコードを入れるのは大変 ● 対策2 –
LifeCycleCallbacks を使う ● ActivityLifecycleCallbacks ● FragmentLifecycleCallbacks
78.
DroidKaigi 2018 @cattaka_net78 FragmentLifecycleCallbacks public
class TrackFragmentLifecycleCallbacks extends FragmentManager.FragmentLifecycleCallbacks { @Override public void onFragmentStarted( FragmentManager fm, Fragment f) { super.onFragmentStarted(fm, f); MyTracker.getInstance().logScreen(f); } } ↑画面用のメソッド
79.
DroidKaigi 2018 @cattaka_net79 FragmentLifecycleCallbacks
の問題 ● 1つの画面に2つFragmentがあると衝突する ● 対策 – マーカーインターフェースを計測の要否に使う
80.
DroidKaigi 2018 @cattaka_net80 マーカーインターフェースを使う @Override public
void onFragmentStarted( FragmentManager fm, Fragment f) { super.onFragmentStarted(fm, f); if (f instanceof ITrackScreen) { MyTracker.getInstance().logScreen(f); } } public interface ITrackScreen {}
81.
DroidKaigi 2018 @cattaka_net81 ViewPagerの問題 ● 左右のFragmentがstart状態になる ● 対策 –
中のFragmentのonResumeでは計測しなくする – 親側で泥臭くハンドリングする ● onStartで最初のFragmentを記録 ● onPageSelectedで切り替わりを記録
82.
DroidKaigi 2018 @cattaka_net82 パッと確認できるようにしておく
83.
DroidKaigi 2018 @cattaka_net83 logcatに出しておく ● トラッカーの確認を検証作業に含めるのは酷 ● 実装者がチラ見でもチェックできるようにする
84.
DroidKaigi 2018 @cattaka_net84 Firebase
AnalyticsのDebugViewを使う ● デバッグを有効にしたデバイスの操作が Webブラウザ上でリアルタイムに確認できる
85.
DroidKaigi 2018 @cattaka_net85 通信についての気遣い
86.
DroidKaigi 2018 @cattaka_net86 実装上の気をつけないといけないこと ● 再送制御 –
雑に独自実装するとエラーが出たときに欠損する ● 送信タイミング – 都度通信するとバッテリーに優しくない – 適当なタイミングでまとめてやって欲しい FA, GA, TDは全部やってくれる
87.
DroidKaigi 2018 @cattaka_net87 Firebase
Analyticsへの気遣い
88.
DroidKaigi 2018 @cattaka_net88 Firebase
Analyticsへの気遣い ● Firebase Analyticsには地味に制約が多い – 制約を守らないとエラーになってログが送れない ● 主な制約 – イベント名の種類は500個まで – イベント名と属性名 ● 英数とアンダースコアで40文字まで – 属性の値は100文字まで – 同一属性名の型は揃えること
89.
DroidKaigi 2018 @cattaka_net89 銀の弾丸は無い、筋肉でカバー
90.
DroidKaigi 2018 @cattaka_net90 ログ取りで気をつけてること
91.
DroidKaigi 2018 @cattaka_net91 1つの指標は最低3系統で確認できること ● おかしな値は割と出る ● 最低3つあれば多数決ができる ● よく使う系統 –
アクションログ – コンバージョンログ – Web側のログやDB
92.
DroidKaigi 2018 @cattaka_net92 ログだけでユーザーの操作を 把握できるようにする ● おかしな数字がでたときは生ログを見る ● 計測がおかしいユーザーを探し、 その行動ログから異常を探る
93.
DroidKaigi 2018 @cattaka_net93 機密情報は入れないこと ● 取扱に困るものはログにいれないこと –
パスワード – メッセージ – 利用規約やプライバシーポリシーに反するもの
94.
DroidKaigi 2018 @cattaka_net94 定量的な数字も必要ならとる ● RecyclerView –
何処までスクロールしたか – どのViewが何秒表示されたか – getGlobalVisibleRectで頑張って実装
95.
DroidKaigi 2018 @cattaka_net96 可視化する
96.
DroidKaigi 2018 @cattaka_net97 最初はExcelとSQL ● Google
BigQueryからSQLでデータを取り出す ● ピボットテーブルでパッと項目別に集計する
97.
DroidKaigi 2018 @cattaka_net98 Excelは強い ● 数十MB、数十万レコードのCSVを開ける ● そのサイズでもピボットテーブルが動く
98.
DroidKaigi 2018 @cattaka_net99 Google
Data Studio(beta) ● データをダッシュボードやレポートにできる ● BigQueryやRDBMSからデータを引っ張れる
99.
DroidKaigi 2018 @cattaka_net100 Domo ● ビジネス管理プラットフォーム ● データの可視化や集約、共有できるサービス ● RDBMSやBigQueryに繋いでグラフが作れる
100.
DroidKaigi 2018 @cattaka_net101 その他 ● Jupyter
notebook ● R ● Tableau ● Metabase ● re:dash ● Chartio 他にもたくさんあるのでググってください
101.
DroidKaigi 2018 @cattaka_net102 過去に起こった失敗
102.
DroidKaigi 2018 @cattaka_net103 Notificationでスパイク ● アクティブユーザーに誤検知されていた ● 操作ではないイベントはNonInteractiveにする –
Receive, Open, Cancel など
103.
DroidKaigi 2018 @cattaka_net105 0 50 100 150 200 250 300 350 400 count 荒ぶるグラフ ● いろんな要因でグラフは壊れる –
アプリの改修時の実装ミス – Web側のDBの構成変更 – APIの改修時の構成変更 壊れたら直す リリース日
104.
DroidKaigi 2018 @cattaka_net106 ProGuard先生ェ... ● ログ上の画面名が
a とか b になっていた – 雑にclass.getSimpleName()でログを取っていた – 何かの弾みで除外指定が外れて難読化されていた
105.
DroidKaigi 2018 @cattaka_net108 onClickイベントが他所から叩かれていた ● トラッカーは暗黙的にonClickに埋めていた ● 一部の実装がonClickを直接叩いていた ● 画面を開いただけでトラッカーが発火していた
106.
DroidKaigi 2018 @cattaka_net109 広告媒体の違いは怖い ● 広告媒体ごとにユーザーの質が異なる –
CPI(Cost Per Install)と継続率は別 ● 対策 – インストール時のリファラーを記録する ● com.android.vending.INSTALL_REFERRER – 広告の計測ライブラリを使う
107.
DroidKaigi 2018 @cattaka_net110 A/Bテストは同時期にやる ● 時間で分けたA/Bテストは恐ろしい –
「先週と今週で比較」は良くない – 広告を使っていると顕著 ● 同じ期間じゃないと徒労に終わる – Firebase Remote Config的なもので サクッと切り替えられるようにする
108.
DroidKaigi 2018 @cattaka_net112 Next
Action
109.
DroidKaigi 2018 @cattaka_net113 ディープラーニングで!
110.
DroidKaigi 2018 @cattaka_net114 ごめんなさいよくわかりません
111.
DroidKaigi 2018 @cattaka_net115 アプリエンジニア的アプローチ ● 改善したい数字を決める ● 仮設を立てる ● 効果を見積もる ● 施策を実装してリリースする ● 結果を確認する
112.
DroidKaigi 2018 @cattaka_net116 べき論では良くならない ● 「ガイドラインではこう言われています」 ● 「デザインパターンではこう言われています」 ● 本当にそれが人を幸せにするのか?
113.
DroidKaigi 2018 @cattaka_net117 まとめ
114.
DroidKaigi 2018 @cattaka_net118 アプリにはたくさんの人が関わる ● エンジニア ● デザイナー ● ディレクター ● マーケター ● ビジネス ● カスタマーサポート ● etc
115.
DroidKaigi 2018 @cattaka_net119 それぞれの意図が 正しく成功したか失敗したかを 指し示せるかはログに掛かっている
116.
DroidKaigi 2018 @cattaka_net120 アプリエンジニアが ログをちゃんと取れば メンバーが動きやすくなり プロダクトの成長に繋がる
117.
DroidKaigi 2018 @cattaka_net121 皆さんのプロダクトの成長が 人類のQoLを上げると信じてます
118.
DroidKaigi 2018 @cattaka_net122 ログを取ろう
119.
DroidKaigi 2018 @cattaka_net123 WANTEDLY
TECH BOOK 配布中 ● 技術書典1〜3で 頒布した記事の中から アプリ向けのものを激選
120.
DroidKaigi 2018 @cattaka_net124 ご清聴ありがとうございました Takao
Sumitomo
Jetzt herunterladen