5
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

さくらインターネットAdvent Calendar 2016

Day 13

さくらのクラウドの請求情報をPowerBIに取り込んで分析してみよう

Last updated at Posted at 2016-12-14

さくらのアドベントカレンダー13日目です。ごめんなさい。ごめんなさい。ごめんなさい。当日に投稿できなくてごめんなさい。13日目分の記事です。

早々にやらかしてしまったのですが、気を取り直して、本題に行きましょう。

さくらのクラウドはビジネスにも優しいクラウドでありたいと思っています。そのためには課金額の傾向なども簡単に把握できるようになったら良いなと思っています。

課金額の過去の履歴はコンパネ上から見えるとは言え、さらに細かい内容まで分析できると良いですよね。そのために請求関連APIで過去の請求履歴を取得できるように実装をしています。この明細をBIツールに取り込んだらもっと自由な分析が出来るんじゃ無いか?と思い立ったわけです。

そして書いたのがこのツール「sacloud_get_all_billdetails.php」です。PHPですがコマンドラインスクリプトです。今回は、このスクリプトで書き出した請求履歴の明細データを、PowerBIに取り込んで分析をしてみます。(ちなみに、請求データは私のテスト環境のデータを使っています。)

請求履歴の明細データをエクスポートする

使い方は、APIキーを作って、設定ファイルに書き込み、スクリプトを実行するだけです。過去の請求履歴にある全明細を一つのCSVにまとめてます。

1. クラウドのコンパネでAPIキーを作成する

さくらのクラウドのコンパネにログインし、上部のメニューにある「設定」- 下に表示されたメニューの「APIキー」 - 右上の「+追加」を順番にクリックします。

APIキーの追加

名前は適切につけ、「リソース閲覧」以上の権限と、他サービスへのアクセス権で「請求情報」にチェックして、「追加」をクリックします。

APIキー詳細

APIキー一覧画面で該当のキーをダブルクリックするとキーの詳細が表示されます。
「ACCESS TOKEN」と、「ACCESS TOKEN SECRET」が重要なのでメモをします。(ちなみにこのキーは削除済みです。)

2. 設定ファイル sacloudapi_config.php を作成する

以下のようなファイルを作り、先ほどメモをした「ACCESS TOKEN」と、「ACCESS TOKEN SECRET」を追記します。

<?php 
// set API Tocken
$token = "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxxxxx";
// set API Secret
$secret = "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx";

3. スクリプトを実行する

sacloud_get_all_billdetails.phpをダウンロードして、実行します。実行にはphp環境が必要です。

 $ wget https://raw.githubusercontent.com/terao/eisaku/master/sacloud_get_all_billdetails.php
 $ php sacloud_get_all_billdetails.php

しばらく実行には掛かりますが、大人しく待っていると、以下のようなファイルが生成されています。実行時間は利用期間の長さによって前後します。

"bill-会員ID-アカウント名.csv"

これで、過去の請求の明細が一つのファイルにまとまりました。

これをPowerBIに喰わせてみよう

PowerBIは、Microsoftが提供するデータの分析&可視化ツールで、無料で提供されています。

PowerBI

データの取り込み

Microsoftのアカウントが無い場合は登録してからログインしてください。

データの取り込み

データセットの右の「+」、ファイルの下の「取得」、「ローカルコンピュータ」を順にクリックし、先ほど生成されたファイルを選択してインポートしてください。

インポート完了

インポートが完了するとデータが表示されるので、これをクリックします

グラフのカスタマイズ

グラフのタイプ

グラフのタイプは様々なタイプが選択可能です。ここでは積み上げ折れ線グラフを選択します。

グラフの設定

軸、凡例、値は、それぞれ上のように指定します。1

ゾーン別利用料金推移

こうやって作成されたのが、この図になります。一番右が落ち込んでいるのは、月半ばなので請求金額がまだ少ないためです。

このデモを作りながら、さすがにちょっと使いすぎだなと気づけたり、夏頃からテスト環境が大きくなったのはExpoのせいかなといった分析や、石狩第1にまだサーバが残っているので、そろそろ移行しようかなとか分析が出来ました。

商品名ごとの利用料金推移

凡例を、ゾーン名から商品名に入れ替えて見ます。そうすると、こんなグラフになります。さすがに細かすぎてよく分からないので、サーバに絞ってみます。絞るにはフィルターの基本フィルターというところで選択肢を選ぶことが出来ます。

簡単なフィルターを設定

そうすると、サーバのプランによってどのくらいの費用を使っているかが一目で分かります。

サーバプラン別利用料金推移

まとめ

今回は簡単に請求情報をエクスポートして、PowerBIにインポートして分析を出来るようにしました。

PowerBIはこれだけでなく様々な分析が可能なようですので、遊んでみてください。

遅れて申し訳なかったですが、13日目のアドベントカレンダーでした。

皆様!良いクリスマスをお過ごしください!


  1. 商品金額(税別)にΣ(合計)が付かず、個数のカウントになる場合があります。その場合は、ローカルでCSVをエクセル等で開き空欄になっている行が無いかを確認してください。空欄がもしあれば0を書き込んで再度インポートをしてください。PowerBIの使用で全行数字が入っていないと合計を計算してくれないようです。

5
1
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
5
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?