はじめに
ゲームデータの分析なんかできたら面白そうと思い立って簡単にできる分析アプリというものを作ってみたので、備忘録として書きます。
今回はSteamで配信している「7Days To Die」というゲームサーバをAzure上に構築し、そのゲームサーバのログや、サーバへのアクセスログなどをPowerBIで分析したレポートをPowerAppsで表示させるというものを作ってみました。
1.システム構成
2.PowerApps画面
3.PowerBIレポート
4.簡単な構築手順
① スマホからワンプッシュでVMを起動、停止するシステムを構築
以下の記事に構築手順を書いているので割愛します。
AzureAutomationでスマホからazureVMを起動/停止⇒Discordに起動/停止の通知してみた
② ゲームサーバログをLog Analyticsワークスペースに格納
[1]Log Analyticsワークスペースを新規作成
[2]詳細設定→カスタムログを選択
[3]各種設定し、作成
[4]log確認
作成したカスタムログに対してクエリを実行し、結果が返ってくることを確認
※LogAnalyticsワークスペースは、Azure Monitor ログのデータも格納できるため、PowerBIで分析するデータ元としては面白いかも。
③ PowerBIレポートを作成
[1]LogAnalyticsワークスペースでPowerBI用のクエリを保存
[2]PowerBI Desktopを開き、データを取得→空のクエリをクリック
[3]新しいソース→空のクエリをクリック
[4]詳細エディターをクリック
[5]③ー[1]で保存したクエリをコピペし、完了をクリック
[6]データが取得できることを確認し、ファイル→閉じて適用をクリック
[7]以上の手順でLogAnalyticsワークスペース内の必要なデータを取得し、好きなようにPowerBIレポートを作成。
[8]レポートをPowerBIマイワークスペースに格納
ブラウザでPowerBIマイワークスペースにアクセスし、データを取得→ファイル→ローカルファイルで作成したPowerBIレポートを選択
[9]PowerAppsに表示するグラフをピン止めする
マイワークスペースを見るとダッシュボード、データセット、レポートができているので、ダッシュボードをクリックし、タイルをクリックする
レポートの画面に遷移するので、PowerAppsに表示したいグラフをピン止めする
[10]ダッシュボードの共有を行う
Power Appsで追加されたグラフは、Power BI上で共有してからのみアクセスが可能となるため
④ Power Apps作成
[1]アプリにグラフを挿入
新規アプリを作成→挿入→グラフ→Power BI タイルをクリック
[2]データを表示
[3]レポートの表示
PowerAppsの再生ボタンを押して、グラフをクリックすると作成したレポートが表示されます。
5.まとめ
1.Azure上にゲームサーバを構築し、データをLogAnalyticsワークスペースに格納
2.LogAnalyticsワークスペースのデータをPowerBIレポートに取り込む
3.PowerBIレポートをマイワークスペースへアップロード
4.PowerAppsでPowerBIグラフを挿入
6.感想
今回はせっかくゲームサーバをAzure上で構築したので、データもAzure上に格納してみました。
本記事の内容はPowerAppsでPowerBIのレポートを見るだけのものを作っただけですが、ここまでくるまでに副産物でいろいろと学べました。
(過去に投稿したQiita記事の内容など)
あとは、学んだ事で何をしようか?こんな面白いことができるのでは?など妄想しながらやったり、自分がやったことを友人に話したりしてるとモチベーションが保てる事に気づけたことが大きな収穫だと思いました。(やったことが長続きしないタイプなので・・・)
7.参考
Azure Automation の概要
Azure Monitor の Log Analytics の概要
PowerAppsアプリにPower BIのグラフを追加する